Merge remote-tracking branch 'origin/master-vue3' into master-vue3
commit
062ede78a2
10
pages.json
10
pages.json
|
@ -260,16 +260,6 @@
|
||||||
"auth": true,
|
"auth": true,
|
||||||
"title": "物流轨迹"
|
"title": "物流轨迹"
|
||||||
}
|
}
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "express/list",
|
|
||||||
"style": {
|
|
||||||
"navigationBarTitleText": "订单包裹"
|
|
||||||
},
|
|
||||||
"meta": {
|
|
||||||
"auth": true,
|
|
||||||
"title": "订单包裹"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
|
|
@ -13,36 +13,48 @@
|
||||||
天
|
天
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
<view class='list acea-row row-between-wrapper'
|
||||||
|
style='padding: 0 30rpx; height:240rpx;display: flex;justify-content: space-between;align-items: center;'>
|
||||||
|
<view class='item' v-for="(item,index) in state.signConfigList" :key="index">
|
||||||
|
<!-- (index + 1 === state.signConfigList.length ? 'reward' : '') + -->
|
||||||
|
<view :class=" ' ' +( state.continuousDay >= item.day ? 'rewardTxt' : '')">
|
||||||
|
第{{item.day}}天
|
||||||
|
</view>
|
||||||
|
<view class='venus'
|
||||||
|
:class="(index + 1 === state.signConfigList.length ? 'reward' : '') + ' ' +( state.continuousDay >= item.day ? 'venusSelect' : '')">
|
||||||
|
</view>
|
||||||
|
<view class='num' :class='state.continuousDay >= item.day ? "on" : ""'>+{{ item.point }}
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
<!-- 切换年月 -->
|
<!-- 切换年月 -->
|
||||||
<view class="bar ss-flex ss-col-center ss-row-center">
|
<!-- <view class="bar ss-flex ss-col-center ss-row-center">
|
||||||
<view class="previous" @tap="handleCalendar(0)"><text class="cicon-back"></text></view>
|
<view class="previous" @tap="handleCalendar(0)"><text class="cicon-back"></text></view>
|
||||||
<view class="date ss-m-x-20">{{ state.cur_year || '--' }} 年 {{ state.cur_month || '--' }} 月</view>
|
<view class="date ss-m-x-20">{{ state.cur_year || '--' }} 年 {{ state.cur_month || '--' }} 月</view>
|
||||||
<view class="next" @tap="handleCalendar(1)"><text class="cicon-forward"></text></view>
|
<view class="next" @tap="handleCalendar(1)"><text class="cicon-forward"></text></view>
|
||||||
</view>
|
</view> -->
|
||||||
|
|
||||||
<!-- 显示星期 -->
|
<!-- 显示星期 -->
|
||||||
<view class="week ss-flex">
|
<!-- <view class="week ss-flex">
|
||||||
<view class="week-item ss-flex ss-row-center" v-for="(item, index) in state.weeks_ch" :key="index">
|
<view class="week-item ss-flex ss-row-center" v-for="(item, index) in state.weeks_ch" :key="index">
|
||||||
{{ item.title }}
|
{{ item.title }}
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view> -->
|
||||||
|
|
||||||
<!-- 日历表 -->
|
<!-- 日历表 -->
|
||||||
<view class="myDateTable">
|
<view class="myDateTable">
|
||||||
<view v-for="(item, j) in state.data.days" :key="j" class="dateCell ss-flex ss-row-center ss-col-center">
|
<!-- <view v-for="(item, j) in state.data.days" :key="j"
|
||||||
<!-- 空格 -->
|
class="dateCell ss-flex ss-row-center ss-col-center">
|
||||||
<view class="ss-flex ss-row-center ss-col-center">
|
<view class="ss-flex ss-row-center ss-col-center">
|
||||||
<text :decode="true"> </text>
|
<text :decode="true"> </text>
|
||||||
</view>
|
</view>
|
||||||
<view>
|
<view>
|
||||||
<!-- 已签到日期 -->
|
|
||||||
<view v-if="item.is_sign" class="is-sign ss-flex ss-row-center">
|
<view v-if="item.is_sign" class="is-sign ss-flex ss-row-center">
|
||||||
<view class="is-sign-num">{{ item.day < 10 ? '0' + item.day : item.day }}</view>
|
<view class="is-sign-num">{{ item.day < 10 ? '0' + item.day : item.day }}</view>
|
||||||
<image class="is-sign-image" :src="sheep.$url.static('/static/img/shop/app/correct.png')">
|
<image class="is-sign-image"
|
||||||
|
:src="sheep.$url.static('/static/img/shop/app/correct.png')">
|
||||||
</image>
|
</image>
|
||||||
</view>
|
</view>
|
||||||
<!-- 未签到日期 -->
|
|
||||||
<view class="is-sign ss-flex ss-row-center" v-if="item.is_replenish == 1"
|
<view class="is-sign ss-flex ss-row-center" v-if="item.is_replenish == 1"
|
||||||
@tap="onShowRetroactive(item.date)">
|
@tap="onShowRetroactive(item.date)">
|
||||||
<view class="cell-num">{{ item.day < 10 ? '0' + item.day : item.day }}</view>
|
<view class="cell-num">{{ item.day < 10 ? '0' + item.day : item.day }}</view>
|
||||||
|
@ -52,7 +64,7 @@
|
||||||
<view class="cell-num">{{ item.day < 10 ? '0' + item.day : item.day }}</view>
|
<view class="cell-num">{{ item.day < 10 ? '0' + item.day : item.day }}</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view> -->
|
||||||
|
|
||||||
<!-- 签到按钮 -->
|
<!-- 签到按钮 -->
|
||||||
<view class="ss-flex ss-col-center ss-row-center sign-box ss-m-y-40">
|
<view class="ss-flex ss-col-center ss-row-center sign-box ss-m-y-40">
|
||||||
|
@ -125,12 +137,20 @@
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { onLoad, onReady } from '@dcloudio/uni-app';
|
import {
|
||||||
import { computed, reactive } from 'vue';
|
onLoad,
|
||||||
|
onReady
|
||||||
|
} from '@dcloudio/uni-app';
|
||||||
|
import {
|
||||||
|
computed,
|
||||||
|
reactive
|
||||||
|
} from 'vue';
|
||||||
|
|
||||||
const headerBg = sheep.$url.css('/static/img/shop/app/sign.png');
|
const headerBg = sheep.$url.css('/static/img/shop/app/sign.png');
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
|
signConfigList: [],
|
||||||
|
continuousDay: [],
|
||||||
data: {
|
data: {
|
||||||
days: [], //日历
|
days: [], //日历
|
||||||
rules: {}, //规则
|
rules: {}, //规则
|
||||||
|
@ -138,8 +158,7 @@ const state = reactive({
|
||||||
cur_year: 0, //当前选的年
|
cur_year: 0, //当前选的年
|
||||||
cur_month: 0, //当前选的月
|
cur_month: 0, //当前选的月
|
||||||
cur_day: 0, //当前选择的天
|
cur_day: 0, //当前选择的天
|
||||||
weeks_ch: [
|
weeks_ch: [{
|
||||||
{
|
|
||||||
title: '日',
|
title: '日',
|
||||||
value: '0',
|
value: '0',
|
||||||
},
|
},
|
||||||
|
@ -177,7 +196,11 @@ const state = reactive({
|
||||||
loading: true,
|
loading: true,
|
||||||
});
|
});
|
||||||
async function onSign() {
|
async function onSign() {
|
||||||
const { error, data } = await sheep.$api.activity.signAdd();
|
// 换签到接口
|
||||||
|
const {
|
||||||
|
code: error,
|
||||||
|
data
|
||||||
|
} = await sheep.$api.activity.signAdd();
|
||||||
if (error === 0) {
|
if (error === 0) {
|
||||||
state.showModel = true;
|
state.showModel = true;
|
||||||
state.signin = data;
|
state.signin = data;
|
||||||
|
@ -196,7 +219,10 @@ function onConfirm() {
|
||||||
}
|
}
|
||||||
//补签
|
//补签
|
||||||
async function onRetroactive() {
|
async function onRetroactive() {
|
||||||
const { error, data } = await sheep.$api.activity.replenish({
|
const {
|
||||||
|
error,
|
||||||
|
data
|
||||||
|
} = await sheep.$api.activity.replenish({
|
||||||
date: state.date,
|
date: state.date,
|
||||||
});
|
});
|
||||||
if (error === 0) {
|
if (error === 0) {
|
||||||
|
@ -206,7 +232,14 @@ async function onRetroactive() {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getData(mouth) {
|
async function getData(mouth) {
|
||||||
const { error, data } = await sheep.$api.activity.signList(mouth);
|
const {
|
||||||
|
error,
|
||||||
|
data
|
||||||
|
} = await sheep.$api.activity.signList(mouth);
|
||||||
|
const res = await sheep.$api.activity.configLise();
|
||||||
|
const res2 = await sheep.$api.activity.recordPage();
|
||||||
|
// 替换数据
|
||||||
|
const ren = await sheep.$api.activity.getSummary();
|
||||||
if (error === 0) {
|
if (error === 0) {
|
||||||
state.data = data;
|
state.data = data;
|
||||||
} else {
|
} else {
|
||||||
|
@ -236,7 +269,14 @@ async function getData(mouth) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
state.continue_days = data.continue_days;
|
if (res.code == 0) {
|
||||||
|
state.signConfigList = res.data;
|
||||||
|
}
|
||||||
|
if (res2.code == 0) {
|
||||||
|
state.continuousDay = res2.data.list;
|
||||||
|
}
|
||||||
|
state.isSign = ren.data.todaySignIn ? 1 : 0;
|
||||||
|
state.continue_days = ren.data.continuousDay;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -509,4 +549,53 @@ const handleCalendar = (type) => {
|
||||||
color: #666666;
|
color: #666666;
|
||||||
line-height: 40rpx;
|
line-height: 40rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.reward {
|
||||||
|
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEsAAAA4CAYAAAC1+AWFAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQyIDc5LjE2MDkyNCwgMjAxNy8wNy8xMy0wMTowNjozOSAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDowYWFmYjU3Mi03MGJhLTRiNDctOTI2Yi0zOThlZDkzZDkxMDkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6RUEyNzZEMjZEMDFCMTFFOEIzQzhEMjMxNjI1NENDQjciIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6RUEyNzZEMjVEMDFCMTFFOEIzQzhEMjMxNjI1NENDQjciIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTggKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6ZmRjNTM0MmUtNmFkOC1iMDRhLThjZTEtMjk2YWYzM2FkMmUxIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjBhYWZiNTcyLTcwYmEtNGI0Ny05MjZiLTM5OGVkOTNkOTEwOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PuGQ9m8AAAf3SURBVHja7Jxbb9xEFMe9Xu81u6VJL0kqSCToZ0CCNyp4CQ0FqVAkQAgeEE98EPgEwBOCSoCEQPTCG30BVSpfAaQ2KQ1tc4Fm77v2cv7jmc3UGdvjsTdrJEY68m527Zn5zZlzszeF8XhspWl37/xhZdwK/Di2jqA9ufqM9ndtKz+tTvIpSYdkl7+u52h8lpMjUFdIzvH3VZIPSM6SrHOAM292DkHJ7Rz/rP4/rGhQuQNm5xxUroAVNm//PhUnQ7JEco9LGlBy+znGhsX1O1vNajYbjwm1F0l+JfmN5BeSlwKfx4KybTtWw6TriXao39xpFga8v98q08tPSN7Dn0yvVSqVrEqlbBUKBQvxX78/sIbDoenlxhzs6ySDPNmsj0k+SguqWq0wUGwV6Yj35XIpTXD7Csk3eTPw76c5GUAARtUqlVTA0C5wOzd7WLQF19JoFEAASFRLCQwa9hXJ2rQj+GdJ3sCcQj4vkrw7TVAyMLTBwMiGHSP5luQLEjfkO0O+ZW+ZGPjnuIE8YQoDEyyVnIkdmmaDQxgOR+QU+mku85DkZe5RE23D19KCguYcBSjhEHxNLStBarZTJBdNtuGcqlNVx6q4CBo1iwavipDjsUk6Rdq+I0u1brZdkKpCrDVMYLlBUMVikQ0mGM4EBydWeiYpiaLfWq1GwEbKUAwQPc+Vz3NTlWgEqHq9xo7BpoKVpwbNDwtNbHto9XpdAjaOXWBtWNhWAOV53lQnBiPdarWs+fnjmRr/MLtVLjvUp2O57tCK2wwJ4qxCyECyhXX//n3r3tZWxp4yel4+pPiJRMHydAbR7XYzm5Trutbu3p41pFjq0aNHmV0XY0ywqJ4JrIoOKEwwq7a9s2M5RYe5/+3tnUwXIQGwSlJYyKfeMgVlkprAFu7t/c3OLZfLLLhst9vGmUEKYG/x+WvBQgT7ZTDfE8ZPB5RuCiO33d095o0cx2HhCeThw+1UAbEusIAXbPL5r8XBWuf5UVP2JNgWGLzrelMBhT72yFaVCFSRBK6+SNux1+sxmSYwaDQ0GfOTPGaTc1gPyw2R3nwdTJoRMiCow4U6HXNQKOJ1uz0KAvssGR4MBuw4Gg2ZHyqX/O0HzRKTwHcQw/mhCwLisj8x9EVH9FetViOhYTurkm+EQZgXlAqahf4wvtFoJGsaAshLJD/IcdYaJ1mSV9uvM/mD6fX6oaAANE6jcO6dOxtsUEVKP+yCzVINaJJDAwckTEAu/mG1cRyNXBZlQ8vanY7lkYa77shaWVmJhYVxiSQ7OB6ARLCKz6HNtVqVaR364+Mocy6vkvwEzUKR/6blF/snoDB4ROyixLu/3wodUKMxp5XeQLs2NzdZtGwXAazABolzZZHH4SGgJMCAjF0CaJClpSWr2Wxqb/NWS+0s5Dq+r2Eu30GePJZNkuehWSsyKFmrsPKYWFwqoZsHQlNWV1etra2/2ORlUGF5XhGLxaFiXK5XsM6cXmZbKEm+iPOD2UewXz+tI013SqRdfTmifwqMYOA3SO7GlTUOJ9AHBjLJwyXYamfOLDO7k+Q88c3lpcVEoCYaqkjThH3USI3AZ8PmLz7klcIJcRhFWRWx91VJtDCiSRPbpcVFZqy9iLxNngBGsUigTLytanyYS/Bavn0cMacjadWQ87knQodr3OoPxEm+i+2xFfG3il/qUAEzqVDimsePP0HG2o2EJbRibq7OPKYJqKBxlz2hvIAHc55UIIQ3vBaMs77nVcK2TBkns5WNAQZNTAoM13Y1qhjCrZuACoYNKlAHc+1OlINzuMi5KIPSK5xkS1wEHgzeQUfDkgLr9roJwHanBgoaFfCALc7hSly6A5V7h2RfqCc6hSofxEDZAOt1+4e2GzTN46/F9hQrr5u0q0AdhEKHzQGCXym22ufzv6abSCNivRzMC4O5ol+udZTA9Ap9AxZrjflWw7VOnzrJPF61WmNwvIkJsLW1K9g/dod4LCDchk5eXhYRe5JKaax6IA7DILDqJvZEBJ0O+br5hXlmxEU7eXKBJt2gnPEf2iIdNhlkEY1Gw6D6Opgshka40jcpK8dWUYXhN2mwEdCWEwsL1rFjTeV1EFosLp5ixv3BgwcMmsndueXlZV9L9UridqoafFwIYNKQ0509+3TU40WThpxtdXWFwzKrwWdxtykBrPFkb2dRdweApK1erxvDCltoP2IPv8eQGJbwiOK+4YxuCabS/jDNQgkINldDwSNhFVWBIaDJ/YatWlaqn4UWAYbqoTh8FZ8Fxlo0gdUOrg6LgxSxjsruIC5L+VyVUVNBYZmCMkYrMI0KLGrLxOMhzN9RlTqCEhUYjsfjI9MoPyAeKNMl1bgVzzmg6P+diWbd5BXUS3IFVbFV8XzWXBiwqGg+ac0+rESs6bGxU1I9nxVn4G9FnSylR1e13ElIpK0DzBQUb0hh3iS5nkZ7s3i0+zqHZdR0csmUoJBevJ0WVCaweLuYZjBRwFKC8jioH7OYZCawSLsGJLg5i/tswWwX79fp8wKE27cbKmDI/YRDwBHvFaBw7px0vUJEvxesHD7aLaBd5QPc4H+6jff87+I7yFnOq4DB7eMuTLvdYbfuFWEAzjnPryE3Zb9pzIPSUUzxtzvLJH9a4b+hqfPJvKB5zRsccidlv+awZvyzX11gOqDMVvU/9LPf0C15FKBmarOmACw3oPICSwb2OQlu4+Cxv8/yBCoPNitsAcdWDv9Vwb8CDACdCFE+P8dk8gAAAABJRU5ErkJggg==');
|
||||||
|
width: 75rpx;
|
||||||
|
height: 56rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.rewardTxt {
|
||||||
|
width: 74rpx;
|
||||||
|
height: 32rpx;
|
||||||
|
background-color: #f4b409;
|
||||||
|
border-radius: 16rpx;
|
||||||
|
font-size: 20rpx;
|
||||||
|
color: #a57d3f;
|
||||||
|
line-height: 32rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.venusSelect {
|
||||||
|
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADgAAAA4CAYAAACohjseAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQyIDc5LjE2MDkyNCwgMjAxNy8wNy8xMy0wMTowNjozOSAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDowYWFmYjU3Mi03MGJhLTRiNDctOTI2Yi0zOThlZDkzZDkxMDkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6QzkwRkI4NEFEMDFCMTFFODhDNDdBMDVGOTBBN0U2NTQiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6QzkwRkI4NDlEMDFCMTFFODhDNDdBMDVGOTBBN0U2NTQiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTggKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6ZmRjNTM0MmUtNmFkOC1iMDRhLThjZTEtMjk2YWYzM2FkMmUxIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjBhYWZiNTcyLTcwYmEtNGI0Ny05MjZiLTM5OGVkOTNkOTEwOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PkX00M0AAAfVSURBVHjaxFpdcBNVFD67STbppn9poU0LtSBYykBlgKrjqKOtihbq8ICKILyJwxM+6fjCk2/6pC+O4hs+6fgAbWFw1OID+ICMAwwKlRmKLW3Tpvlrskk3m13Pvdm0NNn//HA73+ymd3Pv+e4595xzT5bJ3DgJNWyMelUqNaD36a8N+9kaEeMR3yAERES952sxsbtya2lIbgQxqH72IT5EbEW8pZKuHkGlugyLyT3aBtW+qpJkKb/qgEeMIAYNnhlUn+Edz2NuokqtNVdTTbqVyhO0Q67qJMt2MnXbTq/cp+9+ZkyOYYFxN4EiLaF5SbokccyKkWRS1z4we4ZDfIE4hmhxvJLNu8HTtg85ekGRRcjOXwIp9pfT4aKIs4iP+f4zYrl78HPEqbLMJNAPXHBI/SQjSTd+PoD3LpCi15wMGVBlSiM+NfSihJ8Jjlt4Rheu5n7wtL+B93IJPO37aH8Z45+ohBdtKUtz7a+jJLK+/dN+BTX5p5MpWh6HF6XNE9iLwr9mSG6VZP65bPR6NVI1BwQZF3BtA+Bq2oG3Pt3HFCVnfUHaX6XQHCeXgVz8Nojz4+SDzTgo2yfIBV9G89utzi5DtRvDcnQ+JSciyd+rH+hdjb22tFOp5mreCUrocg0CPet5LATJvHbldWSiGllIzZpdeR2ZqFPtZTNJSIQeQGv3DucEbcrLmkRSXvP/cs4RZm6Ow/T1McffpyiSJTZ+jDfOZFDlOuARo5p9aKJ2IYkpCN+9AmLsIcSm/3Y0BkWpPCPRX9/nDVI1BTTAI0YRA9r99gWbv3MF90MGvG4WQrfHnRMslWcQMRL55SivbaJk064FjxhFDGj0gad5u22zkrMZiExcBQ7JcW4GlhfuQ3L+gSMTzc9fItcgYiTy8xHeTIOGmnMHtoEn2G971cP3MAUTk+B2MeBBkh4kGbp92ZEGyfxEDj1NLl56j9fbg4U9N6C179zNPZhK7cV7yRZkSYTI3atIjgUXywCLINf03L8gRGZtj0dA5CDyaMg5SPZk+OLhFZLMwtg7hTLDKGJAM09s6QGuY6+upxLTKcgkFmE5FUdFIYQEiHgv4VURl4BjgZon0SA9EeKKi1kZliU8Nnn84OabwIPw+huB8zdR+OqbwdcYMAwB4ux1yEYmtLp+I5WBdft/EApx8Cs9cu6mblyxXXTl9FpOFGDyjzGQMwlwIQlUEDAMagqvhBTVHl4ZplDezpsq+UdOTkMuIcByfBYElCWHmsgpLHQ/NwTe+gaTBH0XWkgGpPgDrfLHl4gTTOj8IVLdTqkF2aIslwF+2zCeGDjzIJ5OwtSVc6Cko9QMCUmWyZMiZJn8cI8E7Lwm11wJOTypBPuHoCG4yVrgz2VBmFBj69pGTvv1hVSN0XSxHE8LRUbaW9G01wdPvHgQQtcugJwMU5LFpIrWDjXMUGIsMNRR5DwcBPcMQV1L0NKchYHIkU2WkiVrTvgT6XEjyN/TY08R5KyAaWc6n3tagMvjhuCzQ+jlOmylVPRZjw/an9kPdYF1lucjIPLJmERoyP9j+8GflIIXPYW4XOKVJAmWZ27Y8nAMaq5t9yB4WjeumJ4hOaIErx/W978JXH2TbY9K5ZNKMhzC5dSjyTapQ5IyFxozvLJGz9Hp/Am+Y7utH8kan+yDhYVp8lVgdDWX33f+ji3gruNpnLPTxNl/8vKtbeTAeKDj0DmhuGShT3Jxkp4guGCv5cnT0QX0hgq4dOnBSshIxxehUbZJbu4OSJEpbXJvnxf0zoP6JMP/keVGTfZYEiCDQlttmXjE1hlTnJ3A+Ketuc53RwSz86AuSXFxitYzueBWUyGWE9E1pqiozoRhXdQJMLAaEyUMMdJyGp2Ux4Lm7iG5h5rkNhweFUpLFtonZANNTmOA3WzmFiGLGY3XlSel0DpOCzRs6gWXj4fkgwnIhKZIcKDhgsTLTCICfMs683gb1tbchiNjgt0TfYFkym7JQkyl8nkoixkMesiGzT1Q19q20t+0dTvwnU/A0iQSDYeoNinBQLOTE/2BjUcvCE5rMoJ2XcSYYBr3FOPmoHHLU+APdtJMpvg7bp8XAr19mKJ1weK9u5CJxUDpMt+HxfJ2HbsoVLzwa1aT4fw8dD3/Au43lv7YYjQF19gAHXv6UYMJa7UepQZFJzMT9fp9lJidorCvgbfkSRXbBB2UDRX5MdREnZYNwZECRcxQXLUnl8s5KPw6MNFsdBFzzdaaE8xGwrUx0eXZORrw3c1NNdEk0ZwUi2OQn7fvZBz9fEZKDjNzFLqn7dYApnVtNtKvecx5oxVfHCsmSt4ts/0rrxiO5NO6jvUWyC0guZgT+SPllu4Jzjr9AT0bjqKWQ1qH0RWQfvKcwzm+s6BB01X6RC1pHIf82w02NRmnsng7WjX28iJqLu5Ec4XXSE5XYg+S91A+UlHS/H2riXfq1n3N8mM2HKOOgutsodkNqZKIMxGQokvFw40jhnFMoZZ70CzyrpLd2S0kb00Oa5KMJDC8LAHL4QEmK4HGKYaSq+/bJFTyZ/GyX+VK3pzUStA1SRJrkTNZrWHG1e8IGuMZt5eqrUH9U8iwUbVci1w1BKnW65RWSVaVnBomAKoI3E9IQEEipX3jap9Q1hxmBElBocp/AmIYcQaRQSQQ36r/E8odvepOxoa5khfRT1pf+8q0/wUYAFU/P0XyeZQPAAAAAElFTkSuQmCC');
|
||||||
|
}
|
||||||
|
|
||||||
|
.venus {
|
||||||
|
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADgAAAA4CAYAAACohjseAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQyIDc5LjE2MDkyNCwgMjAxNy8wNy8xMy0wMTowNjozOSAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDowYWFmYjU3Mi03MGJhLTRiNDctOTI2Yi0zOThlZDkzZDkxMDkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6RDQ3N0E3RkJEMDFCMTFFODhGODVBOTc1NEM5Nzg2NzkiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6RDQ3N0E3RkFEMDFCMTFFODhGODVBOTc1NEM5Nzg2NzkiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTggKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6ZmRjNTM0MmUtNmFkOC1iMDRhLThjZTEtMjk2YWYzM2FkMmUxIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjBhYWZiNTcyLTcwYmEtNGI0Ny05MjZiLTM5OGVkOTNkOTEwOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PnZClGIAAAT7SURBVHja7JtLcxtFEMdnn1rJUhIrTiS7KLsK/EXwNck3gCMcuUFx4QvACW48buHGMZxJPkiowpjC2LElcKzXSqul/6OdoOB9zezsCCimqmvXtdqd+U33dPf0rq2Tn54zg81KjrGuB75x8FbuddsQWIvkS5IxySA5b5no2DUE94TkKPk7IHmf5JDkUQJdW7MNw623o+Ra698KmAdnDNLeIJwRSHvDcLVDVnYynU771fnLl9eFcLZts+VymQf5iJ6pzfFYJeKgT/IZyTskXdWOPM9jjYbPLMticRyz2Sxk8/lc9XFDksckH1IcDKtq8FOSD6rMIuCCoPHXrBIk/qYDC0MlyO1kTBOSj6uuwXerwPn+63DrrdFo8OsV2ns6nEy3Chwg8lpFyK4OwNrgNGpSvxfFoDzP5etJR8PzsiYETmk+X5BjmpkBrHPGU109TeKqv5X3rT3QQ3ObaPDGRjIZXWZpol+b/cebUUA4iuHw938UoNbk9+zsjP16eqoV4JfjH1uqgLjxe10DiaKIDYZDNqfU7OrqSifjkzxIuwDubV2juLi8ZK7j8oT74uJSJ+BRHqQtC6cS/7A9wtrDvb7v84A9Go2UMyQZSFsWrmz6td4GgyF38a7r8lgGefHiQjnjkYG064ZDmjWktecRnEOCDa9DpjqdTrnUDSk2vJXgsHGdTKa0t5vx/V0Yhvy4WMx5hdf3VqYJDQqTxW+QdmECPM8h8flvPPRFR/QXBEEuKEw9Yz/5AyoDtBkei5zriyw4pGVFmoOHPD7+mQ/ccR1mWzZpyuIacx2Hgzl0FJkIjjBTHBeLiO6LuDZH4zFbRkt63oLt7+8XAmJcIhFP0eTn2C9CgzBTrPjUp7XbW6VSJGjx5OSEBhsz2wGkxc0R967LuukuSWKaFEwMnXJQSL/fZ51Op/QSuL5OdVjY7beFBq2sAlHZ/A8aOTg4YKenv/EBr8Nl5ZUO6jPJRGCg0dJie/d3WbPZlMpPMwpZsN0Y2sOVb7PcOzou22CGe3u7fB3J3Cd+udvvScG9soT0Kt13tAZj4UVRwHmWtZClcj+azX6vxx0GN8ECUFyHjnsEp+KlM8b3TBTKBCDqkA/SIFV20jCbO3duk8OIcgHF7G9ttbinVYFLcTBgeAAP+vc4mAkJVywLibARpZvOjWWA36rApYSI1+DSMhltkJPpRGIyJrXAZeWiWiCnk9kNU4RGl8m5MN1VLFzwWKobLm83kQtZbnMb8lgYJ2aIYH//3g73lEHQ5ECAXYUSu7QWZeCKqmoCcqSyPkQgd8lHbne3uSMRbWenSwNtU476BxtT9oJQOZ3OKKloq6SmmXBlyoZKb3nG4wnXyt1ul9261UkN9ggjvd497mDOz885KGN3pfvKg1OuixY15JCHh2/ymFjUms2AMqD9BFB/qwUQg5ZtrVY9b7H/LxtmZSCbaCr9KgGmpEeG6qpzM2tQBHudb5eKNLfKiUMzgAIyL6uRreHklB9qX4MDlQfLpHUV4AY6AB+rzl4ZyIqa+0aHiX6UlDTwMcK2CqQoEGmEE5+RfFK4N636vWjKh0Cp5ceS38k8JXko8yHQ7W7PXKBPBvYwGegNF4/q12g05mV7HXClqgs1ffEr+/LmaTIx0nCb+uI3U5M64Tadi5aBrBXORLKdB1k7nKndhID8GqUaErze/coEXJ1OJm9CY2bw3wr+FGAAoa6PIUihovYAAAAASUVORK5CYII=');
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-size: 100% 100%;
|
||||||
|
width: 56rpx;
|
||||||
|
height: 56rpx;
|
||||||
|
margin: 10rpx 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.num {
|
||||||
|
font-size: 36rpx;
|
||||||
|
font-family: 'Guildford Pro';
|
||||||
|
}
|
||||||
|
|
||||||
|
.item {
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-between;
|
||||||
|
border-bottom: 1px solid #eee;
|
||||||
|
height: 130rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.reward {
|
||||||
|
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEsAAAA4CAYAAAC1+AWFAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQyIDc5LjE2MDkyNCwgMjAxNy8wNy8xMy0wMTowNjozOSAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDowYWFmYjU3Mi03MGJhLTRiNDctOTI2Yi0zOThlZDkzZDkxMDkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6RUEyNzZEMjZEMDFCMTFFOEIzQzhEMjMxNjI1NENDQjciIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6RUEyNzZEMjVEMDFCMTFFOEIzQzhEMjMxNjI1NENDQjciIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTggKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6ZmRjNTM0MmUtNmFkOC1iMDRhLThjZTEtMjk2YWYzM2FkMmUxIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjBhYWZiNTcyLTcwYmEtNGI0Ny05MjZiLTM5OGVkOTNkOTEwOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PuGQ9m8AAAf3SURBVHja7Jxbb9xEFMe9Xu81u6VJL0kqSCToZ0CCNyp4CQ0FqVAkQAgeEE98EPgEwBOCSoCEQPTCG30BVSpfAaQ2KQ1tc4Fm77v2cv7jmc3UGdvjsTdrJEY68m527Zn5zZlzszeF8XhspWl37/xhZdwK/Di2jqA9ufqM9ndtKz+tTvIpSYdkl7+u52h8lpMjUFdIzvH3VZIPSM6SrHOAM292DkHJ7Rz/rP4/rGhQuQNm5xxUroAVNm//PhUnQ7JEco9LGlBy+znGhsX1O1vNajYbjwm1F0l+JfmN5BeSlwKfx4KybTtWw6TriXao39xpFga8v98q08tPSN7Dn0yvVSqVrEqlbBUKBQvxX78/sIbDoenlxhzs6ySDPNmsj0k+SguqWq0wUGwV6Yj35XIpTXD7Csk3eTPw76c5GUAARtUqlVTA0C5wOzd7WLQF19JoFEAASFRLCQwa9hXJ2rQj+GdJ3sCcQj4vkrw7TVAyMLTBwMiGHSP5luQLEjfkO0O+ZW+ZGPjnuIE8YQoDEyyVnIkdmmaDQxgOR+QU+mku85DkZe5RE23D19KCguYcBSjhEHxNLStBarZTJBdNtuGcqlNVx6q4CBo1iwavipDjsUk6Rdq+I0u1brZdkKpCrDVMYLlBUMVikQ0mGM4EBydWeiYpiaLfWq1GwEbKUAwQPc+Vz3NTlWgEqHq9xo7BpoKVpwbNDwtNbHto9XpdAjaOXWBtWNhWAOV53lQnBiPdarWs+fnjmRr/MLtVLjvUp2O57tCK2wwJ4qxCyECyhXX//n3r3tZWxp4yel4+pPiJRMHydAbR7XYzm5Trutbu3p41pFjq0aNHmV0XY0ywqJ4JrIoOKEwwq7a9s2M5RYe5/+3tnUwXIQGwSlJYyKfeMgVlkprAFu7t/c3OLZfLLLhst9vGmUEKYG/x+WvBQgT7ZTDfE8ZPB5RuCiO33d095o0cx2HhCeThw+1UAbEusIAXbPL5r8XBWuf5UVP2JNgWGLzrelMBhT72yFaVCFSRBK6+SNux1+sxmSYwaDQ0GfOTPGaTc1gPyw2R3nwdTJoRMiCow4U6HXNQKOJ1uz0KAvssGR4MBuw4Gg2ZHyqX/O0HzRKTwHcQw/mhCwLisj8x9EVH9FetViOhYTurkm+EQZgXlAqahf4wvtFoJGsaAshLJD/IcdYaJ1mSV9uvM/mD6fX6oaAANE6jcO6dOxtsUEVKP+yCzVINaJJDAwckTEAu/mG1cRyNXBZlQ8vanY7lkYa77shaWVmJhYVxiSQ7OB6ARLCKz6HNtVqVaR364+Mocy6vkvwEzUKR/6blF/snoDB4ROyixLu/3wodUKMxp5XeQLs2NzdZtGwXAazABolzZZHH4SGgJMCAjF0CaJClpSWr2Wxqb/NWS+0s5Dq+r2Eu30GePJZNkuehWSsyKFmrsPKYWFwqoZsHQlNWV1etra2/2ORlUGF5XhGLxaFiXK5XsM6cXmZbKEm+iPOD2UewXz+tI013SqRdfTmifwqMYOA3SO7GlTUOJ9AHBjLJwyXYamfOLDO7k+Q88c3lpcVEoCYaqkjThH3USI3AZ8PmLz7klcIJcRhFWRWx91VJtDCiSRPbpcVFZqy9iLxNngBGsUigTLytanyYS/Bavn0cMacjadWQ87knQodr3OoPxEm+i+2xFfG3il/qUAEzqVDimsePP0HG2o2EJbRibq7OPKYJqKBxlz2hvIAHc55UIIQ3vBaMs77nVcK2TBkns5WNAQZNTAoM13Y1qhjCrZuACoYNKlAHc+1OlINzuMi5KIPSK5xkS1wEHgzeQUfDkgLr9roJwHanBgoaFfCALc7hSly6A5V7h2RfqCc6hSofxEDZAOt1+4e2GzTN46/F9hQrr5u0q0AdhEKHzQGCXym22ufzv6abSCNivRzMC4O5ol+udZTA9Ap9AxZrjflWw7VOnzrJPF61WmNwvIkJsLW1K9g/dod4LCDchk5eXhYRe5JKaax6IA7DILDqJvZEBJ0O+br5hXlmxEU7eXKBJt2gnPEf2iIdNhlkEY1Gw6D6Opgshka40jcpK8dWUYXhN2mwEdCWEwsL1rFjTeV1EFosLp5ixv3BgwcMmsndueXlZV9L9UridqoafFwIYNKQ0509+3TU40WThpxtdXWFwzKrwWdxtykBrPFkb2dRdweApK1erxvDCltoP2IPv8eQGJbwiOK+4YxuCabS/jDNQgkINldDwSNhFVWBIaDJ/YatWlaqn4UWAYbqoTh8FZ8Fxlo0gdUOrg6LgxSxjsruIC5L+VyVUVNBYZmCMkYrMI0KLGrLxOMhzN9RlTqCEhUYjsfjI9MoPyAeKNMl1bgVzzmg6P+diWbd5BXUS3IFVbFV8XzWXBiwqGg+ac0+rESs6bGxU1I9nxVn4G9FnSylR1e13ElIpK0DzBQUb0hh3iS5nkZ7s3i0+zqHZdR0csmUoJBevJ0WVCaweLuYZjBRwFKC8jioH7OYZCawSLsGJLg5i/tswWwX79fp8wKE27cbKmDI/YRDwBHvFaBw7px0vUJEvxesHD7aLaBd5QPc4H+6jff87+I7yFnOq4DB7eMuTLvdYbfuFWEAzjnPryE3Zb9pzIPSUUzxtzvLJH9a4b+hqfPJvKB5zRsccidlv+awZvyzX11gOqDMVvU/9LPf0C15FKBmarOmACw3oPICSwb2OQlu4+Cxv8/yBCoPNitsAcdWDv9Vwb8CDACdCFE+P8dk8gAAAABJRU5ErkJggg==');
|
||||||
|
width: 75rpx;
|
||||||
|
height: 56rpx;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
|
@ -6,38 +6,26 @@
|
||||||
<view class="detail-wrap ss-p-20">
|
<view class="detail-wrap ss-p-20">
|
||||||
<view class="detail-box">
|
<view class="detail-box">
|
||||||
<view class="tag-box ss-flex ss-col-center ss-row-center">
|
<view class="tag-box ss-flex ss-col-center ss-row-center">
|
||||||
<image
|
<image class="tag-image" :src="sheep.$url.static('/static/img/shop/app/coupon_icon.png')"
|
||||||
class="tag-image"
|
mode="aspectFit"></image>
|
||||||
:src="sheep.$url.static('/static/img/shop/app/coupon_icon.png')"
|
|
||||||
mode="aspectFit"
|
|
||||||
></image>
|
|
||||||
</view>
|
</view>
|
||||||
<view class="top ss-flex-col ss-col-center">
|
<view class="top ss-flex-col ss-col-center">
|
||||||
<view class="title ss-m-t-50 ss-m-b-20 ss-m-x-20">{{ state.list.name }}</view>
|
<view class="title ss-m-t-50 ss-m-b-20 ss-m-x-20">{{ state.list.name }}</view>
|
||||||
<view class="subtitle ss-m-b-50">{{ state.list.amount_text }}</view>
|
<view class="subtitle ss-m-b-50">满{{ state.list.enough }}减{{ state.list.amount }}</view>
|
||||||
<button
|
<!-- (state.list.get_status != 'can_get' && state.list.get_status != 'can_use') ||
|
||||||
class="ss-reset-button ss-m-b-30"
|
state.userCouponId -->
|
||||||
:class="
|
<button class="ss-reset-button ss-m-b-30" :class="
|
||||||
state.list.get_status == 'can_get' || state.list.get_status == 'can_use'
|
state.list.get_status == 'can_get' || state.list.get_status == 'can_use'
|
||||||
? 'use-btn'
|
? 'use-btn'
|
||||||
: 'disable-btn'
|
: 'disable-btn' " :disabled="state.list.status_text=='已过期'" @click="getCoupon">
|
||||||
"
|
<!-- {{ state.list.get_status_text }} -->
|
||||||
:disabled="
|
立即使用
|
||||||
(state.list.get_status != 'can_get' && state.list.get_status != 'can_use') ||
|
|
||||||
state.userCouponId
|
|
||||||
"
|
|
||||||
@click="getCoupon"
|
|
||||||
>
|
|
||||||
{{ state.list.get_status_text }}
|
|
||||||
</button>
|
</button>
|
||||||
<view
|
<view class="time ss-m-y-30" v-if="
|
||||||
class="time ss-m-y-30"
|
|
||||||
v-if="
|
|
||||||
state.list.get_status == 'can_get' ||
|
state.list.get_status == 'can_get' ||
|
||||||
state.list.get_status == 'cannot_get' ||
|
state.list.get_status == 'cannot_get' ||
|
||||||
state.list.get_status == 'get_over'
|
state.list.get_status == 'get_over'
|
||||||
"
|
">
|
||||||
>
|
|
||||||
领取时间:{{ state.list.get_start_time }}至{{ state.list.get_end_time }}
|
领取时间:{{ state.list.get_start_time }}至{{ state.list.get_end_time }}
|
||||||
</view>
|
</view>
|
||||||
<view class="time ss-m-y-30" v-else>
|
<view class="time ss-m-y-30" v-else>
|
||||||
|
@ -61,79 +49,51 @@
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<!-- 适用商品 -->
|
<!-- 适用商品 -->
|
||||||
<view
|
<view class="all-user ss-flex ss-row-center ss-col-center" v-if="state.list.use_scope == 'all_use'">
|
||||||
class="all-user ss-flex ss-row-center ss-col-center"
|
|
||||||
v-if="state.list.use_scope == 'all_use'"
|
|
||||||
>
|
|
||||||
{{ state.list.use_scope_text }}
|
{{ state.list.use_scope_text }}
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<su-sticky v-else bgColor="#fff">
|
<su-sticky v-else bgColor="#fff">
|
||||||
<view class="goods-title ss-p-20">{{ state.list.use_scope_text }}</view>
|
<view class="goods-title ss-p-20">{{ state.list.use_scope_text }}</view>
|
||||||
<su-tabs
|
<su-tabs :scrollable="true" :list="state.tabMaps" @change="onTabsChange" :current="state.currentTab"
|
||||||
:scrollable="true"
|
v-if="state.list.use_scope == 'category'"></su-tabs>
|
||||||
:list="state.tabMaps"
|
|
||||||
@change="onTabsChange"
|
|
||||||
:current="state.currentTab"
|
|
||||||
v-if="state.list.use_scope == 'category'"
|
|
||||||
></su-tabs>
|
|
||||||
</su-sticky>
|
</su-sticky>
|
||||||
<view v-if="state.list.use_scope == 'goods' || state.list.use_scope == 'disabled_goods'">
|
<view v-if="state.list.use_scope == 'goods' || state.list.use_scope == 'disabled_goods'">
|
||||||
<view v-for="(item, index) in state.list.items_value" :key="index">
|
<view v-for="(item, index) in state.list.items_value" :key="index">
|
||||||
<s-goods-column
|
<s-goods-column class="ss-m-20" size="lg" :data="item"
|
||||||
class="ss-m-20"
|
|
||||||
size="lg"
|
|
||||||
:data="item"
|
|
||||||
:titleColor="props.goodsFieldsStyle?.title?.color"
|
:titleColor="props.goodsFieldsStyle?.title?.color"
|
||||||
:subTitleColor="props.goodsFieldsStyle?.subtitle?.color"
|
:subTitleColor="props.goodsFieldsStyle?.subtitle?.color"
|
||||||
@click="sheep.$router.go('/pages/goods/index', { id: item.id })"
|
@click="sheep.$router.go('/pages/goods/index', { id: item.id })" :goodsFields="{
|
||||||
:goodsFields="{
|
|
||||||
title: { show: true },
|
title: { show: true },
|
||||||
subtitle: { show: true },
|
subtitle: { show: true },
|
||||||
price: { show: true },
|
price: { show: true },
|
||||||
original_price: { show: true },
|
original_price: { show: true },
|
||||||
sales: { show: true },
|
sales: { show: true },
|
||||||
stock: { show: false },
|
stock: { show: false },
|
||||||
}"
|
}" :buttonShow="state.list.use_scope != 'disabled_goods'"></s-goods-column>
|
||||||
:buttonShow="state.list.use_scope != 'disabled_goods'"
|
|
||||||
></s-goods-column>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view v-if="state.list.use_scope == 'category'">
|
<view v-if="state.list.use_scope == 'category'">
|
||||||
<view v-for="(item, index) in state.pagination.data" :key="index">
|
<view v-for="(item, index) in state.pagination.data" :key="index">
|
||||||
<s-goods-column
|
<s-goods-column class="ss-m-20" size="lg" :data="item"
|
||||||
class="ss-m-20"
|
|
||||||
size="lg"
|
|
||||||
:data="item"
|
|
||||||
:titleColor="props.goodsFieldsStyle?.title?.color"
|
:titleColor="props.goodsFieldsStyle?.title?.color"
|
||||||
:subTitleColor="props.goodsFieldsStyle?.subtitle?.color"
|
:subTitleColor="props.goodsFieldsStyle?.subtitle?.color"
|
||||||
@click="sheep.$router.go('/pages/goods/index', { id: item.id })"
|
@click="sheep.$router.go('/pages/goods/index', { id: item.id })" :goodsFields="{
|
||||||
:goodsFields="{
|
|
||||||
title: { show: true },
|
title: { show: true },
|
||||||
subtitle: { show: true },
|
subtitle: { show: true },
|
||||||
price: { show: true },
|
price: { show: true },
|
||||||
original_price: { show: true },
|
original_price: { show: true },
|
||||||
sales: { show: true },
|
sales: { show: true },
|
||||||
stock: { show: false },
|
stock: { show: false },
|
||||||
}"
|
}" :buttonShow="state.list.use_scope != 'disabled_goods'"></s-goods-column>
|
||||||
:buttonShow="state.list.use_scope != 'disabled_goods'"
|
|
||||||
></s-goods-column>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<uni-load-more
|
<uni-load-more v-if="state.pagination.total > 0 && state.list.use_scope == 'category'"
|
||||||
v-if="state.pagination.total > 0 && state.list.use_scope == 'category'"
|
:status="state.loadStatus" :content-text="{
|
||||||
:status="state.loadStatus"
|
|
||||||
:content-text="{
|
|
||||||
contentdown: '上拉加载更多',
|
contentdown: '上拉加载更多',
|
||||||
}"
|
}" @tap="loadmore" />
|
||||||
@tap="loadmore"
|
<s-empty v-if="state.list.use_scope == 'category' && state.pagination.total === 0" paddingTop="0"
|
||||||
/>
|
icon="/static/soldout-empty.png" text="暂无商品">
|
||||||
<s-empty
|
|
||||||
v-if="state.list.use_scope == 'category' && state.pagination.total === 0"
|
|
||||||
paddingTop="0"
|
|
||||||
icon="/static/soldout-empty.png"
|
|
||||||
text="暂无商品"
|
|
||||||
>
|
|
||||||
</s-empty>
|
</s-empty>
|
||||||
</view>
|
</view>
|
||||||
</s-layout>
|
</s-layout>
|
||||||
|
@ -141,8 +101,13 @@
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { onLoad, onReachBottom } from '@dcloudio/uni-app';
|
import {
|
||||||
import { reactive } from 'vue';
|
onLoad,
|
||||||
|
onReachBottom
|
||||||
|
} from '@dcloudio/uni-app';
|
||||||
|
import {
|
||||||
|
reactive
|
||||||
|
} from 'vue';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
|
||||||
const pagination = {
|
const pagination = {
|
||||||
|
@ -216,7 +181,10 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
async function getCoupon() {
|
async function getCoupon() {
|
||||||
const { error, msg } = await sheep.$api.coupon.get(state.couponId);
|
const {
|
||||||
|
error,
|
||||||
|
msg
|
||||||
|
} = await sheep.$api.coupon.get(state.couponId);
|
||||||
if (error === 0) {
|
if (error === 0) {
|
||||||
uni.showToast({
|
uni.showToast({
|
||||||
title: msg,
|
title: msg,
|
||||||
|
@ -227,10 +195,15 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
async function getCouponContent(id, c) {
|
async function getCouponContent(id, c) {
|
||||||
const { data } = await sheep.$api.coupon.detail(id, c);
|
const {
|
||||||
|
data
|
||||||
|
} = await sheep.$api.coupon.detail(id, c);
|
||||||
state.list = data;
|
state.list = data;
|
||||||
data.items_value.forEach((i) => {
|
data.items_value.forEach((i) => {
|
||||||
state.tabMaps.push({ name: i.name, value: i.id });
|
state.tabMaps.push({
|
||||||
|
name: i.name,
|
||||||
|
value: i.id
|
||||||
|
});
|
||||||
});
|
});
|
||||||
state.pagination = pagination;
|
state.pagination = pagination;
|
||||||
if (state.list.use_scope == 'category') {
|
if (state.list.use_scope == 'category') {
|
||||||
|
@ -244,6 +217,12 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
onLoad((options) => {
|
onLoad((options) => {
|
||||||
|
if (options.data) {
|
||||||
|
let data = JSON.parse(options.data);
|
||||||
|
console.log(data);
|
||||||
|
state.list = data;
|
||||||
|
return;
|
||||||
|
}
|
||||||
state.couponId = options.id;
|
state.couponId = options.id;
|
||||||
state.userCouponId = options.user_coupon_id;
|
state.userCouponId = options.user_coupon_id;
|
||||||
getCouponContent(state.couponId, state.userCouponId);
|
getCouponContent(state.couponId, state.userCouponId);
|
||||||
|
@ -262,13 +241,11 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.detail-wrap {
|
.detail-wrap {
|
||||||
background: linear-gradient(
|
background: linear-gradient(180deg,
|
||||||
180deg,
|
|
||||||
var(--ui-BG-Main),
|
var(--ui-BG-Main),
|
||||||
var(--ui-BG-Main-gradient),
|
var(--ui-BG-Main-gradient),
|
||||||
var(--ui-BG-Main),
|
var(--ui-BG-Main),
|
||||||
#fff
|
#fff);
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.detail-box {
|
.detail-box {
|
||||||
|
@ -276,6 +253,7 @@
|
||||||
border-radius: 6rpx;
|
border-radius: 6rpx;
|
||||||
position: relative;
|
position: relative;
|
||||||
margin-top: 100rpx;
|
margin-top: 100rpx;
|
||||||
|
|
||||||
.tag-box {
|
.tag-box {
|
||||||
width: 140rpx;
|
width: 140rpx;
|
||||||
height: 140rpx;
|
height: 140rpx;
|
||||||
|
|
|
@ -7,12 +7,11 @@
|
||||||
<s-empty v-if="state.pagination.total === 0" icon="/static/coupon-empty.png" text="暂无优惠券"></s-empty>
|
<s-empty v-if="state.pagination.total === 0" icon="/static/coupon-empty.png" text="暂无优惠券"></s-empty>
|
||||||
<template v-if="state.currentTab == '0'">
|
<template v-if="state.currentTab == '0'">
|
||||||
<view v-for="item in state.pagination.list" :key="item.id">
|
<view v-for="item in state.pagination.list" :key="item.id">
|
||||||
<s-coupon-list :data="item">
|
<s-coupon-list :data="item" @tap="
|
||||||
<!-- @tap="
|
|
||||||
sheep.$router.go('/pages/coupon/detail', {
|
sheep.$router.go('/pages/coupon/detail', {
|
||||||
id: item.id,
|
data: JSON.stringify(item),
|
||||||
})
|
})">
|
||||||
" -->
|
|
||||||
<template #default>
|
<template #default>
|
||||||
<button class="ss-reset-button card-btn ss-flex ss-row-center ss-col-center"
|
<button class="ss-reset-button card-btn ss-flex ss-row-center ss-col-center"
|
||||||
:class="item.get_status != 'can_get' ? 'border-btn' : ''" @click.stop="getBuy(item.id)"
|
:class="item.get_status != 'can_get' ? 'border-btn' : ''" @click.stop="getBuy(item.id)"
|
||||||
|
@ -26,12 +25,12 @@
|
||||||
</template>
|
</template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<view v-for="item in state.pagination.list" :key="item.id">
|
<view v-for="item in state.pagination.list" :key="item.id">
|
||||||
<s-coupon-list :data="item" type="user">
|
<s-coupon-list :data="item" type="user" @tap="
|
||||||
<!-- @tap="
|
|
||||||
sheep.$router.go('/pages/coupon/detail', {
|
sheep.$router.go('/pages/coupon/detail', {
|
||||||
id: item.id,
|
data: JSON.stringify(item),
|
||||||
})
|
})
|
||||||
" -->
|
">
|
||||||
|
|
||||||
<template #default>
|
<template #default>
|
||||||
<button class="ss-reset-button card-btn ss-flex ss-row-center ss-col-center" :class="
|
<button class="ss-reset-button card-btn ss-flex ss-row-center ss-col-center" :class="
|
||||||
item.status == 'can_get' || item.status == 'can_use'
|
item.status == 'can_get' || item.status == 'can_use'
|
||||||
|
@ -148,19 +147,14 @@
|
||||||
});
|
});
|
||||||
if (res.code === 0) {
|
if (res.code === 0) {
|
||||||
// 拦截修改数据
|
// 拦截修改数据
|
||||||
let obj2 = {
|
|
||||||
2: '折扣',
|
|
||||||
1: '满减'
|
|
||||||
}
|
|
||||||
let obj = {
|
let obj = {
|
||||||
1: '可用',
|
1: '可用',
|
||||||
2: '已用',
|
2: '已用',
|
||||||
3: '过期'
|
3: '过期'
|
||||||
}
|
}
|
||||||
let obj3 = {
|
let obj2 = {
|
||||||
1: '已领取',
|
1: '满减',
|
||||||
2: '已使用',
|
2: '折扣'
|
||||||
3: '已过期'
|
|
||||||
}
|
}
|
||||||
res.data.list = res.data.list.map(item => {
|
res.data.list = res.data.list.map(item => {
|
||||||
return {
|
return {
|
||||||
|
|
|
@ -3,35 +3,34 @@
|
||||||
<s-layout title="评价">
|
<s-layout title="评价">
|
||||||
<view>
|
<view>
|
||||||
<view v-for="(item, index) in state.orderInfo.items" :key="item.id">
|
<view v-for="(item, index) in state.orderInfo.items" :key="item.id">
|
||||||
<view v-if="item.btns.includes('comment')">
|
<view>
|
||||||
<view class="commont-from-wrap">
|
<view class="commont-from-wrap">
|
||||||
<!-- 评价商品 -->
|
<!-- 评价商品 -->
|
||||||
<s-goods-item :img="item.goods_image" :title="item.goods_title" :skuText="item.goods_sku_text"
|
<s-goods-item
|
||||||
:price="item.goods_price" :num="item.goods_num"></s-goods-item>
|
:img="item.picUrl"
|
||||||
|
:title="item.spuName"
|
||||||
|
:skuText="item.properties.map((property) => property.valueName).join(' ')"
|
||||||
|
:price="item.payPrice"
|
||||||
|
:num="item.count"
|
||||||
|
/>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<view class="form-item">
|
<view class="form-item">
|
||||||
<!-- 评分 -->
|
<!-- 评分 -->
|
||||||
<view class="star-box ss-flex ss-col-center">
|
<view class="star-box ss-flex ss-col-center">
|
||||||
<view class="star-title ss-m-r-40">
|
<view class="star-title ss-m-r-40">商品质量</view>
|
||||||
<!-- {{ rateMap[state.commentList[index].level] }} -->
|
<uni-rate v-model="state.commentList[index].descriptionScores" />
|
||||||
商品质量
|
|
||||||
</view>
|
|
||||||
<uni-rate v-model="state.commentList[index].level" />
|
|
||||||
</view>
|
</view>
|
||||||
<view class="star-box ss-flex ss-col-center">
|
<view class="star-box ss-flex ss-col-center">
|
||||||
<view class="star-title ss-m-r-40">
|
<view class="star-title ss-m-r-40">服务态度</view>
|
||||||
<!-- {{ rateMap[state.commentList[index].level] }} -->
|
<uni-rate v-model="state.commentList[index].benefitScores" />
|
||||||
服务态度
|
|
||||||
</view>
|
|
||||||
<uni-rate v-model="state.commentList[index].level2" />
|
|
||||||
</view>
|
</view>
|
||||||
<!-- 评价 -->
|
<!-- 评价 -->
|
||||||
<view class="area-box">
|
<view class="area-box">
|
||||||
<uni-easyinput :inputBorder="false" type="textarea" maxlength="120" autoHeight
|
<uni-easyinput :inputBorder="false" type="textarea" maxlength="120" autoHeight
|
||||||
v-model="state.commentList[index].content"
|
v-model="state.commentList[index].content"
|
||||||
placeholder="宝贝满足你的期待吗?说说你的使用心得,分享给想买的他们吧~"></uni-easyinput>
|
placeholder="宝贝满足你的期待吗?说说你的使用心得,分享给想买的他们吧~" />
|
||||||
|
<!-- TODO 芋艿:文件上传 -->
|
||||||
<view class="img-box">
|
<view class="img-box">
|
||||||
<s-uploader v-model:url="state.commentList[index].images" fileMediatype="image"
|
<s-uploader v-model:url="state.commentList[index].images" fileMediatype="image"
|
||||||
limit="9" mode="grid" :imageStyles="{ width: '168rpx', height: '168rpx' }" />
|
limit="9" mode="grid" :imageStyles="{ width: '168rpx', height: '168rpx' }" />
|
||||||
|
@ -41,6 +40,7 @@
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
<!-- TODO 芋艿:是否匿名 -->
|
||||||
|
|
||||||
<su-fixed bottom placeholder>
|
<su-fixed bottom placeholder>
|
||||||
<view class="foot_box ss-flex ss-row-center ss-col-center">
|
<view class="foot_box ss-flex ss-row-center ss-col-center">
|
||||||
|
@ -54,113 +54,49 @@
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import {
|
import { onLoad } from '@dcloudio/uni-app';
|
||||||
onLoad
|
import { reactive } from 'vue';
|
||||||
} from '@dcloudio/uni-app';
|
import OrderApi from '@/sheep/api/trade/order';
|
||||||
import {
|
|
||||||
computed,
|
|
||||||
reactive
|
|
||||||
} from 'vue';
|
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
orderInfo: {},
|
orderInfo: {},
|
||||||
commentList: [],
|
commentList: [],
|
||||||
orderId: null
|
id: null
|
||||||
});
|
});
|
||||||
|
|
||||||
const rateMap = {
|
|
||||||
1: '糟糕',
|
|
||||||
2: '差评',
|
|
||||||
3: '一般',
|
|
||||||
4: '良好',
|
|
||||||
5: '好评',
|
|
||||||
};
|
|
||||||
|
|
||||||
async function onSubmit() {
|
async function onSubmit() {
|
||||||
// 对接商品评价
|
// 顺序提交评论
|
||||||
// console.log(state.orderInfo);
|
for (const comment of state.commentList) {
|
||||||
// return;
|
await OrderApi.createOrderItemComment(comment);
|
||||||
let obj = {
|
|
||||||
anonymous: false,
|
|
||||||
benefitScores: state.commentList[0].level2,
|
|
||||||
content: state.commentList[0].content,
|
|
||||||
descriptionScores: state.commentList[0].level,
|
|
||||||
orderItemId: state.commentList[0].item_id,
|
|
||||||
picUrls: 'https://t7.baidu.com/it/u=2531125946,3055766435&fm=193&f=GIF'
|
|
||||||
}
|
}
|
||||||
const {
|
// 都评论好,返回
|
||||||
code
|
|
||||||
} = await sheep.$api.order.comment(obj);
|
|
||||||
if (code === 0) {
|
|
||||||
sheep.$router.back();
|
sheep.$router.back();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
onLoad(async (options) => {
|
onLoad(async (options) => {
|
||||||
let id = '';
|
if (!options.id) {
|
||||||
if (options.orderSN) {
|
sheep.$helper.toast(`缺少订单信息,请检查`);
|
||||||
id = options.orderSN;
|
return
|
||||||
}
|
|
||||||
if (options.id) {
|
|
||||||
id = options.id;
|
|
||||||
}
|
|
||||||
if (options.orderId) {
|
|
||||||
state.orderId = options.orderId
|
|
||||||
}
|
}
|
||||||
|
state.id = options.id;
|
||||||
|
|
||||||
const res = await sheep.$api.order.detail(id);
|
const { code, data } = await sheep.$api.order.detail(state.id);
|
||||||
if (res.code === 0) {
|
if (code !== 0) {
|
||||||
let obj = {
|
|
||||||
10: ['待发货', '等待买家付款', ["apply_refund"]],
|
|
||||||
30: ['待评价', '等待买家评价', ["express", "comment"]]
|
|
||||||
}
|
|
||||||
|
|
||||||
res.data.status_text = obj[res.data.status][0];
|
|
||||||
res.data.status_desc = obj[res.data.status][1];
|
|
||||||
res.data.btns = obj[res.data.status][2];
|
|
||||||
res.data.address = {
|
|
||||||
province_name: res.data.receiverAreaName.split(' ')[0],
|
|
||||||
district_name: res.data.receiverAreaName.split(' ')[2],
|
|
||||||
city_name: res.data.receiverAreaName.split(' ')[1],
|
|
||||||
address: res.data.receiverDetailAddress,
|
|
||||||
consignee: res.data.receiverName,
|
|
||||||
mobile: res.data.receiverMobile,
|
|
||||||
}
|
|
||||||
res.data.pay_fee = res.data.payPrice / 100
|
|
||||||
res.data.create_time = sheep.$helper.timeFormat(res.data.createTime, 'yyyy-mm-dd hh:MM:ss')
|
|
||||||
res.data.order_sn = res.data.no
|
|
||||||
res.data.id = res.data.id
|
|
||||||
res.data.goods_amount = res.data.totalPrice / 100
|
|
||||||
res.data.dispatch_amount = res.data.deliveryPrice / 100
|
|
||||||
res.data.pay_types_text = res.data.payChannelName.split(',')
|
|
||||||
res.data.items = res.data.items.map(ite => {
|
|
||||||
return {
|
|
||||||
...ite,
|
|
||||||
btns: obj[res.data.status][2],
|
|
||||||
goods_title: ite.spuName,
|
|
||||||
goods_num: ite.count,
|
|
||||||
goods_price: ite.price / 100,
|
|
||||||
goods_image: ite.picUrl,
|
|
||||||
goods_sku_text: ite.properties.reduce((it0, it1) => it0 + it1.valueName + ' ', '')
|
|
||||||
}
|
|
||||||
})
|
|
||||||
if (res.data.btns.includes('comment')) {
|
|
||||||
state.orderInfo = res.data;
|
|
||||||
state.orderInfo.items.forEach((item) => {
|
|
||||||
if (item.btns.includes('comment')) {
|
|
||||||
state.commentList.push({
|
|
||||||
item_id: item.id,
|
|
||||||
level: 5,
|
|
||||||
content: '',
|
|
||||||
images: [],
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
console.log(state.orderInfo.items, '循环')
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
sheep.$helper.toast('无待评价订单');
|
sheep.$helper.toast('无待评价订单');
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// 处理评论
|
||||||
|
data.items.forEach((item) => {
|
||||||
|
state.commentList.push({
|
||||||
|
anonymous: false,
|
||||||
|
orderItemId: item.id,
|
||||||
|
descriptionScores: 5,
|
||||||
|
benefitScores: 5,
|
||||||
|
content: '',
|
||||||
|
picUrls: []
|
||||||
|
});
|
||||||
|
});
|
||||||
|
state.orderInfo = data;
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -1,30 +1,52 @@
|
||||||
|
<!-- 商品详情的底部导航 -->
|
||||||
<template>
|
<template>
|
||||||
<su-fixed bottom placeholder bg="bg-white">
|
<su-fixed bottom placeholder bg="bg-white">
|
||||||
<view class="ui-tabbar-box">
|
<view class="ui-tabbar-box">
|
||||||
<view class="ui-tabbar ss-flex ss-col-center ss-row-between">
|
<view class="ui-tabbar ss-flex ss-col-center ss-row-between">
|
||||||
<view v-if="collectIcon" class="detail-tabbar-item ss-flex ss-flex-col ss-row-center ss-col-center"
|
<view
|
||||||
@tap="onFavorite">
|
v-if="collectIcon"
|
||||||
|
class="detail-tabbar-item ss-flex ss-flex-col ss-row-center ss-col-center"
|
||||||
|
@tap="onFavorite"
|
||||||
|
>
|
||||||
<block v-if="modelValue.favorite">
|
<block v-if="modelValue.favorite">
|
||||||
<image class="item-icon" :src="sheep.$url.static('/static/img/shop/goods/collect_1.gif')"
|
<image
|
||||||
mode="aspectFit"></image>
|
class="item-icon"
|
||||||
|
:src="sheep.$url.static('/static/img/shop/goods/collect_1.gif')"
|
||||||
|
mode="aspectFit"
|
||||||
|
/>
|
||||||
<view class="item-title">已收藏</view>
|
<view class="item-title">已收藏</view>
|
||||||
</block>
|
</block>
|
||||||
<block v-else>
|
<block v-else>
|
||||||
<image class="item-icon" :src="sheep.$url.static('/static/img/shop/goods/collect_0.png')"
|
<image
|
||||||
mode="aspectFit"></image>
|
class="item-icon"
|
||||||
|
:src="sheep.$url.static('/static/img/shop/goods/collect_0.png')"
|
||||||
|
mode="aspectFit"
|
||||||
|
/>
|
||||||
<view class="item-title">收藏</view>
|
<view class="item-title">收藏</view>
|
||||||
</block>
|
</block>
|
||||||
</view>
|
</view>
|
||||||
<view v-if="serviceIcon" class="detail-tabbar-item ss-flex ss-flex-col ss-row-center ss-col-center"
|
<view
|
||||||
@tap="onChat">
|
v-if="serviceIcon"
|
||||||
<image class="item-icon" :src="sheep.$url.static('/static/img/shop/goods/message.png')"
|
class="detail-tabbar-item ss-flex ss-flex-col ss-row-center ss-col-center"
|
||||||
mode="aspectFit"></image>
|
@tap="onChat"
|
||||||
|
>
|
||||||
|
<image
|
||||||
|
class="item-icon"
|
||||||
|
:src="sheep.$url.static('/static/img/shop/goods/message.png')"
|
||||||
|
mode="aspectFit"
|
||||||
|
/>
|
||||||
<view class="item-title">客服</view>
|
<view class="item-title">客服</view>
|
||||||
</view>
|
</view>
|
||||||
<view v-if="shareIcon" class="detail-tabbar-item ss-flex ss-flex-col ss-row-center ss-col-center"
|
<view
|
||||||
@tap="showShareModal">
|
v-if="shareIcon"
|
||||||
<image class="item-icon" :src="sheep.$url.static('/static/img/shop/goods/share.png')"
|
class="detail-tabbar-item ss-flex ss-flex-col ss-row-center ss-col-center"
|
||||||
mode="aspectFit"></image>
|
@tap="showShareModal"
|
||||||
|
>
|
||||||
|
<image
|
||||||
|
class="item-icon"
|
||||||
|
:src="sheep.$url.static('/static/img/shop/goods/share.png')"
|
||||||
|
mode="aspectFit"
|
||||||
|
/>
|
||||||
<view class="item-title">分享</view>
|
<view class="item-title">分享</view>
|
||||||
</view>
|
</view>
|
||||||
<slot></slot>
|
<slot></slot>
|
||||||
|
@ -42,18 +64,11 @@
|
||||||
* @property {String} ui - 自定义样式Class
|
* @property {String} ui - 自定义样式Class
|
||||||
* @property {Boolean} noFixed - 是否定位
|
* @property {Boolean} noFixed - 是否定位
|
||||||
* @property {Boolean} topRadius - 上圆角
|
* @property {Boolean} topRadius - 上圆角
|
||||||
*
|
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
|
import { reactive } from 'vue';
|
||||||
import {
|
|
||||||
computed,
|
|
||||||
reactive
|
|
||||||
} from 'vue';
|
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import {
|
import { showShareModal } from '@/sheep/hooks/useModal';
|
||||||
showShareModal
|
import FavoriteApi from '@/sheep/api/product/favorite';
|
||||||
} from '@/sheep/hooks/useModal';
|
|
||||||
|
|
||||||
// 数据
|
// 数据
|
||||||
const state = reactive({});
|
const state = reactive({});
|
||||||
|
@ -98,34 +113,24 @@
|
||||||
default: true,
|
default: true,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
const elStyles = computed(() => {
|
|
||||||
return {
|
|
||||||
'border-top-left-radius': props.topRadius + 'rpx',
|
|
||||||
'border-top-right-radius': props.topRadius + 'rpx',
|
|
||||||
overflow: 'hidden',
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
const tabbarheight = (e) => {
|
|
||||||
uni.setStorageSync('tabbar', e);
|
|
||||||
};
|
|
||||||
async function onFavorite() {
|
async function onFavorite() {
|
||||||
// const { error } = await sheep.$api.user.favorite.do(props.modelValue.id);
|
// 情况一:取消收藏
|
||||||
// if (error === 0) {
|
|
||||||
// if (props.modelValue.favorite) {
|
|
||||||
// props.modelValue.favorite = 0;
|
|
||||||
// } else {
|
|
||||||
// props.modelValue.favorite = 1;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
let data;
|
|
||||||
if (props.modelValue.favorite) {
|
if (props.modelValue.favorite) {
|
||||||
data = await sheep.$api.user.favorite.dos(props.modelValue.id);
|
const { code } = await FavoriteApi.deleteFavorite(props.modelValue.id);
|
||||||
} else {
|
if (code !== 0) {
|
||||||
data = await sheep.$api.user.favorite.do(props.modelValue.id);
|
return
|
||||||
}
|
}
|
||||||
if (data.data) {
|
sheep.$helper.toast('取消收藏');
|
||||||
props.modelValue.favorite = !props.modelValue.favorite;
|
props.modelValue.favorite = false;
|
||||||
|
// 情况二:添加收藏
|
||||||
|
} else {
|
||||||
|
const { code } = await FavoriteApi.createFavorite(props.modelValue.id);
|
||||||
|
if (code !== 0) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
sheep.$helper.toast('收藏成功');
|
||||||
|
props.modelValue.favorite = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,7 +145,6 @@
|
||||||
.ui-tabbar-box {
|
.ui-tabbar-box {
|
||||||
box-shadow: 0px -6px 10px 0px rgba(51, 51, 51, 0.2);
|
box-shadow: 0px -6px 10px 0px rgba(51, 51, 51, 0.2);
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui-tabbar {
|
.ui-tabbar {
|
||||||
display: flex;
|
display: flex;
|
||||||
height: 50px;
|
height: 50px;
|
||||||
|
|
|
@ -12,7 +12,9 @@
|
||||||
<block v-else>
|
<block v-else>
|
||||||
<view class="detail-swiper-selector">
|
<view class="detail-swiper-selector">
|
||||||
<!-- 商品轮播图 -->
|
<!-- 商品轮播图 -->
|
||||||
<su-swiper class="ss-m-b-14" isPreview :list="formatGoodsSwiper(state.goodsInfo.sliderPicUrls)" dotStyle="tag" imageMode="widthFix" dotCur="bg-mask-40" :seizeHeight="750" />
|
<su-swiper class="ss-m-b-14" isPreview :list="formatGoodsSwiper(state.goodsInfo.sliderPicUrls)"
|
||||||
|
dotStyle="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">
|
||||||
|
@ -30,15 +32,15 @@
|
||||||
</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">
|
||||||
<!-- 满减送/限时折扣活动的提示 TODO 芋艿:promos 未写 -->
|
<!-- 满减送/限时折扣活动的提示 TODO 芋艿:promos 未写 -->
|
||||||
<div class="tag-content">
|
|
||||||
<!-- 满减送/限时折扣活动的提示 TODO 芋艿:promos 未写 -->
|
|
||||||
<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.goodsInfo.promos" :key="promos.id" @tap="onActivity">
|
<view class="tag ss-m-r-10" v-for="promos in state.goodsInfo.promos"
|
||||||
|
:key="promos.id" @tap="onActivity">
|
||||||
{{ promos.title }}
|
{{ promos.title }}
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- 优惠劵 -->
|
<!-- 优惠劵 -->
|
||||||
<view class="get-coupon-box ss-flex ss-col-center ss-m-l-20" @tap="state.showModel = true"
|
<view class="get-coupon-box ss-flex ss-col-center ss-m-l-20" @tap="state.showModel = true"
|
||||||
v-if="state.couponInfo.length">
|
v-if="state.couponInfo.length">
|
||||||
|
@ -86,12 +88,11 @@
|
||||||
<button class="ss-reset-button disabled-btn" disabled> 已售罄 </button>
|
<button class="ss-reset-button disabled-btn" disabled> 已售罄 </button>
|
||||||
</view>
|
</view>
|
||||||
</detail-tabbar>
|
</detail-tabbar>
|
||||||
<!-- 优惠劵弹窗 -->
|
|
||||||
<s-coupon-get v-model="state.couponInfo" :show="state.showModel" @close="state.showModel = false" @get="onGet" />
|
|
||||||
|
|
||||||
<!-- 满减送/限时折扣活动弹窗 -->
|
|
||||||
<!-- 优惠劵弹窗 -->
|
<!-- 优惠劵弹窗 -->
|
||||||
<s-coupon-get v-model="state.couponInfo" :show="state.showModel" @close="state.showModel = false" @get="onGet" />
|
<s-coupon-get 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 v-model="state.activityInfo" :show="state.showActivityModel"
|
||||||
@close="state.showActivityModel = false" />
|
@close="state.showActivityModel = false" />
|
||||||
|
@ -101,19 +102,23 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { reactive, computed } from 'vue';
|
import {
|
||||||
import { onLoad, onPageScroll } from '@dcloudio/uni-app';
|
reactive,
|
||||||
|
computed
|
||||||
|
} from 'vue';
|
||||||
|
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 {
|
import {
|
||||||
formatSales,
|
formatSales,
|
||||||
formatGoodsSwiper,
|
formatGoodsSwiper,
|
||||||
fen2yuan,
|
fen2yuan,
|
||||||
} from '@/sheep/hooks/useGoods';
|
} from '@/sheep/hooks/useGoods';
|
||||||
import CouponApi from '@/sheep/api/promotion/coupon';
|
|
||||||
import ActivityApi from '@/sheep/api/promotion/activity';
|
|
||||||
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 detailCellService from './components/detail/detail-cell-service.vue';
|
import detailCellService from './components/detail/detail-cell-service.vue';
|
||||||
|
@ -147,20 +152,28 @@
|
||||||
|
|
||||||
// 添加购物车 TODO 芋艿:待测试
|
// 添加购物车 TODO 芋艿:待测试
|
||||||
function onAddCart(e) {
|
function onAddCart(e) {
|
||||||
console.log(e, '加入购物车');
|
if (!e.id) {
|
||||||
|
sheep.$helper.toast('请选择商品规格');
|
||||||
|
return;
|
||||||
|
}
|
||||||
sheep.$store('cart').add(e);
|
sheep.$store('cart').add(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 立即购买 TODO 芋艿:待测试
|
// 立即购买
|
||||||
function onBuy(e) {
|
function onBuy(e) {
|
||||||
|
if (!state.selectedSku.id) {
|
||||||
|
sheep.$helper.toast('请选择商品规格');
|
||||||
|
return;
|
||||||
|
}
|
||||||
sheep.$router.go('/pages/order/confirm', {
|
sheep.$router.go('/pages/order/confirm', {
|
||||||
data: JSON.stringify({
|
data: JSON.stringify({
|
||||||
order_type: 'goods',
|
items: [{
|
||||||
goods_list: [{
|
skuId: state.selectedSku.id,
|
||||||
goods_id: e.goods_id,
|
count: 1
|
||||||
goods_num: e.goods_num,
|
}],
|
||||||
goods_sku_price_id: e.id,
|
// TODO 芋艿:后续清理掉这 2 参数
|
||||||
}, ],
|
deliveryType: 1,
|
||||||
|
pointStatus: false,
|
||||||
}),
|
}),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -174,10 +187,10 @@
|
||||||
// 立即领取 TODO 芋艿:待测试
|
// 立即领取 TODO 芋艿:待测试
|
||||||
async function onGet(id) {
|
async function onGet(id) {
|
||||||
const {
|
const {
|
||||||
code,
|
error,
|
||||||
msg
|
msg
|
||||||
} = await sheep.$api.coupon.get(id);
|
} = await sheep.$api.coupon.get(id);
|
||||||
if (code === 0) {
|
if (error === 0) {
|
||||||
uni.showToast({
|
uni.showToast({
|
||||||
title: msg,
|
title: msg,
|
||||||
});
|
});
|
||||||
|
@ -188,7 +201,6 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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({
|
||||||
|
@ -202,8 +214,9 @@
|
||||||
}, {
|
}, {
|
||||||
type: 'goods', // 商品海报
|
type: 'goods', // 商品海报
|
||||||
title: state.goodsInfo.name, // 商品标题
|
title: state.goodsInfo.name, // 商品标题
|
||||||
image: sheep.$url.cdn(state.goodsInfo.image), // 商品主图
|
// image: sheep.$url.cdn(state.goodsInfo.image), // 商品主图
|
||||||
price: state.goodsInfo.price[0], // 商品价格
|
image: sheep.$url.cdn(state.goodsInfo.picUrl), // 商品主图
|
||||||
|
price: state.goodsInfo.price, // 商品价格
|
||||||
original_price: state.goodsInfo.original_price, // 商品原价
|
original_price: state.goodsInfo.original_price, // 商品原价
|
||||||
}, );
|
}, );
|
||||||
});
|
});
|
||||||
|
@ -216,75 +229,6 @@
|
||||||
}
|
}
|
||||||
state.goodsId = options.id;
|
state.goodsId = options.id;
|
||||||
// 1. 加载商品信息
|
// 1. 加载商品信息
|
||||||
sheep.$api.goods.detail(state.goodsId).then(async (res) => {
|
|
||||||
// 未找到商品
|
|
||||||
if (res.code !== 0 || !res.data) {
|
|
||||||
state.goodsInfo = null;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// 加载到商品
|
|
||||||
state.skeletonLoading = false;
|
|
||||||
// 获取收藏信息
|
|
||||||
let dasa = await sheep.$api.goods.exits(options.id);
|
|
||||||
res.data.favorite = dasa.data;
|
|
||||||
state.goodsInfo = res.data;
|
|
||||||
console.log(state.goodsInfo, '商品信息');
|
|
||||||
|
|
||||||
// 此处调试默认弹出可以修改为点击弹出
|
|
||||||
// 2. 加载优惠劵信息
|
|
||||||
CouponApi.getCouponTemplateList({
|
|
||||||
price: state.goodsInfo.price,
|
|
||||||
spuIds: [state.goodsInfo.id],
|
|
||||||
skuIds: state.goodsInfo.skus.map(item => item.id),
|
|
||||||
// 先写死
|
|
||||||
categoryIds: [52]
|
|
||||||
}).then((res) => {
|
|
||||||
console.log(res, '优惠券信息进行对接')
|
|
||||||
if (res.code !== 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// 拦截修改数据
|
|
||||||
let obj2 = {
|
|
||||||
2: '折扣',
|
|
||||||
1: '满减'
|
|
||||||
}
|
|
||||||
let obj = {
|
|
||||||
1: '可用',
|
|
||||||
2: '已用',
|
|
||||||
3: '过期'
|
|
||||||
}
|
|
||||||
let obj3 = {
|
|
||||||
1: '已领取',
|
|
||||||
2: '已使用',
|
|
||||||
3: '已过期'
|
|
||||||
}
|
|
||||||
res.data = res.data.map(item => {
|
|
||||||
return {
|
|
||||||
...item,
|
|
||||||
enough: (item.usePrice / 100).toFixed(2),
|
|
||||||
amount: (item.discountPrice / 100).toFixed(2),
|
|
||||||
use_start_time: sheep.$helper.timeFormat(item
|
|
||||||
.validStartTime,
|
|
||||||
'yyyy-mm-dd hh:MM:ss'),
|
|
||||||
use_end_time: sheep.$helper.timeFormat(item.validEndTime,
|
|
||||||
'yyyy-mm-dd hh:MM:ss'),
|
|
||||||
status_text: obj[item.status],
|
|
||||||
type_text: obj2[item.discountType],
|
|
||||||
get_status_text: obj3[item.status],
|
|
||||||
type_text: obj2[item.discountType]
|
|
||||||
}
|
|
||||||
});
|
|
||||||
state.couponInfo = res.data;
|
|
||||||
});
|
|
||||||
});
|
|
||||||
// return;
|
|
||||||
// 3. 加载营销活动信息
|
|
||||||
ActivityApi.getActivityListBySpuId(state.goodsId).then((res) => {
|
|
||||||
if (res.code !== 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
state.activityList = res.data;
|
|
||||||
});
|
|
||||||
sheep.$api.goods.detail(state.goodsId).then((res) => {
|
sheep.$api.goods.detail(state.goodsId).then((res) => {
|
||||||
// 未找到商品
|
// 未找到商品
|
||||||
if (res.code !== 0 || !res.data) {
|
if (res.code !== 0 || !res.data) {
|
||||||
|
@ -294,6 +238,14 @@
|
||||||
// 加载到商品
|
// 加载到商品
|
||||||
state.skeletonLoading = false;
|
state.skeletonLoading = false;
|
||||||
state.goodsInfo = res.data;
|
state.goodsInfo = res.data;
|
||||||
|
|
||||||
|
// 加载是否收藏
|
||||||
|
FavoriteApi.isFavoriteExists(state.goodsId, 'goods').then((res) => {
|
||||||
|
if (res.code !== 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
state.goodsInfo.favorite = res.data;
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
// 2. 加载优惠劵信息
|
// 2. 加载优惠劵信息
|
||||||
|
|
|
@ -1,22 +1,12 @@
|
||||||
<template>
|
<template>
|
||||||
<s-layout
|
<s-layout navbar="normal" :leftWidth="0" :rightWidth="0" tools="search" :defaultSearch="state.keyword"
|
||||||
navbar="normal"
|
@search="onSearch">
|
||||||
:leftWidth="0"
|
|
||||||
:rightWidth="0"
|
|
||||||
tools="search"
|
|
||||||
:defaultSearch="state.keyword"
|
|
||||||
@search="onSearch"
|
|
||||||
>
|
|
||||||
<!-- 筛选 -->
|
<!-- 筛选 -->
|
||||||
<su-sticky bgColor="#fff">
|
<su-sticky bgColor="#fff">
|
||||||
<view class="ss-flex">
|
<view class="ss-flex">
|
||||||
<view class="ss-flex-1">
|
<view class="ss-flex-1">
|
||||||
<su-tabs
|
<su-tabs :list="state.tabList" :scrollable="false" @change="onTabsChange"
|
||||||
:list="state.tabList"
|
:current="state.currentTab"></su-tabs>
|
||||||
:scrollable="false"
|
|
||||||
@change="onTabsChange"
|
|
||||||
:current="state.currentTab"
|
|
||||||
></su-tabs>
|
|
||||||
</view>
|
</view>
|
||||||
<view class="list-icon" @tap="state.iconStatus = !state.iconStatus">
|
<view class="list-icon" @tap="state.iconStatus = !state.iconStatus">
|
||||||
<text v-if="state.iconStatus" class="sicon-goods-list"></text>
|
<text v-if="state.iconStatus" class="sicon-goods-list"></text>
|
||||||
|
@ -26,58 +16,29 @@
|
||||||
</su-sticky>
|
</su-sticky>
|
||||||
|
|
||||||
<!-- 弹窗 -->
|
<!-- 弹窗 -->
|
||||||
<su-popup
|
<su-popup :show="state.showFilter" type="top" round="10" :space="sys_navBar + 38" backgroundColor="#F6F6F6"
|
||||||
:show="state.showFilter"
|
:zIndex="10" @close="state.showFilter = false">
|
||||||
type="top"
|
|
||||||
round="10"
|
|
||||||
:space="sys_navBar + 38"
|
|
||||||
backgroundColor="#F6F6F6"
|
|
||||||
:zIndex="10"
|
|
||||||
@close="state.showFilter = false"
|
|
||||||
>
|
|
||||||
<view class="filter-list-box">
|
<view class="filter-list-box">
|
||||||
<view
|
<view class="filter-item" v-for="(item, index) in state.tabList[state.currentTab].list"
|
||||||
class="filter-item"
|
:key="item.value" :class="[{ 'filter-item-active': index == state.curFilter }]"
|
||||||
v-for="(item, index) in state.tabList[state.currentTab].list"
|
@tap="onFilterItem(index)">
|
||||||
:key="item.value"
|
|
||||||
:class="[{ 'filter-item-active': index == state.curFilter }]"
|
|
||||||
@tap="onFilterItem(index)"
|
|
||||||
>
|
|
||||||
{{ item.label }}
|
{{ item.label }}
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</su-popup>
|
</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
|
<view class="ss-p-l-20 ss-p-r-20 ss-m-b-20" v-for="item in state.pagination.data" :key="item.id">
|
||||||
class="ss-p-l-20 ss-p-r-20 ss-m-b-20"
|
<s-goods-column class="" size="lg" :data="item" :topRadius="10" :bottomRadius="10"
|
||||||
v-for="item in state.pagination.data"
|
@click="sheep.$router.go('/pages/goods/index', { id: item.id })"></s-goods-column>
|
||||||
:key="item.id"
|
|
||||||
>
|
|
||||||
<s-goods-column
|
|
||||||
class=""
|
|
||||||
size="lg"
|
|
||||||
:data="item"
|
|
||||||
:topRadius="10"
|
|
||||||
:bottomRadius="10"
|
|
||||||
@click="sheep.$router.go('/pages/goods/index', { id: item.id })"
|
|
||||||
></s-goods-column>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view
|
<view v-if="!state.iconStatus && state.pagination.total > 0"
|
||||||
v-if="!state.iconStatus && state.pagination.total > 0"
|
class="ss-flex ss-flex-wrap ss-p-x-20 ss-m-t-20 ss-col-top">
|
||||||
class="ss-flex ss-flex-wrap ss-p-x-20 ss-m-t-20 ss-col-top"
|
|
||||||
>
|
|
||||||
<view class="goods-list-box">
|
<view class="goods-list-box">
|
||||||
<view class="left-list" v-for="item in state.leftGoodsList" :key="item.id">
|
<view class="left-list" v-for="item in state.leftGoodsList" :key="item.id">
|
||||||
<s-goods-column
|
<s-goods-column class="goods-md-box" size="md" :data="item" :topRadius="10" :bottomRadius="10"
|
||||||
class="goods-md-box"
|
|
||||||
size="md"
|
|
||||||
:data="item"
|
|
||||||
:topRadius="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>
|
<button class="ss-reset-button cart-btn"> </button>
|
||||||
</template>
|
</template>
|
||||||
|
@ -86,15 +47,9 @@
|
||||||
</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" size="md" :topRadius="10" :bottomRadius="10" :data="item"
|
||||||
class="goods-md-box"
|
|
||||||
size="md"
|
|
||||||
:topRadius="10"
|
|
||||||
:bottomRadius="10"
|
|
||||||
: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>
|
<button class="ss-reset-button cart-btn"> </button>
|
||||||
</template>
|
</template>
|
||||||
|
@ -102,22 +57,22 @@
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<uni-load-more
|
<uni-load-more v-if="state.pagination.total > 0" :status="state.loadStatus" :content-text="{
|
||||||
v-if="state.pagination.total > 0"
|
|
||||||
:status="state.loadStatus"
|
|
||||||
:content-text="{
|
|
||||||
contentdown: '上拉加载更多',
|
contentdown: '上拉加载更多',
|
||||||
}"
|
}" @tap="loadmore" />
|
||||||
@tap="loadmore"
|
|
||||||
/>
|
|
||||||
<s-empty v-if="state.pagination.total === 0" icon="/static/soldout-empty.png" text="暂无商品">
|
<s-empty v-if="state.pagination.total === 0" icon="/static/soldout-empty.png" text="暂无商品">
|
||||||
</s-empty>
|
</s-empty>
|
||||||
</s-layout>
|
</s-layout>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { reactive } from 'vue';
|
import {
|
||||||
import { onLoad, onReachBottom } from '@dcloudio/uni-app';
|
reactive
|
||||||
|
} from 'vue';
|
||||||
|
import {
|
||||||
|
onLoad,
|
||||||
|
onReachBottom
|
||||||
|
} from '@dcloudio/uni-app';
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
|
||||||
|
@ -145,12 +100,10 @@
|
||||||
showFilter: false,
|
showFilter: false,
|
||||||
iconStatus: false,
|
iconStatus: false,
|
||||||
categoryId: 0,
|
categoryId: 0,
|
||||||
tabList: [
|
tabList: [{
|
||||||
{
|
|
||||||
name: '综合推荐',
|
name: '综合推荐',
|
||||||
// value: '',
|
// value: '',
|
||||||
list: [
|
list: [{
|
||||||
{
|
|
||||||
label: '综合推荐',
|
label: '综合推荐',
|
||||||
// sort: '',
|
// sort: '',
|
||||||
// order: true,
|
// order: true,
|
||||||
|
@ -169,6 +122,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: '销量',
|
name: '销量',
|
||||||
|
sort: 'salesCount',
|
||||||
|
order: false,
|
||||||
// value: 'salesCount',
|
// value: 'salesCount',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -233,8 +188,8 @@
|
||||||
state.currentTab = e.index;
|
state.currentTab = e.index;
|
||||||
}
|
}
|
||||||
emptyList();
|
emptyList();
|
||||||
|
console.log(e, '6666')
|
||||||
getList(e.value, state.currentOrder, state.categoryId, state.keyword);
|
getList(e.sort, e.order, state.categoryId, state.keyword);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 点击筛选项
|
// 点击筛选项
|
||||||
|
@ -307,54 +262,68 @@
|
||||||
.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;
|
||||||
|
|
|
@ -1,11 +1,6 @@
|
||||||
<!-- 购物车界面 -->
|
|
||||||
<template>
|
<template>
|
||||||
<s-layout title="购物车" tabbar="/pages/index/cart" :bgStyle="{ color: '#fff' }">
|
<s-layout title="购物车" tabbar="/pages/index/cart" :bgStyle="{ color: '#fff' }">
|
||||||
<s-empty
|
<s-empty v-if="state.list.length === 0" text="购物车空空如也,快去逛逛吧~" icon="/static/cart-empty.png" />
|
||||||
v-if="state.list.length === 0"
|
|
||||||
text="购物车空空如也,快去逛逛吧~"
|
|
||||||
icon="/static/cart-empty.png"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<!-- 头部 -->
|
<!-- 头部 -->
|
||||||
<view class="cart-box ss-flex ss-flex-col ss-row-between" v-if="state.list.length">
|
<view class="cart-box ss-flex ss-flex-col ss-row-between" v-if="state.list.length">
|
||||||
|
@ -24,72 +19,47 @@
|
||||||
</button>
|
</button>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- 内容 -->
|
<!-- 内容 -->
|
||||||
<view class="cart-content ss-flex-1 ss-p-x-30 ss-m-b-40">
|
<view class="cart-content ss-flex-1 ss-p-x-30 ss-m-b-40">
|
||||||
<view class="goods-box ss-r-10 ss-m-b-14" v-for="item in state.list" :key="item.id">
|
<view class="goods-box ss-r-10 ss-m-b-14" v-for="item in state.list" :key="item.id">
|
||||||
<view class="ss-flex ss-col-center">
|
<view class="ss-flex ss-col-center">
|
||||||
<label class="check-box ss-flex ss-col-center ss-p-l-10" @tap="onSelectSingle(item.id)">
|
<label class="check-box ss-flex ss-col-center ss-p-l-10" @tap="onSelectSingle(item.id)">
|
||||||
<radio
|
<radio :checked="state.selectedIds.includes(item.id)" color="var(--ui-BG-Main)"
|
||||||
:checked="state.selectedIds.includes(item.id)"
|
style="transform: scale(0.8)" @tap.stop="onSelectSingle(item.id)" />
|
||||||
color="var(--ui-BG-Main)"
|
|
||||||
style="transform: scale(0.8)"
|
|
||||||
@tap.stop="onSelectSingle(item.id)"
|
|
||||||
/>
|
|
||||||
</label>
|
</label>
|
||||||
<s-goods-item
|
<s-goods-item :title="item.spu.name" :img="item.spu.picUrl || item.goods.image"
|
||||||
:title="item.spu.name"
|
:price="item.sku.price/100"
|
||||||
:img="item.sku.picUrl || item.spu.picUrl"
|
:skuText="item.sku.properties.length>1? item.sku.properties.reduce((items2,items)=>items2.valueName+' '+items.valueName):item.sku.properties[0].valueName"
|
||||||
:price="fen2yuan(item.sku.price)"
|
priceColor="#FF3000" :titleWidth="400">
|
||||||
:skuText="item.sku.properties.map((property) => property.valueName).join(' ')"
|
|
||||||
priceColor="#FF3000"
|
|
||||||
:titleWidth="400"
|
|
||||||
>
|
|
||||||
<template v-if="!state.editMode" v-slot:tool>
|
<template v-if="!state.editMode" v-slot:tool>
|
||||||
<su-number-box
|
<su-number-box :min="0" :max="item.sku.stock" :step="1" v-model="item.count"
|
||||||
:min="0"
|
@change="onNumberChange($event, item)"></su-number-box>
|
||||||
:max="item.sku.stock"
|
|
||||||
:step="1"
|
|
||||||
v-model="item.count"
|
|
||||||
@change="onNumberChange($event, item)"
|
|
||||||
/>
|
|
||||||
</template>
|
</template>
|
||||||
</s-goods-item>
|
</s-goods-item>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- 底部 -->
|
<!-- 底部 -->
|
||||||
<su-fixed bottom :val="48" placeholder v-if="state.list.length > 0" :isInset="false">
|
<su-fixed bottom :val="48" placeholder v-if="state.list.length > 0" :isInset="false">
|
||||||
<view class="cart-footer ss-flex ss-col-center ss-row-between ss-p-x-30 border-bottom">
|
<view class="cart-footer ss-flex ss-col-center ss-row-between ss-p-x-30 border-bottom">
|
||||||
<view class="footer-left ss-flex ss-col-center">
|
<view class="footer-left ss-flex ss-col-center">
|
||||||
<label class="check-box ss-flex ss-col-center ss-p-r-30" @tap="onSelectAll">
|
<label class="check-box ss-flex ss-col-center ss-p-r-30" @tap="onSelectAll">
|
||||||
<radio
|
<radio :checked="state.isAllSelected" color="var(--ui-BG-Main)"
|
||||||
:checked="state.isAllSelected"
|
style="transform: scale(0.8)" @tap.stop="onSelectAll" />
|
||||||
color="var(--ui-BG-Main)"
|
|
||||||
style="transform: scale(0.8)"
|
|
||||||
@tap.stop="onSelectAll"
|
|
||||||
/>
|
|
||||||
<view class="ss-m-l-8"> 全选 </view>
|
<view class="ss-m-l-8"> 全选 </view>
|
||||||
</label>
|
</label>
|
||||||
<text>合计:</text>
|
<text>合计:</text>
|
||||||
<view class="text-price price-text">
|
<view class="text-price price-text">
|
||||||
{{ fen2yuan(state.totalPriceSelected) }}
|
{{ state.totalPriceSelected }}
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view class="footer-right">
|
<view class="footer-right">
|
||||||
<button
|
<button v-if="state.editMode" class="ss-reset-button ui-BG-Main-Gradient pay-btn ui-Shadow-Main"
|
||||||
v-if="state.editMode"
|
@tap="onDelete">
|
||||||
class="ss-reset-button ui-BG-Main-Gradient pay-btn ui-Shadow-Main"
|
|
||||||
@tap="onDelete"
|
|
||||||
>
|
|
||||||
删除
|
删除
|
||||||
</button>
|
</button>
|
||||||
<button
|
<button v-else class="ss-reset-button ui-BG-Main-Gradient pay-btn ui-Shadow-Main"
|
||||||
v-else
|
@tap="onConfirm">
|
||||||
class="ss-reset-button ui-BG-Main-Gradient pay-btn ui-Shadow-Main"
|
|
||||||
@tap="onConfirm"
|
|
||||||
>
|
|
||||||
去结算
|
去结算
|
||||||
{{ state.selectedIds?.length ? `(${state.selectedIds.length})` : '' }}
|
{{ state.selectedIds?.length ? `(${state.selectedIds.length})` : '' }}
|
||||||
</button>
|
</button>
|
||||||
|
@ -102,26 +72,28 @@
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { computed, reactive } from 'vue';
|
import {
|
||||||
import { fen2yuan } from '@/sheep/hooks/useGoods';
|
computed,
|
||||||
import { property } from 'lodash/util';
|
reactive,
|
||||||
|
unref
|
||||||
|
} from 'vue';
|
||||||
|
|
||||||
const sys_navBar = sheep.$platform.navbar;
|
const sys_navBar = sheep.$platform.navbar;
|
||||||
const cart = sheep.$store('cart');
|
const cart = sheep.$store('cart');
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
editMode: false,
|
editMode: false,
|
||||||
list: computed(() => cart.list), // 购物车项的列表
|
list: computed(() => cart.list),
|
||||||
|
selectedList: [],
|
||||||
selectedIds: computed(() => cart.selectedIds),
|
selectedIds: computed(() => cart.selectedIds),
|
||||||
isAllSelected: computed(() => cart.isAllSelected),
|
isAllSelected: computed(() => cart.isAllSelected),
|
||||||
totalPriceSelected: computed(() => cart.totalPriceSelected),
|
totalPriceSelected: computed(() => cart.totalPriceSelected),
|
||||||
});
|
});
|
||||||
|
// 单选选中
|
||||||
// 单选
|
|
||||||
function onSelectSingle(id) {
|
function onSelectSingle(id) {
|
||||||
|
console.log('单选')
|
||||||
cart.selectSingle(id);
|
cart.selectSingle(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 全选
|
// 全选
|
||||||
function onSelectAll() {
|
function onSelectAll() {
|
||||||
cart.selectAll(!state.isAllSelected);
|
cart.selectAll(!state.isAllSelected);
|
||||||
|
@ -129,24 +101,36 @@
|
||||||
|
|
||||||
// 结算
|
// 结算
|
||||||
function onConfirm() {
|
function onConfirm() {
|
||||||
const items = state.list
|
let items = []
|
||||||
.filter((item) => state.selectedIds.includes(item.id))
|
let goods_list = [];
|
||||||
.map((item) => {
|
state.selectedList = state.list.filter((item) => state.selectedIds.includes(item.id));
|
||||||
return {
|
state.selectedList.map((item) => {
|
||||||
|
console.log(item, '便利');
|
||||||
|
// 此处前端做出修改
|
||||||
|
items.push({
|
||||||
skuId: item.sku.id,
|
skuId: item.sku.id,
|
||||||
count: item.count,
|
count: item.count,
|
||||||
cartId: item.id,
|
cartId: item.id,
|
||||||
};
|
})
|
||||||
|
goods_list.push({
|
||||||
|
// goods_id: item.goods_id,
|
||||||
|
goods_id: item.spu.id,
|
||||||
|
// goods_num: item.goods_num,
|
||||||
|
goods_num: item.count,
|
||||||
|
// 商品价格id真没有
|
||||||
|
// goods_sku_price_id: item.goods_sku_price_id,
|
||||||
});
|
});
|
||||||
if (items.length === 0) {
|
});
|
||||||
|
// return;
|
||||||
|
if (goods_list.length === 0) {
|
||||||
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,
|
|
||||||
// order_type: 'goods',
|
// order_type: 'goods',
|
||||||
// goods_list,
|
// goods_list,
|
||||||
|
items,
|
||||||
// from: 'cart',
|
// from: 'cart',
|
||||||
deliveryType: 1,
|
deliveryType: 1,
|
||||||
pointStatus: false,
|
pointStatus: false,
|
||||||
|
@ -154,23 +138,19 @@
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// 更新数量
|
function onNumberChange(e, cartItem) {
|
||||||
function onNumberChange(number, cartItem) {
|
if (e === 0) {
|
||||||
if (number === 0) {
|
cart.delete(cartItem.id);
|
||||||
cart.delete([cartItem.id]);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (cartItem.goods_num === number) {
|
if (cartItem.goods_num === e) return;
|
||||||
return;
|
cartItem.goods_num = e;
|
||||||
}
|
|
||||||
cartItem.goods_num = number;
|
|
||||||
cart.update({
|
cart.update({
|
||||||
goods_id: cartItem.id,
|
goods_id: cartItem.id,
|
||||||
goods_num: number,
|
goods_num: e,
|
||||||
|
goods_sku_price_id: cartItem.goods_sku_price_id,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// 删除
|
|
||||||
async function onDelete() {
|
async function onDelete() {
|
||||||
cart.delete(state.selectedIds);
|
cart.delete(state.selectedIds);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,12 @@
|
||||||
<template>
|
<template>
|
||||||
|
<s-layout
|
||||||
<s-layout title="我的" tabbar="/pages/index/user" navbar="custom" :bgStyle="template.page"
|
title="我的"
|
||||||
:navbarStyle="template.style?.navbar" onShareAppMessage>
|
tabbar="/pages/index/user"
|
||||||
|
navbar="custom"
|
||||||
|
:bgStyle="template.page"
|
||||||
|
:navbarStyle="template.style?.navbar"
|
||||||
|
onShareAppMessage
|
||||||
|
>
|
||||||
<s-block v-for="(item, index) in template.components" :key="index" :styles="item.property.style">
|
<s-block v-for="(item, index) in template.components" :key="index" :styles="item.property.style">
|
||||||
<s-block-item :type="item.id" :data="item.property" :styles="item.property.style" />
|
<s-block-item :type="item.id" :data="item.property" :styles="item.property.style" />
|
||||||
</s-block>
|
</s-block>
|
||||||
|
@ -9,14 +14,8 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import {
|
import { computed } from 'vue';
|
||||||
computed
|
import { onShow, onPageScroll, onPullDownRefresh } from '@dcloudio/uni-app';
|
||||||
} from 'vue';
|
|
||||||
import {
|
|
||||||
onShow,
|
|
||||||
onPageScroll,
|
|
||||||
onPullDownRefresh
|
|
||||||
} from '@dcloudio/uni-app';
|
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
|
|
||||||
// 隐藏原生tabBar
|
// 隐藏原生tabBar
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<!-- 订单详情 -->
|
<!-- 售后申请 -->
|
||||||
<template>
|
<template>
|
||||||
<s-layout title="申请售后">
|
<s-layout title="申请售后">
|
||||||
<!-- 售后商品 -->
|
<!-- 售后商品 -->
|
||||||
|
|
|
@ -0,0 +1,215 @@
|
||||||
|
<template>
|
||||||
|
<s-layout>
|
||||||
|
<!-- title='退货物流' -->
|
||||||
|
<!-- 不知为何加上页面就错误 -->
|
||||||
|
<view>
|
||||||
|
<form @submit="subRefund" report-submit='true'>
|
||||||
|
<view class='apply-return'>
|
||||||
|
<view class='list borRadius14'>
|
||||||
|
<view class='item acea-row row-between-wrapper' style="display: flex;align-items: center;">
|
||||||
|
<view>物流公司</view>
|
||||||
|
<picker mode='selector' class='num' @change="bindPickerChange" :value="state.expressIndex"
|
||||||
|
:range="state.expresses" range-key="name">
|
||||||
|
<view class="picker acea-row row-between-wrapper">
|
||||||
|
<view class='reason'>{{ state.expresses[state.expressIndex].name }}</view>
|
||||||
|
<text class='iconfont icon-jiantou'></text>
|
||||||
|
</view>
|
||||||
|
</picker>
|
||||||
|
</view>
|
||||||
|
<view class='item textarea acea-row row-between' style="display: flex;align-items: center;">
|
||||||
|
<view>物流单号</view>
|
||||||
|
<input placeholder='请填写物流单号' class='num' name="logisticsNo"
|
||||||
|
placeholder-class='placeholder' />
|
||||||
|
</view>
|
||||||
|
<button class='returnBnt bg-color ss-reset-button ui-BG-Main-Gradient sub-btn'
|
||||||
|
form-type="submit"
|
||||||
|
style="background: linear-gradient(90deg,var(--ui-BG-Main),var(--ui-BG-Main-gradient))!important">提交</button>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</form>
|
||||||
|
</view>
|
||||||
|
</s-layout>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import sheep from '@/sheep';
|
||||||
|
import {
|
||||||
|
onLoad,
|
||||||
|
onReachBottom,
|
||||||
|
onPullDownRefresh
|
||||||
|
} from '@dcloudio/uni-app';
|
||||||
|
import {
|
||||||
|
computed,
|
||||||
|
watch,
|
||||||
|
ref,
|
||||||
|
reactive,
|
||||||
|
unref
|
||||||
|
} from 'vue';
|
||||||
|
const state = reactive({
|
||||||
|
expressIndex: 0,
|
||||||
|
expresses: [{
|
||||||
|
"id": 1,
|
||||||
|
"name": "申通快递"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 2,
|
||||||
|
"name": "顺丰速运"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 3,
|
||||||
|
"name": "中通快递"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 4,
|
||||||
|
"name": "韵达快递"
|
||||||
|
}
|
||||||
|
], //模拟物流公司数组
|
||||||
|
})
|
||||||
|
|
||||||
|
function bindPickerChange(e) {
|
||||||
|
state.expressIndex = e.detail.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
function subRefund(e) {
|
||||||
|
const formData = e.detail.value;
|
||||||
|
console.log(formData, '表单数据');
|
||||||
|
console.log(state.expresses[state.expressIndex].id, '物流公司id');
|
||||||
|
return;
|
||||||
|
// 下面是参考逻辑
|
||||||
|
AfterSaleApi.deliveryAfterSale({
|
||||||
|
id: this.id,
|
||||||
|
logisticsId: this.expresses[this.expressIndex].id,
|
||||||
|
logisticsNo: formData.logisticsNo,
|
||||||
|
}).then(res => {
|
||||||
|
this.$util.Tips({
|
||||||
|
title: '填写退货成功',
|
||||||
|
icon: 'success'
|
||||||
|
}, {
|
||||||
|
tab: 5,
|
||||||
|
url: '/pages/users/user_return_detail/index?id=' + this.id
|
||||||
|
});
|
||||||
|
}).catch(err => {
|
||||||
|
return this.$util.Tips({
|
||||||
|
title: err
|
||||||
|
});
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function getList() {
|
||||||
|
|
||||||
|
}
|
||||||
|
onLoad(() => {
|
||||||
|
// 拿退货编号
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.apply-return {
|
||||||
|
padding: 20rpx 30rpx 70rpx 30rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list {
|
||||||
|
background-color: #fff;
|
||||||
|
margin-top: 18rpx;
|
||||||
|
padding: 0 24rpx 70rpx 24rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item {
|
||||||
|
min-height: 90rpx;
|
||||||
|
border-bottom: 1rpx solid #eee;
|
||||||
|
font-size: 30rpx;
|
||||||
|
color: #333;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .num {
|
||||||
|
color: #282828;
|
||||||
|
margin-left: 27rpx;
|
||||||
|
// width: 227rpx;
|
||||||
|
// text-align: right;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .num .picker .reason {
|
||||||
|
width: 385rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .num .picker .iconfont {
|
||||||
|
color: #666;
|
||||||
|
font-size: 30rpx;
|
||||||
|
margin-top: 2rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item.textarea {
|
||||||
|
padding: 24rpx 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item textarea {
|
||||||
|
height: 100rpx;
|
||||||
|
font-size: 30rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .placeholder {
|
||||||
|
color: #bbb;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .title {
|
||||||
|
height: 95rpx;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .title .tip {
|
||||||
|
font-size: 30rpx;
|
||||||
|
color: #bbb;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .upload {
|
||||||
|
padding-bottom: 36rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .upload .pictrue {
|
||||||
|
border-radius: 14rpx;
|
||||||
|
margin: 22rpx 23rpx 0 0;
|
||||||
|
width: 156rpx;
|
||||||
|
height: 156rpx;
|
||||||
|
position: relative;
|
||||||
|
font-size: 24rpx;
|
||||||
|
color: #bbb;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .upload .pictrue:nth-of-type(4n) {
|
||||||
|
margin-right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .upload .pictrue image {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
border-radius: 14rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .upload .pictrue .icon-guanbi1 {
|
||||||
|
position: absolute;
|
||||||
|
font-size: 45rpx;
|
||||||
|
top: -10rpx;
|
||||||
|
right: -10rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .upload .pictrue .icon-icon25201 {
|
||||||
|
color: #bfbfbf;
|
||||||
|
font-size: 50rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .list .item .upload .pictrue:nth-last-child(1) {
|
||||||
|
border: 1rpx solid #ddd;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
.apply-return .returnBnt {
|
||||||
|
font-size: 32rpx;
|
||||||
|
color: #fff;
|
||||||
|
width: 100%;
|
||||||
|
height: 86rpx;
|
||||||
|
border-radius: 50rpx;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 86rpx;
|
||||||
|
margin: 43rpx auto;
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -1,57 +1,35 @@
|
||||||
|
<!-- 售后日志的每一项展示 -->
|
||||||
<template>
|
<template>
|
||||||
<view class="log-item ss-flex">
|
<view class="log-item ss-flex">
|
||||||
<view class="log-icon ss-flex-col ss-col-center ss-m-r-20">
|
<view class="log-icon ss-flex-col ss-col-center ss-m-r-20">
|
||||||
<text class="cicon-title" :class="index === 0 ? 'activity-color' : ''"></text>
|
<text class="cicon-title" :class="index === 0 ? 'activity-color' : ''" />
|
||||||
<view v-if="data.length - 1 != index" class="line"></view>
|
<view v-if="data.length - 1 !== index" class="line" />
|
||||||
</view>
|
</view>
|
||||||
<view>
|
<view>
|
||||||
<view class="text">{{ item.log_type_text }}</view>
|
<view class="text">{{ item.content }}</view>
|
||||||
<mp-html class="richtext" :content="item.content"></mp-html>
|
<view class="date">
|
||||||
<view class="" v-if="item.images?.length">
|
{{ sheep.$helper.timeFormat(item.createTime, 'yyyy-mm-dd hh:MM:ss') }}
|
||||||
<scroll-view class="scroll-box" scroll-x scroll-anchoring>
|
|
||||||
<view class="ss-flex">
|
|
||||||
<view v-for="i in item.images" :key="i" class="ss-m-r-20">
|
|
||||||
<su-image
|
|
||||||
class="content-img"
|
|
||||||
isPreview
|
|
||||||
:previewList="state.commentImages"
|
|
||||||
:current="index"
|
|
||||||
:src="i"
|
|
||||||
:height="120"
|
|
||||||
:width="120"
|
|
||||||
mode="aspectFit"
|
|
||||||
></su-image>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</scroll-view>
|
|
||||||
</view>
|
|
||||||
<view class="date">{{ item.create_time }}</view>
|
|
||||||
</view>
|
|
||||||
</view>
|
</view>
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { reactive } from 'vue';
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
item: {
|
item: {
|
||||||
type: Object,
|
type: Object, // 当前日志
|
||||||
default() {},
|
default() {},
|
||||||
},
|
},
|
||||||
index: {
|
index: {
|
||||||
type: Number,
|
type: Number, // item 在 data 的下标
|
||||||
default: 0,
|
default: 0,
|
||||||
},
|
},
|
||||||
data: {
|
data: {
|
||||||
type: Object,
|
type: Object, // 日志列表
|
||||||
default() {},
|
default() {},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
const state = reactive({
|
|
||||||
commentImages: [],
|
|
||||||
});
|
|
||||||
props.item.images?.forEach((i) => {
|
|
||||||
state.commentImages.push(sheep.$url.cdn(i));
|
|
||||||
});
|
|
||||||
</script>
|
</script>
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.log-item {
|
.log-item {
|
||||||
|
|
|
@ -1,45 +1,29 @@
|
||||||
<!-- 售后进度 -->
|
<!-- 售后日志列表 -->
|
||||||
<template>
|
<template>
|
||||||
<s-layout title="售后进度">
|
<s-layout title="售后进度">
|
||||||
<view class="log-box">
|
<view class="log-box">
|
||||||
<view v-for="(item, index) in state.info" :key="item.title">
|
<view v-for="(item, index) in state.list" :key="item.id">
|
||||||
<log-item :item="item" :index="index" :data="state.info"></log-item>
|
<log-item :item="item" :index="index" :data="state.list" />
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</s-layout>
|
</s-layout>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import sheep from '@/sheep';
|
|
||||||
import { onLoad } from '@dcloudio/uni-app';
|
import { onLoad } from '@dcloudio/uni-app';
|
||||||
import { computed, reactive } from 'vue';
|
import { reactive } from 'vue';
|
||||||
import logItem from './log-item.vue';
|
import logItem from './log-item.vue';
|
||||||
|
import AfterSaleApi from '@/sheep/api/trade/afterSale';
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
active: 1,
|
list: [],
|
||||||
list: [
|
|
||||||
{
|
|
||||||
title: '买家下单',
|
|
||||||
desc: '2018-11-11',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '卖家发货',
|
|
||||||
desc: '2018-11-12',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '买家签收',
|
|
||||||
desc: '2018-11-13',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '交易完成',
|
|
||||||
desc: '2018-11-14',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
});
|
});
|
||||||
|
|
||||||
async function getDetail(id) {
|
async function getDetail(id) {
|
||||||
const { data } = await sheep.$api.order.aftersale.detail(id);
|
const { data } = await AfterSaleApi.getAfterSaleLogList(id);
|
||||||
state.info = data.logs;
|
state.list = data;
|
||||||
}
|
}
|
||||||
|
|
||||||
onLoad((options) => {
|
onLoad((options) => {
|
||||||
state.aftersaleId = options.id;
|
state.aftersaleId = options.id;
|
||||||
getDetail(options.id);
|
getDetail(options.id);
|
||||||
|
|
|
@ -1,146 +1,125 @@
|
||||||
<template>
|
<template>
|
||||||
<s-layout title="确认订单">
|
<s-layout title="确认订单">
|
||||||
<!-- TODO:这个判断先删除 v-if="state.orderInfo.need_address === 1" -->
|
<!-- v-if="state.orderInfo.need_address === 1" -->
|
||||||
|
<!-- 这个判断先删除 -->
|
||||||
<view class="bg-white address-box ss-m-b-14 ss-r-b-10" @tap="onSelectAddress">
|
<view class="bg-white address-box ss-m-b-14 ss-r-b-10" @tap="onSelectAddress">
|
||||||
<s-address-item :item="state.addressInfo" :hasBorderBottom="false">
|
<s-address-item :item="state.addressInfo" :hasBorderBottom="false">
|
||||||
<view class="ss-rest-button">
|
<view class="ss-rest-button"><text class="_icon-forward"></text></view>
|
||||||
<text class="_icon-forward" />
|
|
||||||
</view>
|
|
||||||
</s-address-item>
|
</s-address-item>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- 商品信息 -->
|
|
||||||
<view class="order-card-box ss-m-b-14">
|
<view class="order-card-box ss-m-b-14">
|
||||||
<s-goods-item
|
<s-goods-item v-for="item in state.orderInfo.goods_list" :key="item.goods_id"
|
||||||
v-for="item in state.orderInfo.items"
|
:img="item.current_sku_price.image || item.goods.image" :title="item.goods.title"
|
||||||
:key="item.skuId"
|
:skuText="item.current_sku_price?.goods_sku_text" :price="item.current_sku_price.price"
|
||||||
:img="item.picUrl"
|
:num="item.goods_num" marginBottom="10">
|
||||||
:title="item.spuName"
|
<template #top>
|
||||||
:skuText="item.properties.map((property) => property.valueName).join(' ')"
|
<view class="order-item ss-flex ss-col-center ss-row-between ss-p-x-20 bg-white">
|
||||||
:price="item.price"
|
<view class="item-title">配送方式</view>
|
||||||
:num="item.count"
|
<view class="ss-flex ss-col-center">
|
||||||
marginBottom="10"
|
<text class="item-value">{{ item.dispatch_type_text }}</text>
|
||||||
/>
|
</view>
|
||||||
|
</view>
|
||||||
|
</template>
|
||||||
|
</s-goods-item>
|
||||||
|
|
||||||
<view class="order-item ss-flex ss-col-center ss-row-between ss-p-x-20 bg-white ss-r-10">
|
<view class="order-item ss-flex ss-col-center ss-row-between ss-p-x-20 bg-white ss-r-10">
|
||||||
<view class="item-title">订单备注</view>
|
<view class="item-title">订单备注</view>
|
||||||
<view class="ss-flex ss-col-center">
|
<view class="ss-flex ss-col-center">
|
||||||
<uni-easyinput
|
<uni-easyinput maxlength="20" placeholder="建议留言前先与商家沟通" v-model="state.orderPayload.remark"
|
||||||
maxlength="20"
|
:inputBorder="false" :clearable="false"></uni-easyinput>
|
||||||
placeholder="建议留言前先与商家沟通"
|
|
||||||
v-model="state.orderPayload.remark"
|
|
||||||
:inputBorder="false"
|
|
||||||
:clearable="false"
|
|
||||||
/>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
<!-- 合计 -->
|
||||||
<!-- 价格信息 -->
|
|
||||||
<view class="bg-white total-card-box ss-p-20 ss-m-b-14 ss-r-10">
|
<view class="bg-white total-card-box ss-p-20 ss-m-b-14 ss-r-10">
|
||||||
<view class="total-box-content border-bottom">
|
<view class="total-box-content border-bottom">
|
||||||
<view class="order-item ss-flex ss-col-center ss-row-between">
|
<view class="order-item ss-flex ss-col-center ss-row-between">
|
||||||
<view class="item-title">商品金额</view>
|
<view class="item-title">商品金额</view>
|
||||||
<view class="ss-flex ss-col-center">
|
<view class="ss-flex ss-col-center">
|
||||||
<text class="item-value ss-m-r-24">
|
<text class="item-value ss-m-r-24">¥{{ state.orderInfo.goods_amount }}</text>
|
||||||
¥{{ fen2yuan(state.orderInfo.price.totalPrice) }}
|
|
||||||
</text>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<!-- TODO 芋艿:接入积分 -->
|
<view class="order-item ss-flex ss-col-center ss-row-between"
|
||||||
<view
|
v-if="state.orderPayload.order_type === 'score'">
|
||||||
class="order-item ss-flex ss-col-center ss-row-between"
|
|
||||||
v-if="state.orderPayload.order_type === 'score'"
|
|
||||||
>
|
|
||||||
<view class="item-title">扣除积分</view>
|
<view class="item-title">扣除积分</view>
|
||||||
<view class="ss-flex ss-col-center">
|
<view class="ss-flex ss-col-center">
|
||||||
<image
|
<image :src="sheep.$url.static('/static/img/shop/goods/score1.svg')" class="score-img"></image>
|
||||||
:src="sheep.$url.static('/static/img/shop/goods/score1.svg')"
|
|
||||||
class="score-img"
|
|
||||||
/>
|
|
||||||
<text class="item-value ss-m-r-24">{{ state.orderInfo.score_amount }}</text>
|
<text class="item-value ss-m-r-24">{{ state.orderInfo.score_amount }}</text>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view class="order-item ss-flex ss-col-center ss-row-between">
|
<view class="order-item ss-flex ss-col-center ss-row-between">
|
||||||
<view class="item-title">运费</view>
|
<view class="item-title">运费</view>
|
||||||
<view class="ss-flex ss-col-center">
|
<view class="ss-flex ss-col-center">
|
||||||
<text class="item-value ss-m-r-24">
|
<text class="item-value ss-m-r-24">+¥{{ state.orderInfo.dispatch_amount }}</text>
|
||||||
+¥{{ fen2yuan(state.orderInfo.price.deliveryPrice) }}
|
|
||||||
</text>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<!-- 优惠劵:只有 type = 0 普通订单(非拼团、秒杀、砍价),才可以使用优惠劵 -->
|
<view class="order-item ss-flex ss-col-center ss-row-between"
|
||||||
<view
|
v-if="state.orderPayload.order_type != 'score'">
|
||||||
class="order-item ss-flex ss-col-center ss-row-between"
|
<!-- <view v-if="state.orderInfo.coupon_discount_fee > 0" class="order-item ss-flex ss-col-center ss-row-between"> -->
|
||||||
v-if="state.orderInfo.type === 0"
|
|
||||||
>
|
|
||||||
<view class="item-title">优惠券</view>
|
<view class="item-title">优惠券</view>
|
||||||
<view class="ss-flex ss-col-center" @tap="state.showCoupon = true">
|
<view class="ss-flex ss-col-center" @tap="state.showCoupon = true">
|
||||||
<text class="item-value text-red" v-if="state.orderPayload.couponId > 0">
|
<text class="item-value text-red"
|
||||||
-¥{{ fen2yuan(state.orderInfo.price.couponPrice) }}
|
v-if="state.orderPayload.coupon_id">-¥{{ state.orderInfo.coupon_discount_fee }}</text>
|
||||||
</text>
|
<text class="item-value"
|
||||||
<text
|
:class="state.couponInfo.can_use?.length > 0 ? 'text-red' : 'text-disabled'" v-else>{{
|
||||||
class="item-value"
|
state.couponInfo.can_use?.length > 0
|
||||||
:class="state.couponInfo.length > 0 ? 'text-red' : 'text-disabled'"
|
? state.couponInfo.can_use?.length + '张可用'
|
||||||
v-else
|
: '暂无可用优惠券'
|
||||||
>
|
}}</text>
|
||||||
{{
|
|
||||||
state.couponInfo.length > 0 ? state.couponInfo.length + ' 张可用' : '暂无可用优惠券'
|
<text class="_icon-forward item-icon"></text>
|
||||||
}}
|
|
||||||
</text>
|
|
||||||
<text class="_icon-forward item-icon" />
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view
|
<view class="order-item ss-flex ss-col-center ss-row-between"
|
||||||
class="order-item ss-flex ss-col-center ss-row-between"
|
v-if="state.orderInfo.promo_infos?.length">
|
||||||
v-if="state.orderInfo.price.discountPrice > 0"
|
<!-- <view v-if="state.orderInfo.promo_discount_fee > 0" class="order-item ss-flex ss-col-center ss-row-between"> -->
|
||||||
>
|
|
||||||
<view class="item-title">活动优惠</view>
|
<view class="item-title">活动优惠</view>
|
||||||
<view class="ss-flex ss-col-center">
|
<view class="ss-flex ss-col-center" @tap="state.showDiscount = true">
|
||||||
<!-- @tap="state.showDiscount = true" TODO 芋艿:后续要把优惠信息打进去 -->
|
<text class="item-value text-red"> -¥{{ state.orderInfo.promo_discount_fee }} </text>
|
||||||
<text class="item-value text-red">
|
<text class="_icon-forward item-icon"></text>
|
||||||
-¥{{ fen2yuan(state.orderInfo.price.discountPrice) }}
|
|
||||||
</text>
|
|
||||||
<text class="_icon-forward item-icon" />
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view class="total-box-footer ss-font-28 ss-flex ss-row-right ss-col-center ss-m-r-28">
|
<view class="total-box-footer ss-font-28 ss-flex ss-row-right ss-col-center ss-m-r-28">
|
||||||
<view class="total-num ss-m-r-20">
|
<view class="total-num ss-m-r-20">共{{ state.totalNumber }}件</view>
|
||||||
共{{ state.orderInfo.items.reduce((acc, item) => acc + item.count, 0) }}件
|
|
||||||
</view>
|
|
||||||
<view>合计:</view>
|
<view>合计:</view>
|
||||||
<view class="total-num text-red"> ¥{{ fen2yuan(state.orderInfo.price.payPrice) }} </view>
|
<view class="total-num text-red"> ¥{{ state.orderInfo.pay_fee }} </view>
|
||||||
|
<view class="ss-flex" v-if="state.orderPayload.order_type === 'score'">
|
||||||
|
<view class="total-num ss-font-30 text-red ss-m-l-4"> + </view>
|
||||||
|
<image :src="sheep.$url.static('/static/img/shop/goods/score1.svg')" class="score-img"></image>
|
||||||
|
<view class="total-num ss-font-30 text-red">{{ state.orderInfo.score_amount }}</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<!-- 发票 -->
|
||||||
|
<view class="bg-white ss-p-20 ss-r-20">
|
||||||
|
<view class="order-item ss-flex ss-col-center ss-row-between">
|
||||||
|
<view class="item-title">发票申请</view>
|
||||||
|
<view class="ss-flex ss-col-center" @tap="onSelectInvoice">
|
||||||
|
<text class="item-value">{{ state.invoiceInfo.name || '无需开具发票' }}</text>
|
||||||
|
<text class="_icon-forward item-icon"></text>
|
||||||
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- 选择优惠券弹框 -->
|
<!-- 选择优惠券弹框 -->
|
||||||
<s-coupon-select
|
<s-coupon-select v-model="state.couponInfo" :show="state.showCoupon" @confirm="onSelectCoupon"
|
||||||
v-model="state.couponInfo"
|
@close="state.showCoupon = false" />
|
||||||
:show="state.showCoupon"
|
<!-- 满额折扣弹框 -->
|
||||||
@confirm="onSelectCoupon"
|
<s-discount-list v-model="state.orderInfo" :show="state.showDiscount" @close="state.showDiscount = false" />
|
||||||
@close="state.showCoupon = false"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<!-- 满额折扣弹框 TODO 芋艿:后续要把优惠信息打进去 -->
|
|
||||||
<s-discount-list
|
|
||||||
v-model="state.orderInfo"
|
|
||||||
:show="state.showDiscount"
|
|
||||||
@close="state.showDiscount = false"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<!-- 底部 -->
|
<!-- 底部 -->
|
||||||
<su-fixed bottom :opacity="false" bg="bg-white" placeholder :noFixed="false" :index="200">
|
<su-fixed bottom :opacity="false" bg="bg-white" placeholder :noFixed="false" :index="200">
|
||||||
<view class="footer-box border-top ss-flex ss-row-between ss-p-x-20 ss-col-center">
|
<view class="footer-box border-top ss-flex ss-row-between ss-p-x-20 ss-col-center">
|
||||||
<view class="total-box-footer ss-flex ss-col-center">
|
<view class="total-box-footer ss-flex ss-col-center">
|
||||||
<view class="total-num ss-font-30 text-red">
|
<view class="total-num ss-font-30 text-red"> ¥{{ state.orderInfo.pay_fee }} </view>
|
||||||
¥{{ fen2yuan(state.orderInfo.price.payPrice) }}
|
<view v-if="state.orderPayload.order_type === 'score'" class="ss-flex">
|
||||||
|
<view class="total-num ss-font-30 text-red ss-m-l-4">+</view>
|
||||||
|
<image :src="sheep.$url.static('/static/img/shop/goods/score1.svg')" class="score-img"></image>
|
||||||
|
<view class="total-num ss-font-30 text-red">{{ state.orderInfo.score_amount }}</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<button
|
|
||||||
class="ss-reset-button ui-BG-Main-Gradient ss-r-40 submit-btn ui-Shadow-Main"
|
<button class="ss-reset-button ui-BG-Main-Gradient ss-r-40 submit-btn ui-Shadow-Main" @tap="onConfirm">
|
||||||
@tap="onConfirm"
|
{{ exchangeNow ? '立即兑换' : '提交订单' }}
|
||||||
>
|
|
||||||
提交订单
|
|
||||||
</button>
|
</button>
|
||||||
</view>
|
</view>
|
||||||
</su-fixed>
|
</su-fixed>
|
||||||
|
@ -148,26 +127,36 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { reactive } from 'vue';
|
import {
|
||||||
import { onLoad } from '@dcloudio/uni-app';
|
reactive,
|
||||||
|
computed
|
||||||
|
} from 'vue';
|
||||||
|
import {
|
||||||
|
onLoad,
|
||||||
|
onPageScroll,
|
||||||
|
onShow
|
||||||
|
} from '@dcloudio/uni-app';
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { isEmpty } from 'lodash';
|
import {
|
||||||
import OrderApi from '@/sheep/api/trade/order';
|
isEmpty
|
||||||
import CouponApi from '@/sheep/api/promotion/coupon';
|
} from 'lodash';
|
||||||
import { fen2yuan } from '@/sheep/hooks/useGoods';
|
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
orderPayload: {},
|
orderPayload: {},
|
||||||
orderInfo: {
|
orderInfo: {},
|
||||||
items: [], // 商品项列表
|
addressInfo: {},
|
||||||
price: {}, // 价格信息
|
invoiceInfo: {},
|
||||||
},
|
totalNumber: 0,
|
||||||
addressInfo: {}, // 选择的收货地址
|
showCoupon: false,
|
||||||
showCoupon: false, // 是否展示优惠劵
|
couponInfo: [],
|
||||||
couponInfo: [], // 优惠劵列表
|
showDiscount: false,
|
||||||
showDiscount: false, // 是否展示营销活动
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// 立即兑换(立即兑换无需跳转收银台)
|
||||||
|
const exchangeNow = computed(
|
||||||
|
() => state.orderPayload.order_type === 'score' && state.orderInfo.pay_fee == 0,
|
||||||
|
);
|
||||||
|
|
||||||
// 选择地址
|
// 选择地址
|
||||||
function onSelectAddress() {
|
function onSelectAddress() {
|
||||||
uni.$once('SELECT_ADDRESS', (e) => {
|
uni.$once('SELECT_ADDRESS', (e) => {
|
||||||
|
@ -178,91 +167,128 @@
|
||||||
|
|
||||||
// 更改收货人地址&计算订单信息
|
// 更改收货人地址&计算订单信息
|
||||||
async function changeConsignee(addressInfo = {}) {
|
async function changeConsignee(addressInfo = {}) {
|
||||||
|
if (isEmpty(addressInfo)) {
|
||||||
|
const {
|
||||||
|
code,
|
||||||
|
data
|
||||||
|
} = await sheep.$api.user.address.default();
|
||||||
|
console.log(data, '默认收货地址');
|
||||||
|
if (code === 0 && !isEmpty(data)) {
|
||||||
|
console.log('执行赋值')
|
||||||
|
addressInfo = data;
|
||||||
|
}
|
||||||
|
}
|
||||||
if (!isEmpty(addressInfo)) {
|
if (!isEmpty(addressInfo)) {
|
||||||
state.addressInfo = addressInfo;
|
state.addressInfo = addressInfo;
|
||||||
|
state.orderPayload.address_id = state.addressInfo.id;
|
||||||
}
|
}
|
||||||
await getOrderInfo();
|
getOrderInfo();
|
||||||
}
|
}
|
||||||
|
|
||||||
// 选择优惠券
|
// 选择优惠券
|
||||||
async function onSelectCoupon(couponId) {
|
async function onSelectCoupon(e) {
|
||||||
state.orderPayload.couponId = couponId || 0;
|
state.orderPayload.coupon_id = e || 0;
|
||||||
await getOrderInfo();
|
getOrderInfo();
|
||||||
state.showCoupon = false;
|
state.showCoupon = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 提交订单
|
// 选择发票信息
|
||||||
|
function onSelectInvoice() {
|
||||||
|
uni.$once('SELECT_INVOICE', (e) => {
|
||||||
|
state.invoiceInfo = e.invoiceInfo;
|
||||||
|
state.orderPayload.invoice_id = e.invoiceInfo.id || 0;
|
||||||
|
});
|
||||||
|
sheep.$router.go('/pages/user/invoice/list');
|
||||||
|
}
|
||||||
|
|
||||||
|
// 提交订单/立即兑换
|
||||||
function onConfirm() {
|
function onConfirm() {
|
||||||
if (!state.addressInfo.id) {
|
if (!state.orderPayload.address_id && state.orderInfo.need_address === 1) {
|
||||||
sheep.$helper.toast('请选择收货地址');
|
sheep.$helper.toast('请选择收货地址');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (exchangeNow.value) {
|
||||||
|
uni.showModal({
|
||||||
|
title: '提示',
|
||||||
|
content: '确定使用积分立即兑换?',
|
||||||
|
cancelText: '再想想',
|
||||||
|
success: async function(res) {
|
||||||
|
if (res.confirm) {
|
||||||
submitOrder();
|
submitOrder();
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
submitOrder();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 创建订单&跳转
|
// 创建订单&跳转
|
||||||
async function submitOrder() {
|
async function submitOrder() {
|
||||||
const { code, data } = await OrderApi.createOrder({
|
const {
|
||||||
items: state.orderPayload.items,
|
error,
|
||||||
couponId: state.orderPayload.couponId,
|
data
|
||||||
addressId: state.addressInfo.id,
|
} = await sheep.$api.order.create(state.orderPayload);
|
||||||
deliveryType: 1, // TODO 芋艿:需要支持【门店自提】
|
if (error === 0) {
|
||||||
pointStatus: false, // TODO 芋艿:需要支持【积分选择】
|
// 更新购物车列表
|
||||||
});
|
if (state.orderPayload.from === 'cart') {
|
||||||
if (code !== 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// 更新购物车列表,如果来自购物车
|
|
||||||
if (state.orderPayload.items[0].cartId > 0) {
|
|
||||||
sheep.$store('cart').getList();
|
sheep.$store('cart').getList();
|
||||||
}
|
}
|
||||||
// 跳转到支付页面
|
if (exchangeNow.value) {
|
||||||
sheep.$router.redirect('/pages/pay/index', {
|
sheep.$router.redirect('/pages/pay/result', {
|
||||||
orderSN: data.payOrderId,
|
orderSN: data.order_sn,
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
sheep.$router.redirect('/pages/pay/index', {
|
||||||
|
orderSN: data.order_sn,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 检查库存&计算订单价格
|
// 检查库存&计算订单价格
|
||||||
async function getOrderInfo() {
|
async function getOrderInfo() {
|
||||||
// 计算价格
|
console.log(state.orderPayload, '计算价格传参')
|
||||||
const { data, code } = await OrderApi.settlementOrder({
|
// let {code, data} = await sheep.$api.order.calc(state.orderPayload);
|
||||||
items: state.orderPayload.items,
|
// let data = await sheep.$api.order.calc(state.orderPayload);
|
||||||
couponId: state.orderPayload.couponId,
|
console.log(state.orderPayload.items)
|
||||||
addressId: state.addressInfo.id,
|
let data = await sheep.$api.order.calc({
|
||||||
deliveryType: 1, // TODO 芋艿:需要支持【门店自提】
|
deliveryType: 1,
|
||||||
pointStatus: false, // TODO 芋艿:需要支持【积分选择】
|
pointStatus: false,
|
||||||
|
items: state.orderPayload.items
|
||||||
});
|
});
|
||||||
if (code !== 0) {
|
console.log(data, '修改后的获取订单详细数据')
|
||||||
return;
|
return;
|
||||||
}
|
if (error === 0) {
|
||||||
|
state.totalNumber = 0;
|
||||||
state.orderInfo = data;
|
state.orderInfo = data;
|
||||||
// 设置收货地址
|
state.orderInfo.goods_list.forEach((item) => {
|
||||||
if (state.orderInfo.address) {
|
state.totalNumber += item.goods_num;
|
||||||
state.addressInfo = state.orderInfo.address;
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获取可用优惠券
|
// 获取可用优惠券
|
||||||
async function getCoupons() {
|
async function getCoupons() {
|
||||||
const { code, data } = await CouponApi.getMatchCouponList(
|
const {
|
||||||
state.orderInfo.price.payPrice,
|
error,
|
||||||
state.orderInfo.items.map((item) => item.spuId),
|
data
|
||||||
state.orderPayload.items.map((item) => item.skuId),
|
} = await sheep.$api.order.coupons(state.orderPayload);
|
||||||
state.orderPayload.items.map((item) => item.categoryId),
|
if (error === 0) {
|
||||||
);
|
|
||||||
if (code === 0) {
|
|
||||||
state.couponInfo = data;
|
state.couponInfo = data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
onLoad(async (options) => {
|
onLoad(async (options) => {
|
||||||
if (!options.data) {
|
console.log(options)
|
||||||
sheep.$helper.toast('参数不正确,请检查!');
|
if (options.data) {
|
||||||
return;
|
|
||||||
}
|
|
||||||
state.orderPayload = JSON.parse(options.data);
|
state.orderPayload = JSON.parse(options.data);
|
||||||
await getOrderInfo();
|
changeConsignee();
|
||||||
await getCoupons();
|
if (state.orderPayload.order_type !== 'score') {
|
||||||
|
getCoupons();
|
||||||
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -232,7 +232,7 @@
|
||||||
<button
|
<button
|
||||||
class="ss-reset-button cancel-btn"
|
class="ss-reset-button cancel-btn"
|
||||||
v-if="state.orderInfo.buttons?.includes('comment')"
|
v-if="state.orderInfo.buttons?.includes('comment')"
|
||||||
@tap="onComment(state.orderInfo.id, state.orderInfo)"
|
@tap="onComment(state.orderInfo.id)"
|
||||||
>
|
>
|
||||||
评价
|
评价
|
||||||
</button>
|
</button>
|
||||||
|
@ -299,10 +299,10 @@
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// 查看物流 TODO 芋艿:待测试
|
// 查看物流
|
||||||
async function onExpress(orderId) {
|
async function onExpress(id) {
|
||||||
sheep.$router.go('/pages/order/express/list', {
|
sheep.$router.go('/pages/order/express/log', {
|
||||||
orderId,
|
id,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -362,10 +362,9 @@
|
||||||
// #endif
|
// #endif
|
||||||
|
|
||||||
// 评价
|
// 评价
|
||||||
function onComment(orderSN, orderId) {
|
function onComment(id) {
|
||||||
sheep.$router.go('/pages/goods/comment/add', {
|
sheep.$router.go('/pages/goods/comment/add', {
|
||||||
orderSN,
|
id
|
||||||
orderId,
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -377,7 +376,7 @@
|
||||||
merchant_trade_no: state.merchantTradeNo,
|
merchant_trade_no: state.merchantTradeNo,
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
res = await sheep.$api.order.detail(id);
|
res = await OrderApi.getOrder(id);
|
||||||
}
|
}
|
||||||
if (res.code === 0) {
|
if (res.code === 0) {
|
||||||
state.orderInfo = res.data;
|
state.orderInfo = res.data;
|
||||||
|
|
|
@ -1,104 +0,0 @@
|
||||||
<!-- 物流包裹-->
|
|
||||||
<template>
|
|
||||||
<s-layout title="物流包裹">
|
|
||||||
<view class="express-wrap">
|
|
||||||
<su-sticky bgColor="#FFE2B6">
|
|
||||||
<view class="header ss-flex ss-p-l-24">{{ state.list.length }}个包裹已派送</view>
|
|
||||||
</su-sticky>
|
|
||||||
<view
|
|
||||||
class="express-box"
|
|
||||||
v-for="item in state.list"
|
|
||||||
:key="item.type"
|
|
||||||
@tap="sheep.$router.go('/pages/order/express/log', { id: item.id, orderId: state.orderId })"
|
|
||||||
>
|
|
||||||
<view class="express-box-header ss-flex ss-row-between">
|
|
||||||
<view class="express-box-header-type">{{ item.status_text }}</view>
|
|
||||||
<view class="express-box-header-num">{{
|
|
||||||
item.express_name + ' : ' + item.express_no
|
|
||||||
}}</view>
|
|
||||||
</view>
|
|
||||||
<view class="express-box-content">
|
|
||||||
<view class="content-address">{{ item.logs[0]?.content }}</view>
|
|
||||||
<view class="" v-if="item.items?.length">
|
|
||||||
<scroll-view class="scroll-box" scroll-x scroll-anchoring>
|
|
||||||
<view class="ss-flex">
|
|
||||||
<view v-for="i in item.items" :key="i" class="ss-m-r-20"
|
|
||||||
><image class="content-img" :src="sheep.$url.static(i.goods_image)" />
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
</scroll-view>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
<view class="express-box-foot">共{{ item.items.length }}件商品</view>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
</s-layout>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script setup>
|
|
||||||
import sheep from '@/sheep';
|
|
||||||
import { onLoad } from '@dcloudio/uni-app';
|
|
||||||
import { computed, reactive } from 'vue';
|
|
||||||
const state = reactive({
|
|
||||||
list: [],
|
|
||||||
orderId: '',
|
|
||||||
});
|
|
||||||
async function getExpressList(id) {
|
|
||||||
const { data } = await sheep.$api.order.express(id, '');
|
|
||||||
state.list = data;
|
|
||||||
}
|
|
||||||
onLoad((Option) => {
|
|
||||||
state.orderId = Option.orderId;
|
|
||||||
getExpressList(state.orderId);
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.header {
|
|
||||||
height: 84rpx;
|
|
||||||
font-size: 30rpx;
|
|
||||||
font-weight: 500;
|
|
||||||
color: #a8700d;
|
|
||||||
}
|
|
||||||
.express-box {
|
|
||||||
background: #fff;
|
|
||||||
padding-bottom: 30rpx;
|
|
||||||
box-sizing: border-box;
|
|
||||||
margin-bottom: 20rpx;
|
|
||||||
.express-box-header {
|
|
||||||
height: 76rpx;
|
|
||||||
padding: 0 24rpx;
|
|
||||||
border-bottom: 2rpx solid rgba(#dfdfdf, 0.5);
|
|
||||||
.express-box-header-type {
|
|
||||||
font-size: 26rpx;
|
|
||||||
font-weight: 500;
|
|
||||||
color: #999;
|
|
||||||
}
|
|
||||||
.express-box-header-num {
|
|
||||||
font-size: 26rpx;
|
|
||||||
font-weight: 400;
|
|
||||||
color: #999999;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.express-box-content {
|
|
||||||
padding: 20rpx 24rpx;
|
|
||||||
.content-address {
|
|
||||||
font-size: 28rpx;
|
|
||||||
font-weight: 400;
|
|
||||||
color: #333333;
|
|
||||||
line-height: normal;
|
|
||||||
margin-bottom: 20rpx;
|
|
||||||
}
|
|
||||||
.content-img {
|
|
||||||
width: 180rpx;
|
|
||||||
height: 180rpx;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.express-box-foot {
|
|
||||||
padding: 0 24rpx;
|
|
||||||
font-size: 24rpx;
|
|
||||||
font-weight: 400;
|
|
||||||
color: #999999;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
|
@ -2,65 +2,46 @@
|
||||||
<template>
|
<template>
|
||||||
<s-layout title="物流追踪">
|
<s-layout title="物流追踪">
|
||||||
<view class="log-wrap">
|
<view class="log-wrap">
|
||||||
|
<!-- 商品信息 -->
|
||||||
<view class="log-card ss-flex ss-m-20 ss-r-10" v-if="goodsImages.length > 0">
|
<view class="log-card ss-flex ss-m-20 ss-r-10" v-if="goodsImages.length > 0">
|
||||||
<uni-swiper-dot :info="goodsImages" :current="state.current" mode="round">
|
<uni-swiper-dot :info="goodsImages" :current="state.current" mode="round">
|
||||||
<swiper class="swiper-box" @change="change">
|
<swiper class="swiper-box">
|
||||||
<swiper-item v-for="(item, index) in goodsImages" :key="index">
|
<swiper-item v-for="(item, index) in goodsImages" :key="index">
|
||||||
<image class="log-card-img" :src="sheep.$url.static(item.image)"></image>
|
<image class="log-card-img" :src="sheep.$url.static(item.image)" />
|
||||||
</swiper-item>
|
</swiper-item>
|
||||||
</swiper>
|
</swiper>
|
||||||
</uni-swiper-dot>
|
</uni-swiper-dot>
|
||||||
|
|
||||||
<view class="log-card-msg">
|
<view class="log-card-msg">
|
||||||
<view class="ss-flex ss-m-b-8">
|
<!-- TODO 芋艿:优化点:展示状态 -->
|
||||||
<view>物流状态:</view>
|
<!-- <view class="ss-flex ss-m-b-8">-->
|
||||||
<view class="warning-color">{{ state.info.status_text }}</view>
|
<!-- <view>物流状态:</view>-->
|
||||||
</view>
|
<!-- <view class="warning-color">{{ state.info.status_text }}</view>-->
|
||||||
<view class="ss-m-b-8">快递单号:{{ state.info.express_no }}</view>
|
<!-- </view>-->
|
||||||
<view>快递公司:{{ state.info.express_name }}</view>
|
<view class="ss-m-b-8">快递单号:{{ state.info.logisticsNo }}</view>
|
||||||
|
<view>快递公司:{{ state.info.logisticsName }}</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
|
<!-- 物流轨迹 -->
|
||||||
<view class="log-content ss-m-20 ss-r-10">
|
<view class="log-content ss-m-20 ss-r-10">
|
||||||
<view
|
<view
|
||||||
class="log-content-box ss-flex"
|
class="log-content-box ss-flex"
|
||||||
v-for="(item, index) in state.info.logs"
|
v-for="(item, index) in state.tracks"
|
||||||
:key="item.title"
|
:key="item.title"
|
||||||
>
|
>
|
||||||
<view class="log-icon ss-flex-col ss-col-center ss-m-r-20">
|
<view class="log-icon ss-flex-col ss-col-center ss-m-r-20">
|
||||||
<text
|
<text class="cicon-title" />
|
||||||
v-if="state.info.logs[index].status === state.info.logs[index - 1]?.status"
|
<view v-if="state.tracks.length - 1 !== index" class="line" />
|
||||||
class="cicon-title"
|
|
||||||
></text>
|
|
||||||
<text
|
|
||||||
v-if="state.info.logs[index].status != state.info.logs[index - 1]?.status"
|
|
||||||
:class="[
|
|
||||||
index === 0 ? 'activity-color' : 'info-color',
|
|
||||||
item.status === 'transport'
|
|
||||||
? 'sicon-transport'
|
|
||||||
: item.status === 'delivery'
|
|
||||||
? 'sicon-delivery'
|
|
||||||
: item.status === 'collect'
|
|
||||||
? 'sicon-a-collectmaterials'
|
|
||||||
: item.status === 'fail' || item.status === 'back' || item.status === 'refuse'
|
|
||||||
? 'sicon-circleclose'
|
|
||||||
: item.status === 'signfor'
|
|
||||||
? 'sicon-circlecheck'
|
|
||||||
: 'sicon-warning-outline',
|
|
||||||
]"
|
|
||||||
></text>
|
|
||||||
<view v-if="state.info.logs.length - 1 != index" class="line"></view>
|
|
||||||
</view>
|
</view>
|
||||||
<view class="log-content-msg">
|
<view class="log-content-msg">
|
||||||
<view
|
<!-- TODO 芋艿:优化点:展示状态 -->
|
||||||
v-if="
|
<!-- <view class="log-msg-title ss-m-b-20">-->
|
||||||
item.status_text &&
|
<!-- {{ item.status_text }}-->
|
||||||
state.info.logs[index].status != state.info.logs[index - 1]?.status
|
<!-- </view>-->
|
||||||
"
|
|
||||||
class="log-msg-title ss-m-b-20"
|
|
||||||
>{{ item.status_text }}</view
|
|
||||||
>
|
|
||||||
<view class="log-msg-desc ss-m-b-16">{{ item.content }}</view>
|
<view class="log-msg-desc ss-m-b-16">{{ item.content }}</view>
|
||||||
<view class="log-msg-date ss-m-b-40">{{ item.change_date }}</view>
|
<view class="log-msg-date ss-m-b-40">
|
||||||
|
{{ sheep.$helper.timeFormat(item.time, 'yyyy-mm-dd hh:MM:ss') }}
|
||||||
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
@ -72,31 +53,38 @@
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { onLoad } from '@dcloudio/uni-app';
|
import { onLoad } from '@dcloudio/uni-app';
|
||||||
import { computed, reactive } from 'vue';
|
import { computed, reactive } from 'vue';
|
||||||
|
import OrderApi from '@/sheep/api/trade/order';
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
info: [],
|
info: [],
|
||||||
current: 0,
|
tracks: [],
|
||||||
});
|
});
|
||||||
|
|
||||||
const goodsImages = computed(() => {
|
const goodsImages = computed(() => {
|
||||||
let array = [];
|
let array = [];
|
||||||
if (state.info.items) {
|
if (state.info.items) {
|
||||||
state.info.items.forEach((item) => {
|
state.info.items.forEach((item) => {
|
||||||
array.push({
|
array.push({
|
||||||
image: item.goods_image,
|
image: item.picUrl,
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
return array;
|
return array;
|
||||||
});
|
});
|
||||||
function change(e) {
|
|
||||||
state.current = e.detail.current;
|
async function getExpressDetail(id) {
|
||||||
|
const { data } = await OrderApi.getOrderExpressTrackList(id);
|
||||||
|
state.tracks = data.reverse();
|
||||||
}
|
}
|
||||||
async function getExpressdetail(id, orderId) {
|
|
||||||
const { data } = await sheep.$api.order.express(id, orderId);
|
async function getOrderDetail(id) {
|
||||||
|
const { data } = await OrderApi.getOrder(id)
|
||||||
state.info = data;
|
state.info = data;
|
||||||
}
|
}
|
||||||
onLoad((Option) => {
|
|
||||||
getExpressdetail(Option.id, Option.orderId);
|
onLoad((options) => {
|
||||||
|
getExpressDetail(options.id);
|
||||||
|
getOrderDetail(options.id);
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -55,7 +55,7 @@
|
||||||
取消订单
|
取消订单
|
||||||
</button>
|
</button>
|
||||||
<button v-if="order.buttons.includes('comment')" class="tool-btn ss-reset-button"
|
<button v-if="order.buttons.includes('comment')" class="tool-btn ss-reset-button"
|
||||||
@tap.stop="onComment(order.order_sn)">
|
@tap.stop="onComment(order.id)">
|
||||||
评价
|
评价
|
||||||
</button>
|
</button>
|
||||||
<button v-if="order.buttons.includes('delete')" class="delete-btn ss-reset-button"
|
<button v-if="order.buttons.includes('delete')" class="delete-btn ss-reset-button"
|
||||||
|
@ -164,10 +164,10 @@
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// 评价 TODO 芋艿:待测试
|
// 评价
|
||||||
function onComment(orderSN) {
|
function onComment(id) {
|
||||||
sheep.$router.go('/pages/goods/comment/add', {
|
sheep.$router.go('/pages/goods/comment/add', {
|
||||||
orderSN,
|
id,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -228,10 +228,10 @@
|
||||||
}
|
}
|
||||||
// #endif
|
// #endif
|
||||||
|
|
||||||
// 查看物流 TODO 芋艿:待测试
|
// 查看物流
|
||||||
async function onExpress(orderId) {
|
async function onExpress(id) {
|
||||||
sheep.$router.go('/pages/order/express/list', {
|
sheep.$router.go('/pages/order/express/log', {
|
||||||
orderId,
|
id,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,17 +2,14 @@
|
||||||
<template>
|
<template>
|
||||||
<s-layout title="收银台">
|
<s-layout title="收银台">
|
||||||
<view class="bg-white ss-modal-box ss-flex-col">
|
<view class="bg-white ss-modal-box ss-flex-col">
|
||||||
<!-- 订单信息 -->
|
|
||||||
<view class="modal-header ss-flex-col ss-col-center ss-row-center">
|
<view class="modal-header ss-flex-col ss-col-center ss-row-center">
|
||||||
<view class="money-box ss-m-b-20">
|
<view class="money-box ss-m-b-20">
|
||||||
<text class="money-text">{{ fen2yuan(state.orderInfo.price) }}</text>
|
<text class="money-text">{{ state.orderInfo.pay_fee }}</text>
|
||||||
</view>
|
</view>
|
||||||
<view class="time-text">
|
<view class="time-text">
|
||||||
<text>{{ payDescText }}</text>
|
<text>{{ payDescText }}</text>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- 支付方式 -->
|
|
||||||
<view class="modal-content ss-flex-1">
|
<view class="modal-content ss-flex-1">
|
||||||
<view class="pay-title ss-p-l-30 ss-m-y-30">选择支付方式</view>
|
<view class="pay-title ss-p-l-30 ss-m-y-30">选择支付方式</view>
|
||||||
<radio-group @change="onTapPay">
|
<radio-group @change="onTapPay">
|
||||||
|
@ -20,6 +17,7 @@
|
||||||
<view
|
<view
|
||||||
class="pay-item ss-flex ss-col-center ss-row-between ss-p-x-30 border-bottom"
|
class="pay-item ss-flex ss-col-center ss-row-between ss-p-x-30 border-bottom"
|
||||||
:class="{ 'disabled-pay-item': item.disabled }"
|
:class="{ 'disabled-pay-item': item.disabled }"
|
||||||
|
v-if="allowedPayment.includes(item.value)"
|
||||||
>
|
>
|
||||||
<view class="ss-flex ss-col-center">
|
<view class="ss-flex ss-col-center">
|
||||||
<image
|
<image
|
||||||
|
@ -27,19 +25,25 @@
|
||||||
v-if="item.disabled"
|
v-if="item.disabled"
|
||||||
:src="sheep.$url.static('/static/img/shop/pay/cod_disabled.png')"
|
:src="sheep.$url.static('/static/img/shop/pay/cod_disabled.png')"
|
||||||
mode="aspectFit"
|
mode="aspectFit"
|
||||||
/>
|
></image>
|
||||||
<image
|
<image
|
||||||
class="pay-icon"
|
class="pay-icon"
|
||||||
v-else
|
v-else
|
||||||
:src="sheep.$url.static(item.icon)"
|
:src="sheep.$url.static(item.icon)"
|
||||||
mode="aspectFit"
|
mode="aspectFit"
|
||||||
/>
|
></image>
|
||||||
<text class="pay-title">{{ item.title }}</text>
|
<text class="pay-title">{{ item.title }}</text>
|
||||||
</view>
|
</view>
|
||||||
<view class="check-box ss-flex ss-col-center ss-p-l-10">
|
<view class="check-box ss-flex ss-col-center ss-p-l-10">
|
||||||
<view class="userInfo-money ss-m-r-10" v-if="item.value === 'wallet'">
|
<view class="userInfo-money ss-m-r-10" v-if="item.value == 'money'">
|
||||||
余额: {{ userInfo.money }}元
|
余额: {{ userInfo.money }}元
|
||||||
</view>
|
</view>
|
||||||
|
<view
|
||||||
|
class="userInfo-money ss-m-r-10"
|
||||||
|
v-if="item.value == 'offline' && item.disabled"
|
||||||
|
>
|
||||||
|
部分商品不支持
|
||||||
|
</view>
|
||||||
<radio
|
<radio
|
||||||
:value="item.value"
|
:value="item.value"
|
||||||
color="var(--ui-BG-Main)"
|
color="var(--ui-BG-Main)"
|
||||||
|
@ -52,7 +56,6 @@
|
||||||
</label>
|
</label>
|
||||||
</radio-group>
|
</radio-group>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- 工具 -->
|
<!-- 工具 -->
|
||||||
<view class="modal-footer ss-flex ss-row-center ss-col-center ss-m-t-80 ss-m-b-40">
|
<view class="modal-footer ss-flex ss-row-center ss-col-center ss-m-t-80 ss-m-b-40">
|
||||||
<button v-if="state.payStatus === 0" class="ss-reset-button past-due-btn">
|
<button v-if="state.payStatus === 0" class="ss-reset-button past-due-btn">
|
||||||
|
@ -78,49 +81,95 @@
|
||||||
import { computed, reactive } from 'vue';
|
import { computed, reactive } from 'vue';
|
||||||
import { onLoad } from '@dcloudio/uni-app';
|
import { onLoad } from '@dcloudio/uni-app';
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { fen2yuan, useDurationTime } from '@/sheep/hooks/useGoods';
|
import { useDurationTime } from '@/sheep/hooks/useGoods';
|
||||||
import PayOrderApi from '@/sheep/api/pay/order';
|
|
||||||
import PayChannelApi from '@/sheep/api/pay/channel';
|
|
||||||
import { getPayMethods } from '@/sheep/platform/pay';
|
|
||||||
|
|
||||||
const userInfo = computed(() => sheep.$store('user').userInfo);
|
const userInfo = computed(() => sheep.$store('user').userInfo);
|
||||||
|
|
||||||
// 检测支付环境
|
// 检测支付环境
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
orderType: 'goods', // 订单类型; goods - 商品订单, recharge - 充值订单
|
orderType: 'goods',
|
||||||
orderInfo: {}, // 支付单信息
|
payment: '',
|
||||||
|
orderInfo: {},
|
||||||
payStatus: 0, // 0=检测支付环境, -2=未查询到支付单信息, -1=支付已过期, 1=待支付,2=订单已支付
|
payStatus: 0, // 0=检测支付环境, -2=未查询到支付单信息, -1=支付已过期, 1=待支付,2=订单已支付
|
||||||
payMethods: [], // 可选的支付方式
|
payMethods: [],
|
||||||
payment: '', // 选中的支付方式
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const allowedPayment = computed(() => {
|
||||||
|
if(state.orderType === 'recharge') {
|
||||||
|
return sheep.$store('app').platform.recharge_payment
|
||||||
|
}
|
||||||
|
return sheep.$store('app').platform.payment
|
||||||
|
});
|
||||||
|
|
||||||
|
const payMethods = [
|
||||||
|
{
|
||||||
|
icon: '/static/img/shop/pay/wechat.png',
|
||||||
|
title: '微信支付',
|
||||||
|
value: 'wechat',
|
||||||
|
disabled: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
icon: '/static/img/shop/pay/alipay.png',
|
||||||
|
title: '支付宝支付',
|
||||||
|
value: 'alipay',
|
||||||
|
disabled: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
icon: '/static/img/shop/pay/wallet.png',
|
||||||
|
title: '余额支付',
|
||||||
|
value: 'money',
|
||||||
|
disabled: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
icon: '/static/img/shop/pay/apple.png',
|
||||||
|
title: 'Apple Pay',
|
||||||
|
value: 'apple',
|
||||||
|
disabled: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
icon: '/static/img/shop/pay/cod.png',
|
||||||
|
title: '货到付款',
|
||||||
|
value: 'offline',
|
||||||
|
disabled: false,
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
const onPay = () => {
|
const onPay = () => {
|
||||||
if (state.payment === '') {
|
if (state.payment === '') {
|
||||||
sheep.$helper.toast('请选择支付方式');
|
sheep.$helper.toast('请选择支付方式');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (state.payment === 'wallet') {
|
if (state.payment === 'money') {
|
||||||
uni.showModal({
|
uni.showModal({
|
||||||
title: '提示',
|
title: '提示',
|
||||||
content: '确定要支付吗?',
|
content: '确定要支付吗?',
|
||||||
success: function (res) {
|
success: function (res) {
|
||||||
if (res.confirm) {
|
if (res.confirm) {
|
||||||
sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.id);
|
sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.order_sn);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
});
|
||||||
|
} else if (state.payment === 'offline') {
|
||||||
|
uni.showModal({
|
||||||
|
title: '提示',
|
||||||
|
content: '确定要下单吗?',
|
||||||
|
success: function (res) {
|
||||||
|
if (res.confirm) {
|
||||||
|
sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.order_sn);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.id);
|
sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.order_sn);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// 支付文案提示
|
|
||||||
const payDescText = computed(() => {
|
const payDescText = computed(() => {
|
||||||
if (state.payStatus === 2) {
|
if (state.payStatus === 2) {
|
||||||
return '该订单已支付';
|
return '该订单已支付';
|
||||||
}
|
}
|
||||||
if (state.payStatus === 1) {
|
if (state.payStatus === 1 && state.orderInfo.ext.expired_time !== 0) {
|
||||||
const time = useDurationTime(state.orderInfo.expireTime);
|
const time = useDurationTime(state.orderInfo.ext.expired_time);
|
||||||
if (time.ms <= 0) {
|
if (time.ms <= 0) {
|
||||||
state.payStatus = -1;
|
state.payStatus = -1;
|
||||||
return '';
|
return '';
|
||||||
|
@ -130,65 +179,86 @@
|
||||||
if (state.payStatus === -2) {
|
if (state.payStatus === -2) {
|
||||||
return '未查询到支付单信息';
|
return '未查询到支付单信息';
|
||||||
}
|
}
|
||||||
|
|
||||||
return '';
|
return '';
|
||||||
});
|
});
|
||||||
|
|
||||||
// 状态转换:payOrder.status => payStatus
|
|
||||||
function checkPayStatus() {
|
function checkPayStatus() {
|
||||||
if (state.orderInfo.status === 10
|
if (state.orderInfo.status === 'unpaid') {
|
||||||
|| state.orderInfo.status === 20 ) { // 支付成功
|
state.payStatus = 1;
|
||||||
state.payStatus = 2;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (state.orderInfo.status === 30) { // 支付关闭
|
if (state.orderInfo.status === 'closed') {
|
||||||
state.payStatus = -1;
|
state.payStatus = -1;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
state.payStatus = 1; // 待支付
|
state.payStatus = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 切换支付方式
|
|
||||||
function onTapPay(e) {
|
function onTapPay(e) {
|
||||||
state.payment = e.detail.value;
|
state.payment = e.detail.value;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 设置支付订单信息
|
async function setRechargeOrder(id) {
|
||||||
async function setOrder(id) {
|
const { data, error } = await sheep.$api.trade.order(id);
|
||||||
// 获得支付订单信息
|
if (error === 0) {
|
||||||
const { data, code } = await PayOrderApi.getOrder(id);
|
|
||||||
if (code !== 0 || !data) {
|
|
||||||
state.payStatus = -2;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
state.orderInfo = data;
|
state.orderInfo = data;
|
||||||
// 获得支付方式
|
state.payMethods = payMethods;
|
||||||
await setPayMethods();
|
|
||||||
// 设置支付状态
|
|
||||||
checkPayStatus();
|
checkPayStatus();
|
||||||
|
} else {
|
||||||
|
state.payStatus = -2;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获得支付方式
|
async function setGoodsOrder(id) {
|
||||||
async function setPayMethods() {
|
const { data, error } = await sheep.$api.order.detail(id);
|
||||||
const { data, code } = await PayChannelApi.getEnableChannelCodeList(state.orderInfo.appId)
|
if (error === 0) {
|
||||||
if (code !== 0) {
|
state.orderInfo = data;
|
||||||
return
|
if (state.orderInfo.ext.offline_status === 'none') {
|
||||||
|
payMethods.forEach((item, index, array) => {
|
||||||
|
if (item.value === 'offline') {
|
||||||
|
array.splice(index, 1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if (state.orderInfo.ext.offline_status === 'disabled') {
|
||||||
|
payMethods.forEach((item) => {
|
||||||
|
if (item.value === 'offline') {
|
||||||
|
item.disabled = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
state.payMethods = payMethods;
|
||||||
|
checkPayStatus();
|
||||||
|
} else {
|
||||||
|
state.payStatus = -2;
|
||||||
}
|
}
|
||||||
state.payMethods = getPayMethods(data)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
onLoad((options) => {
|
onLoad((options) => {
|
||||||
if (sheep.$platform.name === 'WechatOfficialAccount'
|
if (
|
||||||
&& sheep.$platform.os === 'ios'
|
sheep.$platform.name === 'WechatOfficialAccount' &&
|
||||||
&& !sheep.$platform.landingPage.includes('pages/pay/index')) {
|
sheep.$platform.os === 'ios' &&
|
||||||
|
!sheep.$platform.landingPage.includes('pages/pay/index')
|
||||||
|
) {
|
||||||
location.reload();
|
location.reload();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 获得支付订单信息
|
let id = '';
|
||||||
let id = options.id;
|
if (options.orderSN) {
|
||||||
if (options.orderType) {
|
id = options.orderSN;
|
||||||
state.orderType = options.orderType;
|
}
|
||||||
|
if (options.id) {
|
||||||
|
id = options.id;
|
||||||
|
}
|
||||||
|
if (options.type === 'recharge') {
|
||||||
|
state.orderType = 'recharge';
|
||||||
|
// 充值订单
|
||||||
|
setRechargeOrder(id);
|
||||||
|
} else {
|
||||||
|
state.orderType = 'goods';
|
||||||
|
// 商品订单
|
||||||
|
setGoodsOrder(id);
|
||||||
}
|
}
|
||||||
setOrder(id);
|
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -17,15 +17,17 @@
|
||||||
<view class="input-label ss-m-b-50">充值金额</view>
|
<view class="input-label ss-m-b-50">充值金额</view>
|
||||||
<view class="input-box ss-flex border-bottom ss-p-b-20" v-if="state.data.custom_status">
|
<view class="input-box ss-flex border-bottom ss-p-b-20" v-if="state.data.custom_status">
|
||||||
<view class="unit">¥</view>
|
<view class="unit">¥</view>
|
||||||
<uni-easyinput v-model="state.recharge_money" type="digit" placeholder="请输入充值金额" :inputBorder="false">
|
<uni-easyinput v-model="state.recharge_money" type="digit" placeholder="请输入充值金额"
|
||||||
|
:inputBorder="false">
|
||||||
</uni-easyinput>
|
</uni-easyinput>
|
||||||
</view>
|
</view>
|
||||||
<view class="face-value-box ss-flex ss-flex-wrap ss-m-y-40">
|
<view class="face-value-box ss-flex ss-flex-wrap ss-m-y-40">
|
||||||
<button class="ss-reset-button face-value-btn" v-for="item in state.faceValueList" :key="item.money"
|
<button class="ss-reset-button face-value-btn" v-for="item in state.faceValueList" :key="item.money"
|
||||||
:class="[{ 'btn-active': state.recharge_money == parseFloat(item.money) }]" @tap="onCard(item.money)">
|
:class="[{ 'btn-active': state.recharge_money == parseFloat(item.money) }]"
|
||||||
<text class="face-value-title">{{ item.money }}</text>
|
@tap="onCard(item.payPrice/100)">
|
||||||
<view v-if="item.gift" class="face-value-tag">
|
<text class="face-value-title">{{ item.payPrice/100 }}</text>
|
||||||
送{{ item.gift }}{{ state.data.gift_type == 'money' ? '元' : '积分' }}</view>
|
<view v-if="item.bonusPrice" class="face-value-tag">
|
||||||
|
送{{ item.bonusPrice/100 }}{{ state.data.gift_type == 'money' ? '元' : '积分' }}</view>
|
||||||
</button>
|
</button>
|
||||||
</view>
|
</view>
|
||||||
<button class="ss-reset-button save-btn ui-BG-Main-Gradient ss-m-t-60 ui-Shadow-Main" @tap="onConfirm">
|
<button class="ss-reset-button save-btn ui-BG-Main-Gradient ss-m-t-60 ui-Shadow-Main" @tap="onConfirm">
|
||||||
|
@ -38,9 +40,14 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { computed, reactive } from 'vue';
|
import {
|
||||||
|
computed,
|
||||||
|
reactive
|
||||||
|
} from 'vue';
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { onLoad } from '@dcloudio/uni-app';
|
import {
|
||||||
|
onLoad
|
||||||
|
} from '@dcloudio/uni-app';
|
||||||
|
|
||||||
const userInfo = computed(() => sheep.$store('user').userInfo);
|
const userInfo = computed(() => sheep.$store('user').userInfo);
|
||||||
const statusBarHeight = sheep.$platform.device.statusBarHeight * 2;
|
const statusBarHeight = sheep.$platform.device.statusBarHeight * 2;
|
||||||
|
@ -58,10 +65,14 @@ function onCard(e) {
|
||||||
}
|
}
|
||||||
async function getRechargeTabs() {
|
async function getRechargeTabs() {
|
||||||
const res = await sheep.$api.trade.rechargeRules();
|
const res = await sheep.$api.trade.rechargeRules();
|
||||||
|
const res2 = await sheep.$api.trade.rechargeRules2();
|
||||||
if (res.error === 0) {
|
if (res.error === 0) {
|
||||||
state.data = res.data;
|
state.data = res.data;
|
||||||
state.data.status = res.data.status;
|
state.data.status = res.data.status;
|
||||||
state.faceValueList = res.data.quick_amounts;
|
console.log(res);
|
||||||
|
console.log(res2);
|
||||||
|
// state.faceValueList = res.data.quick_amounts;
|
||||||
|
state.faceValueList = res2.data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,14 +81,21 @@ function onChange(e) {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function onConfirm() {
|
async function onConfirm() {
|
||||||
const { error, data } = await sheep.$api.trade.recharge({
|
const {
|
||||||
recharge_money: state.recharge_money,
|
code,
|
||||||
|
data
|
||||||
|
} = await sheep.$api.trade.recharge({
|
||||||
|
packageId: 0,
|
||||||
|
payPrice: state.recharge_money * 100
|
||||||
});
|
});
|
||||||
if (error === 0) {
|
if (code === 0) {
|
||||||
// #ifdef MP
|
// #ifdef MP
|
||||||
sheep.$platform.useProvider('wechat').subscribeMessage('money_change');
|
sheep.$platform.useProvider('wechat').subscribeMessage('money_change');
|
||||||
// #endif
|
// #endif
|
||||||
sheep.$router.go('/pages/pay/index', { orderSN: data.order_sn, type: 'recharge' });
|
sheep.$router.go('/pages/pay/index', {
|
||||||
|
orderSN: data.order_sn,
|
||||||
|
type: 'recharge'
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
onLoad(() => {
|
onLoad(() => {
|
||||||
|
|
|
@ -2,27 +2,34 @@
|
||||||
<template>
|
<template>
|
||||||
<s-layout title="支付结果" :bgStyle="{ color: '#FFF' }">
|
<s-layout title="支付结果" :bgStyle="{ color: '#FFF' }">
|
||||||
<view class="pay-result-box ss-flex-col ss-row-center ss-col-center">
|
<view class="pay-result-box ss-flex-col ss-row-center ss-col-center">
|
||||||
<!-- 信息展示 -->
|
<view class="pay-waiting ss-m-b-30" v-if="payResult === 'waiting'"> </view>
|
||||||
<view class="pay-waiting ss-m-b-30" v-if="payResult === 'waiting'" />
|
|
||||||
<image
|
<image
|
||||||
class="pay-img ss-m-b-30"
|
class="pay-img ss-m-b-30"
|
||||||
v-if="payResult === 'success'"
|
v-if="payResult === 'success'"
|
||||||
:src="sheep.$url.static('/static/img/shop/order/order_pay_success.gif')"
|
:src="sheep.$url.static('/static/img/shop/order/order_pay_success.gif')"
|
||||||
/>
|
></image>
|
||||||
<image
|
<image
|
||||||
class="pay-img ss-m-b-30"
|
class="pay-img ss-m-b-30"
|
||||||
v-if="['failed', 'closed'].includes(payResult)"
|
v-if="['failed', 'closed'].includes(payResult)"
|
||||||
:src="sheep.$url.static('/static/img/shop/order/order_paty_fail.gif')"
|
:src="sheep.$url.static('/static/img/shop/order/order_paty_fail.gif')"
|
||||||
/>
|
></image>
|
||||||
<view class="tip-text ss-m-b-30" v-if="payResult === 'success'">支付成功</view>
|
<view class="tip-text ss-m-b-30" v-if="payResult == 'success'">{{
|
||||||
<view class="tip-text ss-m-b-30" v-if="payResult === 'failed'">支付失败</view>
|
state.orderInfo.pay_mode === 'offline' ? '下单成功' : '支付成功'
|
||||||
<view class="tip-text ss-m-b-30" v-if="payResult === 'closed'">该订单已关闭</view>
|
}}</view>
|
||||||
<view class="tip-text ss-m-b-30" v-if="payResult === 'waiting'">检测支付结果...</view>
|
<view class="tip-text ss-m-b-30" v-if="payResult == 'failed'">支付失败</view>
|
||||||
|
<view class="tip-text ss-m-b-30" v-if="payResult == 'closed'">该订单已关闭</view>
|
||||||
|
<view class="tip-text ss-m-b-30" v-if="payResult == 'waiting'">检测支付结果...</view>
|
||||||
<view class="pay-total-num ss-flex" v-if="payResult === 'success'">
|
<view class="pay-total-num ss-flex" v-if="payResult === 'success'">
|
||||||
<view>¥{{ fen2yuan(state.orderInfo.price) }}</view>
|
<view v-if="Number(state.orderInfo.pay_fee) > 0">¥{{ state.orderInfo.pay_fee }}</view>
|
||||||
|
<view v-if="state.orderInfo.score_amount && Number(state.orderInfo.pay_fee) > 0">+</view>
|
||||||
|
<view class="price-text ss-flex ss-col-center" v-if="state.orderInfo.score_amount">
|
||||||
|
<image
|
||||||
|
:src="sheep.$url.static('/static/img/shop/goods/score1.svg')"
|
||||||
|
class="score-img"
|
||||||
|
></image>
|
||||||
|
<view>{{ state.orderInfo.score_amount }}</view>
|
||||||
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- 操作区 -->
|
|
||||||
<view class="btn-box ss-flex ss-row-center ss-m-t-50">
|
<view class="btn-box ss-flex ss-row-center ss-m-t-50">
|
||||||
<button class="back-btn ss-reset-button" @tap="sheep.$router.go('/pages/index/index')">
|
<button class="back-btn ss-reset-button" @tap="sheep.$router.go('/pages/index/index')">
|
||||||
返回首页
|
返回首页
|
||||||
|
@ -30,29 +37,30 @@
|
||||||
<button
|
<button
|
||||||
class="check-btn ss-reset-button"
|
class="check-btn ss-reset-button"
|
||||||
v-if="payResult === 'failed'"
|
v-if="payResult === 'failed'"
|
||||||
@tap="
|
@tap="sheep.$router.redirect('/pages/pay/index', { orderSN: state.orderId })"
|
||||||
sheep.$router.redirect('/pages/pay/index', { id: state.id, orderType: state.orderType })
|
|
||||||
"
|
|
||||||
>
|
>
|
||||||
重新支付
|
重新支付
|
||||||
</button>
|
</button>
|
||||||
<button class="check-btn ss-reset-button" v-if="payResult === 'success'" @tap="onOrder">
|
<button class="check-btn ss-reset-button" v-if="payResult === 'success'" @tap="onOrder">
|
||||||
查看订单
|
查看订单
|
||||||
</button>
|
</button>
|
||||||
<!-- TODO 芋艿:拼团接入 -->
|
|
||||||
<button
|
<button
|
||||||
class="check-btn ss-reset-button"
|
class="check-btn ss-reset-button"
|
||||||
v-if="payResult === 'success' && state.tradeOrder.type === 3"
|
v-if="
|
||||||
|
payResult === 'success' &&
|
||||||
|
['groupon', 'groupon_ladder'].includes(state.orderInfo.activity_type)
|
||||||
|
"
|
||||||
@tap="sheep.$router.redirect('/pages/activity/groupon/order')"
|
@tap="sheep.$router.redirect('/pages/activity/groupon/order')"
|
||||||
>
|
>
|
||||||
我的拼团
|
我的拼团
|
||||||
</button>
|
</button>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- TODO 芋艿:订阅 -->
|
|
||||||
<!-- #ifdef MP -->
|
<!-- #ifdef MP -->
|
||||||
<view class="subscribe-box ss-flex ss-m-t-44">
|
<view class="subscribe-box ss-flex ss-m-t-44">
|
||||||
<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')"
|
||||||
|
></image>
|
||||||
<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>
|
||||||
</view>
|
</view>
|
||||||
|
@ -66,20 +74,15 @@
|
||||||
import { reactive, computed } from 'vue';
|
import { reactive, computed } from 'vue';
|
||||||
import { isEmpty } from 'lodash';
|
import { isEmpty } from 'lodash';
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import PayOrderApi from '@/sheep/api/pay/order';
|
|
||||||
import { fen2yuan } from '../../sheep/hooks/useGoods';
|
|
||||||
import OrderApi from '@/sheep/api/trade/order';
|
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
id: 0, // 支付单号
|
orderId: 0,
|
||||||
orderType: 'goods', // 订单类型
|
orderType: 'goods',
|
||||||
result: 'unpaid', // 支付状态
|
result: 'unpaid', // 支付状态
|
||||||
orderInfo: {}, // 支付订单信息
|
orderInfo: {}, // 订单详情
|
||||||
tradeOrder: {}, // 商品订单信息,只有在 orderType 为 goods 才会请求。目的:【我的拼团】按钮的展示
|
|
||||||
counter: 0, // 获取结果次数
|
counter: 0, // 获取结果次数
|
||||||
});
|
});
|
||||||
|
|
||||||
// 支付结果 result => payResult
|
|
||||||
const payResult = computed(() => {
|
const payResult = computed(() => {
|
||||||
if (state.result === 'unpaid') {
|
if (state.result === 'unpaid') {
|
||||||
return 'waiting';
|
return 'waiting';
|
||||||
|
@ -90,65 +93,57 @@
|
||||||
if (state.result === 'failed') {
|
if (state.result === 'failed') {
|
||||||
return 'failed';
|
return 'failed';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (state.result === 'closed') {
|
if (state.result === 'closed') {
|
||||||
return 'closed';
|
return 'closed';
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
async function getOrderInfo(orderId) {
|
||||||
// 获得订单信息
|
let checkPayResult;
|
||||||
async function getOrderInfo(id) {
|
|
||||||
state.counter++;
|
state.counter++;
|
||||||
// 1. 加载订单信息
|
if (state.orderType === 'recharge') {
|
||||||
const { data, code } = await PayOrderApi.getOrder(id);
|
checkPayResult = sheep.$api.trade.order;
|
||||||
if (code === 0) {
|
} else {
|
||||||
|
checkPayResult = sheep.$api.order.detail;
|
||||||
|
}
|
||||||
|
const { data, error } = await checkPayResult(orderId);
|
||||||
|
if (error === 0) {
|
||||||
state.orderInfo = data;
|
state.orderInfo = data;
|
||||||
if (!state.orderInfo || state.orderInfo.status === 30) {
|
if (state.orderInfo.status === 'closed') {
|
||||||
// 支付关闭
|
|
||||||
state.result = 'closed';
|
state.result = 'closed';
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (state.orderInfo.status !== 0) {
|
if (state.orderInfo.status !== 'unpaid') {
|
||||||
// 非待支付,可能是已支付,可能是已退款
|
|
||||||
state.result = 'paid';
|
state.result = 'paid';
|
||||||
// #ifdef MP
|
// #ifdef MP
|
||||||
subscribeMessage();
|
subscribeMessage();
|
||||||
// #endif
|
// #endif
|
||||||
// 特殊:获得商品订单信息
|
|
||||||
if (state.orderType === 'goods') {
|
|
||||||
const { data, code } = await OrderApi.getOrder(state.orderInfo.merchantOrderId);
|
|
||||||
if (code === 0) {
|
|
||||||
state.tradeOrder = data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 2.1 情况三一:未支付,且轮询次数小于三次,则继续轮询
|
|
||||||
if (state.counter < 3 && state.result === 'unpaid') {
|
if (state.counter < 3 && state.result === 'unpaid') {
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
getOrderInfo(id);
|
getOrderInfo(orderId);
|
||||||
}, 1500);
|
}, 1500);
|
||||||
}
|
}
|
||||||
// 2.2 情况二:超过三次检测才判断为支付失败
|
// 超过三次检测才判断为支付失败
|
||||||
if (state.counter >= 3) {
|
if (state.counter >= 3) {
|
||||||
state.result = 'failed';
|
state.result = 'failed';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function onOrder() {
|
function onOrder() {
|
||||||
// TODO 芋艿:待测试
|
if ((state.orderType === 'recharge')) {
|
||||||
if (state.orderType === 'recharge') {
|
|
||||||
sheep.$router.redirect('/pages/pay/recharge-log');
|
sheep.$router.redirect('/pages/pay/recharge-log');
|
||||||
} else {
|
} else {
|
||||||
sheep.$router.redirect('/pages/order/list');
|
sheep.$router.redirect('/pages/order/list');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO 芋艿:待测试
|
|
||||||
// #ifdef MP
|
// #ifdef MP
|
||||||
function subscribeMessage() {
|
function subscribeMessage() {
|
||||||
let event = ['order_dispatched'];
|
let event = ['order_dispatched'];
|
||||||
if (state.tradeOrder.type === 3) {
|
if (['groupon', 'groupon_ladder'].includes(state.orderInfo.activity_type)) {
|
||||||
event.push('groupon_finish');
|
event.push('groupon_finish');
|
||||||
event.push('groupon_fail');
|
event.push('groupon_fail');
|
||||||
}
|
}
|
||||||
|
@ -157,13 +152,18 @@
|
||||||
// #endif
|
// #endif
|
||||||
|
|
||||||
onLoad(async (options) => {
|
onLoad(async (options) => {
|
||||||
|
let id = '';
|
||||||
// 支付订单号
|
// 支付订单号
|
||||||
if (options.id) {
|
if (options.orderSN) {
|
||||||
state.id = options.id;
|
id = options.orderSN;
|
||||||
}
|
}
|
||||||
// 订单类型
|
if (options.id) {
|
||||||
if (options.orderType) {
|
id = options.id;
|
||||||
state.orderType = options.orderType;
|
}
|
||||||
|
state.orderId = id;
|
||||||
|
|
||||||
|
if (options.orderType === 'recharge') {
|
||||||
|
state.orderType = 'recharge';
|
||||||
}
|
}
|
||||||
|
|
||||||
// 支付结果传值过来是失败,则直接显示失败界面
|
// 支付结果传值过来是失败,则直接显示失败界面
|
||||||
|
@ -171,16 +171,14 @@
|
||||||
state.result = 'failed';
|
state.result = 'failed';
|
||||||
} else {
|
} else {
|
||||||
// 轮询三次检测订单支付结果
|
// 轮询三次检测订单支付结果
|
||||||
await getOrderInfo(state.id);
|
getOrderInfo(state.orderId);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
onShow(() => {
|
onShow(() => {
|
||||||
if (isEmpty(state.orderInfo)) {
|
if(isEmpty(state.orderInfo)) return;
|
||||||
return;
|
getOrderInfo(state.orderId);
|
||||||
}
|
})
|
||||||
getOrderInfo(state.id);
|
|
||||||
});
|
|
||||||
|
|
||||||
onHide(() => {
|
onHide(() => {
|
||||||
state.result = 'unpaid';
|
state.result = 'unpaid';
|
||||||
|
|
|
@ -101,6 +101,7 @@
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
const onRegionConfirm = (e) => {
|
const onRegionConfirm = (e) => {
|
||||||
|
console.log(e);
|
||||||
state.model = {
|
state.model = {
|
||||||
...state.model,
|
...state.model,
|
||||||
...e,
|
...e,
|
||||||
|
@ -186,7 +187,13 @@
|
||||||
|
|
||||||
if (options.data) {
|
if (options.data) {
|
||||||
let data = JSON.parse(options.data);
|
let data = JSON.parse(options.data);
|
||||||
console.log(data)
|
const areaData = uni.getStorageSync('areaData');
|
||||||
|
let provinceArr = areaData.filter(item => item.name == data.province_name);
|
||||||
|
data.province_id = provinceArr[0].id;
|
||||||
|
let provinceArr2 = provinceArr[0].children.filter(item => item.name == data.city_name);
|
||||||
|
data.city_id = provinceArr2[0].id;
|
||||||
|
let provinceArr3 = provinceArr2[0].children.filter(item => item.name == data.district_name);
|
||||||
|
data.district_id = provinceArr3[0].id;
|
||||||
state.model = {
|
state.model = {
|
||||||
...state.model,
|
...state.model,
|
||||||
...data,
|
...data,
|
||||||
|
|
|
@ -1,12 +1,11 @@
|
||||||
|
<!-- 我的商品收藏 -->
|
||||||
<template>
|
<template>
|
||||||
<s-layout title="商品收藏">
|
<s-layout title="商品收藏">
|
||||||
<view class="cart-box ss-flex ss-flex-col ss-row-between">
|
<view class="cart-box ss-flex ss-flex-col ss-row-between">
|
||||||
<!-- 头部 -->
|
<!-- 头部 -->
|
||||||
<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
|
||||||
|
@ -20,15 +19,16 @@
|
||||||
v-if="!state.editMode && state.pagination.total"
|
v-if="!state.editMode && state.pagination.total"
|
||||||
class="ss-reset-button ui-TC-Main"
|
class="ss-reset-button ui-TC-Main"
|
||||||
@tap="state.editMode = true"
|
@tap="state.editMode = true"
|
||||||
>编辑</button
|
|
||||||
>
|
>
|
||||||
|
编辑
|
||||||
|
</button>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<!-- 内容 -->
|
<!-- 内容 -->
|
||||||
<view class="cart-content">
|
<view class="cart-content">
|
||||||
<view
|
<view
|
||||||
class="goods-box ss-r-10 ss-m-b-14"
|
class="goods-box ss-r-10 ss-m-b-14"
|
||||||
v-for="item in state.pagination.data"
|
v-for="item in state.pagination.list"
|
||||||
:key="item.id"
|
:key="item.id"
|
||||||
>
|
>
|
||||||
<view class="ss-flex ss-col-center">
|
<view class="ss-flex ss-col-center">
|
||||||
|
@ -44,12 +44,10 @@
|
||||||
@tap.stop="onSelect(item.spuId)"
|
@tap.stop="onSelect(item.spuId)"
|
||||||
/>
|
/>
|
||||||
</label>
|
</label>
|
||||||
<!-- :skuText="item.goods.subtitle" -->
|
|
||||||
<s-goods-item
|
<s-goods-item
|
||||||
:title="item.spuName"
|
:title="item.spuName"
|
||||||
:img="item.picUrl"
|
:img="item.picUrl"
|
||||||
:price="item.price"
|
:price="item.price"
|
||||||
|
|
||||||
priceColor="#FF3000"
|
priceColor="#FF3000"
|
||||||
:titleWidth="400"
|
:titleWidth="400"
|
||||||
@tap="
|
@tap="
|
||||||
|
@ -57,11 +55,11 @@
|
||||||
id: item.spuId,
|
id: item.spuId,
|
||||||
})
|
})
|
||||||
"
|
"
|
||||||
>
|
/>
|
||||||
</s-goods-item>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- 底部 -->
|
<!-- 底部 -->
|
||||||
<su-fixed bottom :val="0" placeholder v-show="state.editMode">
|
<su-fixed bottom :val="0" placeholder v-show="state.editMode">
|
||||||
<view class="cart-footer ss-flex ss-col-center ss-row-between ss-p-x-30 border-bottom">
|
<view class="cart-footer ss-flex ss-col-center ss-row-between ss-p-x-30 border-bottom">
|
||||||
|
@ -79,9 +77,9 @@
|
||||||
<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>
|
||||||
</view>
|
</view>
|
||||||
</su-fixed>
|
</su-fixed>
|
||||||
|
@ -92,7 +90,7 @@
|
||||||
:content-text="{
|
:content-text="{
|
||||||
contentdown: '上拉加载更多',
|
contentdown: '上拉加载更多',
|
||||||
}"
|
}"
|
||||||
@tap="loadmore"
|
@tap="loadMore"
|
||||||
/>
|
/>
|
||||||
<s-empty v-if="state.pagination.total === 0" text="暂无收藏" icon="/static/collect-empty.png" />
|
<s-empty v-if="state.pagination.total === 0" text="暂无收藏" icon="/static/collect-empty.png" />
|
||||||
</s-layout>
|
</s-layout>
|
||||||
|
@ -103,98 +101,89 @@
|
||||||
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';
|
||||||
|
import FavoriteApi from '@/sheep/api/product/favorite';
|
||||||
|
import { resetPagination } from '@/sheep/util';
|
||||||
|
|
||||||
const sys_navBar = sheep.$platform.navbar;
|
const sys_navBar = sheep.$platform.navbar;
|
||||||
const pagination = {
|
|
||||||
data: [],
|
|
||||||
current_page: 1,
|
|
||||||
total: 1,
|
|
||||||
last_page: 1,
|
|
||||||
};
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
pagination: {
|
pagination: {
|
||||||
data: [],
|
list: [],
|
||||||
current_page: 1,
|
total: 0,
|
||||||
total: 1,
|
pageNo: 1,
|
||||||
last_page: 1,
|
pageSize: 6,
|
||||||
},
|
},
|
||||||
loadStatus: '',
|
loadStatus: '',
|
||||||
|
|
||||||
editMode: false,
|
editMode: false,
|
||||||
selectedCollectList: [],
|
selectedCollectList: [], // 选中的 SPU 数组
|
||||||
selectAll: false,
|
selectAll: false,
|
||||||
});
|
});
|
||||||
|
|
||||||
async function getData(page = 1, list_rows = 6) {
|
async function getData() {
|
||||||
state.loadStatus = 'loading';
|
state.loadStatus = 'loading';
|
||||||
let res = await sheep.$api.user.favorite.list({
|
const { code, data } = await FavoriteApi.getFavoritePage({
|
||||||
pageSize:list_rows,
|
pageNo: state.pagination.pageNo,
|
||||||
pageNo:page,
|
pageSize: state.pagination.pageSize,
|
||||||
});
|
});
|
||||||
if (res.code === 0) {
|
if (code !== 0) {
|
||||||
console.log('yudao收藏列表',res)
|
return;
|
||||||
let orderList = _.concat(state.pagination.data, res.data.list);
|
|
||||||
state.pagination = {
|
|
||||||
...res.data,
|
|
||||||
data: orderList,
|
|
||||||
};
|
|
||||||
// 没有原接口文档不太理解这字段意思
|
|
||||||
if (state.pagination.current_page < state.pagination.last_page) {
|
|
||||||
state.loadStatus = 'more';
|
|
||||||
} else {
|
|
||||||
state.loadStatus = 'noMore';
|
|
||||||
}
|
}
|
||||||
}
|
state.pagination.list = _.concat(state.pagination.list, data.list)
|
||||||
}
|
state.pagination.total = data.total;
|
||||||
// 格式化价格
|
state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore';
|
||||||
function formatPrice(e) {
|
|
||||||
return e.length === 1 ? e[0] : e.join('~');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 单选选中
|
// 单选选中
|
||||||
const onSelect = (id) => {
|
const onSelect = (spuId) => {
|
||||||
if (!state.selectedCollectList.includes(id)) {
|
if (!state.selectedCollectList.includes(spuId)) {
|
||||||
state.selectedCollectList.push(id);
|
state.selectedCollectList.push(spuId);
|
||||||
} else {
|
} else {
|
||||||
state.selectedCollectList.splice(state.selectedCollectList.indexOf(id), 1);
|
state.selectedCollectList.splice(state.selectedCollectList.indexOf(spuId), 1);
|
||||||
}
|
}
|
||||||
state.selectAll = state.selectedCollectList.length === state.pagination.data.length;
|
state.selectAll = state.selectedCollectList.length === state.pagination.list.length;
|
||||||
};
|
};
|
||||||
|
|
||||||
// 全选
|
// 全选
|
||||||
const onSelectAll = () => {
|
const onSelectAll = () => {
|
||||||
state.selectAll = !state.selectAll;
|
state.selectAll = !state.selectAll;
|
||||||
if (!state.selectAll) {
|
if (!state.selectAll) {
|
||||||
state.selectedCollectList = [];
|
state.selectedCollectList = [];
|
||||||
} else {
|
} else {
|
||||||
state.pagination.data.forEach((item) => {
|
state.selectedCollectList = state.pagination.list.map((item) => item.spuId);
|
||||||
if (state.selectedCollectList.includes(item.goods_id)) {
|
|
||||||
state.selectedCollectList.splice(state.selectedCollectList.indexOf(item.goods_id), 1);
|
|
||||||
}
|
|
||||||
state.selectedCollectList.push(item.goods_id);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
async function onCancel() {
|
async function onCancel() {
|
||||||
if (state.selectedCollectList) {
|
if (!state.selectedCollectList) {
|
||||||
state.selectedCollectList = state.selectedCollectList.toString();
|
return;
|
||||||
const { code } = await sheep.$api.user.favorite.cancel(state.selectedCollectList);
|
}
|
||||||
if (code === 0) {
|
// 取消收藏
|
||||||
|
for (const spuId of state.selectedCollectList) {
|
||||||
|
await FavoriteApi.deleteFavorite(spuId);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 清空选择 + 重新加载
|
||||||
state.editMode = false;
|
state.editMode = false;
|
||||||
state.selectedCollectList = [];
|
state.selectedCollectList = [];
|
||||||
state.selectAll = false;
|
state.selectAll = false;
|
||||||
state.pagination = pagination;
|
resetPagination(state.pagination);
|
||||||
|
await getData();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 加载更多
|
||||||
|
function loadMore() {
|
||||||
|
if (state.loadStatus === 'noMore') {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
state.pagination.pageNo++;
|
||||||
getData();
|
getData();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
// 加载更多
|
|
||||||
function loadmore() {
|
|
||||||
if (state.loadStatus !== 'noMore') {
|
|
||||||
getData(state.pagination.current_page + 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onReachBottom(() => {
|
onReachBottom(() => {
|
||||||
loadmore();
|
loadMore();
|
||||||
});
|
});
|
||||||
|
|
||||||
onLoad(() => {
|
onLoad(() => {
|
||||||
getData();
|
getData();
|
||||||
});
|
});
|
||||||
|
|
|
@ -26,9 +26,24 @@ export default {
|
||||||
}),
|
}),
|
||||||
signAdd: () =>
|
signAdd: () =>
|
||||||
request({
|
request({
|
||||||
url: 'activity/signin',
|
url: '/app-api/member/sign-in/record/create',
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
}),
|
}),
|
||||||
|
configLise: () =>
|
||||||
|
request({
|
||||||
|
url: '/app-api/member/sign-in/config/list',
|
||||||
|
method: 'GET',
|
||||||
|
}),
|
||||||
|
recordPage: () =>
|
||||||
|
request({
|
||||||
|
url: '/app-api/member/sign-in/record/page',
|
||||||
|
method: 'GET',
|
||||||
|
}),
|
||||||
|
// signAdd: () =>
|
||||||
|
// request({
|
||||||
|
// url: 'activity/signin',
|
||||||
|
// method: 'POST',
|
||||||
|
// }),
|
||||||
replenish: (data) =>
|
replenish: (data) =>
|
||||||
request({
|
request({
|
||||||
url: 'activity/signin/replenish',
|
url: 'activity/signin/replenish',
|
||||||
|
@ -40,4 +55,10 @@ export default {
|
||||||
url: 'activity/activity/' + id,
|
url: 'activity/activity/' + id,
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
}),
|
}),
|
||||||
|
getSummary: () =>
|
||||||
|
request({
|
||||||
|
url: '/app-api/member/sign-in/record/get-summary',
|
||||||
|
method: 'GET',
|
||||||
|
}),
|
||||||
|
|
||||||
};
|
};
|
|
@ -115,13 +115,11 @@ export default {
|
||||||
formData: {
|
formData: {
|
||||||
group,
|
group,
|
||||||
},
|
},
|
||||||
// TODO 芋艿:临时写死
|
|
||||||
header: {
|
header: {
|
||||||
// Accept: 'text/json',
|
// Accept: 'text/json',
|
||||||
// Authorization: token,
|
// Authorization: token,
|
||||||
Accept : '*/*',
|
Accept : '*/*',
|
||||||
'tenant-id' :'1',
|
'tenant-id' :'1',
|
||||||
'terminal': 20,
|
|
||||||
Authorization: 'Bearer test247',
|
Authorization: 'Bearer test247',
|
||||||
},
|
},
|
||||||
success: (uploadFileRes) => {
|
success: (uploadFileRes) => {
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
import request from '@/sheep/request';
|
import request from '@/sheep/request';
|
||||||
|
import request2 from '@/sheep/request2';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
list: (data) =>
|
list: (data) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/trade/cart/list',
|
url: 'trade/cart/list',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
custom: {
|
custom: {
|
||||||
showLoading: false,
|
showLoading: false,
|
||||||
|
@ -12,40 +13,26 @@ export default {
|
||||||
}),
|
}),
|
||||||
append: (data) =>
|
append: (data) =>
|
||||||
request({
|
request({
|
||||||
url: '/app-api/trade/cart/add',
|
url: 'cart',
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
// TODO 芋艿:这里没提示
|
|
||||||
custom: {
|
custom: {
|
||||||
showSuccess: true,
|
showSuccess: true,
|
||||||
successMsg: '已添加到购物车~',
|
successMsg: '已添加到购物车~',
|
||||||
},
|
},
|
||||||
data: {
|
data: {
|
||||||
...data,
|
...data,
|
||||||
// type: 'inc',
|
type: 'inc',
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
// append: (data) =>
|
|
||||||
// request({
|
|
||||||
// url: 'cart',
|
|
||||||
// method: 'POST',
|
|
||||||
// custom: {
|
|
||||||
// showSuccess: true,
|
|
||||||
// successMsg: '已添加到购物车~',
|
|
||||||
// },
|
|
||||||
// data: {
|
|
||||||
// ...data,
|
|
||||||
// type: 'inc',
|
|
||||||
// },
|
|
||||||
// }),
|
|
||||||
// 删除购物车
|
// 删除购物车
|
||||||
delete: (ids) =>
|
delete: (ids) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/trade/cart/delete?ids=' + ids,
|
url: 'trade/cart/delete?ids=' + ids,
|
||||||
method: 'DELETE',
|
method: 'DELETE',
|
||||||
}),
|
}),
|
||||||
update: (data) =>
|
update: (data) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/trade/cart/update-count',
|
url: 'trade/cart/update-count',
|
||||||
method: 'PUT',
|
method: 'PUT',
|
||||||
data: {
|
data: {
|
||||||
...data,
|
...data,
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
|
import request2 from '@/sheep/request2';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
list: (params) =>
|
list: (params) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/product/category/list',
|
url: 'product/category/list',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
}),
|
}),
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import request from '@/sheep/request';
|
import request from '@/sheep/request';
|
||||||
|
import request2 from '@/sheep/request2';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
// 我的拼团
|
// 我的拼团
|
||||||
|
@ -12,8 +13,8 @@ export default {
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
userCoupon: (params) =>
|
userCoupon: (params) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/promotion/coupon/page',
|
url: 'promotion/coupon/page',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
}),
|
}),
|
||||||
|
@ -33,20 +34,9 @@ export default {
|
||||||
}),
|
}),
|
||||||
get: (id) =>
|
get: (id) =>
|
||||||
request({
|
request({
|
||||||
url: '/app-api/promotion/coupon/take',
|
url: 'coupon/get/' + id,
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
data: {
|
|
||||||
templateId: id
|
|
||||||
},
|
|
||||||
params: {
|
|
||||||
templateId: id
|
|
||||||
},
|
|
||||||
}),
|
}),
|
||||||
// get: (id) =>
|
|
||||||
// request({
|
|
||||||
// url: 'coupon/get/' + id,
|
|
||||||
// method: 'POST',
|
|
||||||
// }),
|
|
||||||
listByGoods: (id) =>
|
listByGoods: (id) =>
|
||||||
request({
|
request({
|
||||||
url: 'coupon/listByGoods/' + id,
|
url: 'coupon/listByGoods/' + id,
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
import request from '@/sheep/request';
|
import request from '@/sheep/request';
|
||||||
|
import request2 from '@/sheep/request2';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
area: () =>
|
area: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/system/area/tree',
|
url: 'system/area/tree',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
}),
|
}),
|
||||||
// area: () =>
|
// area: () =>
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
import request from '@/sheep/request';
|
import request from '@/sheep/request';
|
||||||
|
import request2 from '@/sheep/request2';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
// 商品详情
|
// 商品详情
|
||||||
detail: (id, params = {}) =>
|
detail: (id, params = {}) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/product/spu/get-detail?id=' + id,
|
url: 'product/spu/get-detail?id=' + id,
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
custom: {
|
custom: {
|
||||||
|
@ -15,8 +16,8 @@ export default {
|
||||||
|
|
||||||
// 商品列表
|
// 商品列表
|
||||||
list: (params) =>
|
list: (params) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/product/spu/page',
|
url: 'product/spu/page',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
custom: {
|
custom: {
|
||||||
|
@ -36,10 +37,11 @@ export default {
|
||||||
showError: false,
|
showError: false,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
|
||||||
// 商品评价列表
|
// 商品评价列表
|
||||||
comment: (id, params = {}) =>
|
comment: (id, params = {}) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/product/comment/list?spuId=' + id,
|
url: 'product/comment/list?spuId=' + id,
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
custom: {
|
custom: {
|
||||||
|
@ -75,10 +77,4 @@ export default {
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
}),
|
}),
|
||||||
// 检查是否收藏商品
|
|
||||||
exits: (id) =>
|
|
||||||
request({
|
|
||||||
url: '/app-api/product/favorite/exits?spuId=' + id,
|
|
||||||
method: 'GET',
|
|
||||||
}),
|
|
||||||
};
|
};
|
|
@ -1,14 +1,14 @@
|
||||||
import request from '@/sheep/request';
|
import request2 from '@/sheep/request2';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
decorate: () =>
|
decorate: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/promotion/decorate/list?page=1',
|
url: 'promotion/decorate/list?page=1',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
}),
|
}),
|
||||||
spids: () =>
|
spids: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/product/spu/page?recommendType=best&pageNo=1&pageSize=10',
|
url: 'product/spu/page?recommendType=best&pageNo=1&pageSize=10',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
}),
|
}),
|
||||||
};
|
};
|
|
@ -1,10 +1,11 @@
|
||||||
import request from '@/sheep/request';
|
import request from '@/sheep/request';
|
||||||
|
import request2 from '@/sheep/request2';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
// 订单详情
|
// 订单详情
|
||||||
detail: (id, params) =>
|
detail: (id, params) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/trade/order/get-detail?id=' + id,
|
url: 'trade/order/get-detail?id=' + id,
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
}),
|
}),
|
||||||
|
@ -37,7 +38,16 @@ export default {
|
||||||
showLoading: false,
|
showLoading: false,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
// 订单列表
|
||||||
|
list: (params) =>
|
||||||
|
request2({
|
||||||
|
url: 'trade/order/page',
|
||||||
|
method: 'GET',
|
||||||
|
params,
|
||||||
|
custom: {
|
||||||
|
showLoading: false,
|
||||||
|
},
|
||||||
|
}),
|
||||||
// list: (params) =>
|
// list: (params) =>
|
||||||
// request({
|
// request({
|
||||||
// url: 'order/order',
|
// url: 'order/order',
|
||||||
|
@ -55,27 +65,27 @@ export default {
|
||||||
// 解决 SpringMVC 接受 List<Item> 参数的问题
|
// 解决 SpringMVC 接受 List<Item> 参数的问题
|
||||||
delete data2.items
|
delete data2.items
|
||||||
for (let i = 0; i < data.items.length; i++) {
|
for (let i = 0; i < data.items.length; i++) {
|
||||||
// 此处转码问题,待解决方案
|
// data2['items[' + i + '' + '].skuId'] = data.items[i].skuId + '';
|
||||||
data2[encodeURIComponent('items[' + i + '' + '].skuId')] = data.items[i].skuId + '';
|
// data2['items[' + i + '' + '].count'] = data.items[i].count + '';
|
||||||
data2[encodeURIComponent('items[' + i + '' + '].count')] = data.items[i].count + '';
|
// data2['items[' + i + '' + '].cartId'] = data.items[i].cartId + '';
|
||||||
data2[encodeURIComponent('items[' + i + '' + '].cartId')] = data.items[i].cartId + '';
|
data2['items' + `%5B${i}%5D` + '.skuId'] = data.items[i].skuId + '';
|
||||||
|
data2['items' + `%5B${i}%5D` + '.count'] = data.items[i].count + '';
|
||||||
// data2['items' + `[${i}]` + '.skuId'] = data.items[i].skuId + '';
|
data2['items' + `%5B${i}%5D` + '.cartId'] = data.items[i].cartId + '';
|
||||||
// data2['items' + `[${i}]` + '.count'] = data.items[i].count + '';
|
|
||||||
// data2['items' + `[${i}]` + '.cartId'] = data.items[i].cartId + '';
|
|
||||||
|
|
||||||
// data2['items' + `%5B${i}%5D` + '.skuId'] = data.items[i].skuId + '';
|
|
||||||
// data2['items' + `%5B${i}%5D` + '.count'] = data.items[i].count + '';
|
|
||||||
// data2['items' + `%5B${i}%5D` + '.cartId'] = data.items[i].cartId + '';
|
|
||||||
}
|
}
|
||||||
console.log(data2, '手动转码的参数')
|
console.log(data2, '对比数据')
|
||||||
return request({
|
return request2({
|
||||||
url: '/app-api/trade/order/settlement',
|
url: 'trade/order/settlement',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
// data: data2,
|
// data,
|
||||||
params: data2
|
params: data2
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
// calc: (data) =>
|
||||||
|
// request({
|
||||||
|
// url: 'order/order/calc',
|
||||||
|
// method: 'POST',
|
||||||
|
// data,
|
||||||
|
// }),
|
||||||
// 创建订单
|
// 创建订单
|
||||||
create: (data) =>
|
create: (data) =>
|
||||||
request({
|
request({
|
||||||
|
@ -98,8 +108,8 @@ export default {
|
||||||
}),
|
}),
|
||||||
// 评价订单
|
// 评价订单
|
||||||
comment: (data) =>
|
comment: (data) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/trade/order/item/create-comment',
|
url: 'trade/order/item/create-comment',
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
data,
|
data,
|
||||||
}),
|
}),
|
||||||
|
@ -129,15 +139,31 @@ export default {
|
||||||
}),
|
}),
|
||||||
// 售后
|
// 售后
|
||||||
aftersale: {
|
aftersale: {
|
||||||
list: (params) =>
|
// 申请售后
|
||||||
|
apply: (data) =>
|
||||||
request({
|
request({
|
||||||
url: '/app-api/trade/after-sale/page',
|
url: 'order/aftersale',
|
||||||
|
method: 'POST',
|
||||||
|
data,
|
||||||
|
}),
|
||||||
|
list: (params) =>
|
||||||
|
request2({
|
||||||
|
url: 'trade/after-sale/page',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
custom: {
|
custom: {
|
||||||
showLoading: false,
|
showLoading: false,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
// list: (params) =>
|
||||||
|
// request({
|
||||||
|
// url: 'order/aftersale',
|
||||||
|
// method: 'GET',
|
||||||
|
// params,
|
||||||
|
// custom: {
|
||||||
|
// showLoading: false,
|
||||||
|
// },
|
||||||
|
// }),
|
||||||
//取消售后
|
//取消售后
|
||||||
cancel: (id) =>
|
cancel: (id) =>
|
||||||
request({
|
request({
|
||||||
|
@ -150,10 +176,10 @@ export default {
|
||||||
url: 'order/aftersale/' + id,
|
url: 'order/aftersale/' + id,
|
||||||
method: 'DELETE',
|
method: 'DELETE',
|
||||||
}),
|
}),
|
||||||
// 售后详情 DONE
|
// 售后详情
|
||||||
detail: (id) =>
|
detail: (id) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/trade/after-sale/get?id=' + id,
|
url: 'trade/after-sale/get?id=' + id,
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
|
|
|
@ -1,14 +0,0 @@
|
||||||
import request from '@/sheep/request';
|
|
||||||
|
|
||||||
const PayChannelApi = {
|
|
||||||
// 获得指定应用的开启的支付渠道编码列表
|
|
||||||
getEnableChannelCodeList: (appId) => {
|
|
||||||
return request({
|
|
||||||
url: '/app-api/pay/channel/get-enable-code-list',
|
|
||||||
method: 'GET',
|
|
||||||
params: { appId }
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default PayChannelApi;
|
|
|
@ -1,22 +0,0 @@
|
||||||
import request from '@/sheep/request';
|
|
||||||
|
|
||||||
const PayOrderApi = {
|
|
||||||
// 获得支付订单
|
|
||||||
getOrder: (id) => {
|
|
||||||
return request({
|
|
||||||
url: '/app-api/pay/order/get',
|
|
||||||
method: 'GET',
|
|
||||||
params: { id }
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// 提交支付订单
|
|
||||||
submitOrder: (data) => {
|
|
||||||
return request({
|
|
||||||
url: '/app-api/pay/order/submit',
|
|
||||||
method: 'POST',
|
|
||||||
data
|
|
||||||
});
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export default PayOrderApi;
|
|
|
@ -1,7 +1,6 @@
|
||||||
import request from '@/sheep/request';
|
import request from '@/sheep/request';
|
||||||
|
|
||||||
const CommentApi = {
|
const CommentApi = {
|
||||||
|
|
||||||
// 获得商品评价分页
|
// 获得商品评价分页
|
||||||
getCommentPage: (spuId, pageNo, pageSize, type) => {
|
getCommentPage: (spuId, pageNo, pageSize, type) => {
|
||||||
return request({
|
return request({
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
import request from '@/sheep/request';
|
||||||
|
|
||||||
|
const FavoriteApi = {
|
||||||
|
// 获得商品收藏分页
|
||||||
|
getFavoritePage: (data) => {
|
||||||
|
return request({
|
||||||
|
url: '/app-api/product/favorite/page',
|
||||||
|
method: 'GET',
|
||||||
|
params: data
|
||||||
|
});
|
||||||
|
},
|
||||||
|
// 检查是否收藏过商品
|
||||||
|
isFavoriteExists: (spuId) => {
|
||||||
|
return request({
|
||||||
|
url: '/app-api/product/favorite/exits',
|
||||||
|
method: 'GET',
|
||||||
|
params: {
|
||||||
|
spuId
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
// 添加商品收藏
|
||||||
|
createFavorite: (spuId) => {
|
||||||
|
return request({
|
||||||
|
url: '/app-api/product/favorite/create',
|
||||||
|
method: 'POST',
|
||||||
|
data: {
|
||||||
|
spuId
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
// 取消商品收藏
|
||||||
|
deleteFavorite: (spuId) => {
|
||||||
|
return request({
|
||||||
|
url: '/app-api/product/favorite/delete',
|
||||||
|
method: 'DELETE',
|
||||||
|
data: {
|
||||||
|
spuId
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export default FavoriteApi;
|
|
@ -1,9 +1,9 @@
|
||||||
import request from '@/sheep/request';
|
import request2 from '@/sheep/request2';
|
||||||
|
|
||||||
const ActivityApi = {
|
const ActivityApi = {
|
||||||
// 获得单个商品,近期参与的每个活动
|
// 获得单个商品,近期参与的每个活动
|
||||||
getActivityListBySpuId: (spuId) => {
|
getActivityListBySpuId: (spuId) => {
|
||||||
return request({
|
return request2({
|
||||||
url: '/app-api/promotion/activity/list-by-spu-id',
|
url: '/app-api/promotion/activity/list-by-spu-id',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params: {
|
params: {
|
||||||
|
|
|
@ -1,22 +1,20 @@
|
||||||
import request from "@/sheep/request";
|
import request2 from "@/sheep/request2";
|
||||||
|
|
||||||
// 拼团 API
|
// 拼团 API
|
||||||
const CombinationApi = {
|
const CombinationApi = {
|
||||||
// 获得拼团活动列表
|
// 获得拼团活动列表
|
||||||
getCombinationActivityList: (count) => {
|
getCombinationActivityList: (count) => {
|
||||||
return request({
|
return request2({
|
||||||
url: "/app-api/promotion/combination-activity/list",
|
url: "promotion/combination-activity/list",
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params: {
|
params: {count}
|
||||||
count
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
// 获得拼团活动分页
|
// 获得拼团活动分页
|
||||||
getCombinationActivityPage: (params) => {
|
getCombinationActivityPage: (params) => {
|
||||||
return request({
|
return request2({
|
||||||
url: "/app-api/promotion/combination-activity/page",
|
url: "promotion/combination-activity/page",
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params
|
params
|
||||||
});
|
});
|
||||||
|
@ -24,8 +22,8 @@ const CombinationApi = {
|
||||||
|
|
||||||
// 获得拼团活动明细
|
// 获得拼团活动明细
|
||||||
getCombinationActivity: (id) => {
|
getCombinationActivity: (id) => {
|
||||||
return request({
|
return request2({
|
||||||
url: "/app-api/promotion/combination-activity/get-detail",
|
url: "promotion/combination-activity/get-detail",
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params: {
|
params: {
|
||||||
id
|
id
|
||||||
|
@ -35,8 +33,8 @@ const CombinationApi = {
|
||||||
|
|
||||||
// 获得最近 n 条拼团记录(团长发起的)
|
// 获得最近 n 条拼团记录(团长发起的)
|
||||||
getHeadCombinationRecordList: (activityId, status, count) => {
|
getHeadCombinationRecordList: (activityId, status, count) => {
|
||||||
return request({
|
return request2({
|
||||||
url: "/app-api/promotion/combination-record/get-head-list",
|
url: "promotion/combination-record/get-head-list",
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params: {
|
params: {
|
||||||
activityId,
|
activityId,
|
||||||
|
@ -48,8 +46,8 @@ const CombinationApi = {
|
||||||
|
|
||||||
// 获得拼团记录明细
|
// 获得拼团记录明细
|
||||||
getCombinationRecordDetail: (id) => {
|
getCombinationRecordDetail: (id) => {
|
||||||
return request({
|
return request2({
|
||||||
url: "/app-api/promotion/combination-record/get-detail",
|
url: "promotion/combination-record/get-detail",
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params: {
|
params: {
|
||||||
id
|
id
|
||||||
|
@ -59,8 +57,8 @@ const CombinationApi = {
|
||||||
|
|
||||||
// 获得拼团记录的概要信息
|
// 获得拼团记录的概要信息
|
||||||
getCombinationRecordSummary: () => {
|
getCombinationRecordSummary: () => {
|
||||||
return request({
|
return request2({
|
||||||
url: "/app-api/promotion/combination-record/get-summary",
|
url: "promotion/combination-record/get-summary",
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,17 +17,4 @@ export default {
|
||||||
params: { spuId, productScope, count },
|
params: { spuId, productScope, count },
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
// 获得匹配指定商品的优惠劵列表
|
|
||||||
getMatchCouponList: (price, spuIds, skuIds, categoryIds) => {
|
|
||||||
return request({
|
|
||||||
url: '/app-api/promotion/coupon/match-list',
|
|
||||||
method: 'GET',
|
|
||||||
params: {
|
|
||||||
price,
|
|
||||||
spuIds: spuIds.join(','),
|
|
||||||
skuIds: skuIds.join(','),
|
|
||||||
categoryIds: categoryIds.join(','),
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,28 +1,19 @@
|
||||||
import request from "@/sheep/request";
|
import request2 from "@/sheep/request2";
|
||||||
|
|
||||||
const SeckillApi = {
|
const SeckillApi = {
|
||||||
// 获得秒杀时间段列表
|
// 获得秒杀时间段列表
|
||||||
getSeckillConfigList: () => {
|
getSeckillConfigList: () => {
|
||||||
return request({
|
return request2({ url: 'promotion/seckill-config/list', method: 'GET' });
|
||||||
url: '/app-api/promotion/seckill-config/list',
|
|
||||||
method: 'GET'
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// 获得当前秒杀活动
|
// 获得当前秒杀活动
|
||||||
getNowSeckillActivity: () => {
|
getNowSeckillActivity: () => {
|
||||||
return request({
|
return request2({ url: 'promotion/seckill-activity/get-now', method: 'GET' });
|
||||||
url: '/app-api/promotion/seckill-activity/get-now',
|
|
||||||
method: 'GET'
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// 获得秒杀活动分页
|
// 获得秒杀活动分页
|
||||||
getSeckillActivityPage: () => {
|
getSeckillActivityPage: () => {
|
||||||
return request({
|
return request2({ url: 'promotion/seckill-activity/page', method: 'GET' });
|
||||||
url: '/app-api/promotion/seckill-activity/page',
|
|
||||||
method: 'GET'
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -31,12 +22,10 @@ const SeckillApi = {
|
||||||
* @return {*}
|
* @return {*}
|
||||||
*/
|
*/
|
||||||
getSeckillActivity: (id) => {
|
getSeckillActivity: (id) => {
|
||||||
return request({
|
return request2({
|
||||||
url: '/app-api/promotion/seckill-activity/get-detail',
|
url: 'promotion/seckill-activity/get-detail',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params: {
|
params: { id }
|
||||||
id
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,9 +28,18 @@ export default {
|
||||||
showLoading: false,
|
showLoading: false,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
rechargeRules2: () =>
|
||||||
|
request({
|
||||||
|
url: '/app-api/pay/wallet-recharge-package/list',
|
||||||
|
method: 'GET',
|
||||||
|
custom: {
|
||||||
|
showError: false,
|
||||||
|
showLoading: false,
|
||||||
|
},
|
||||||
|
}),
|
||||||
recharge: (data) =>
|
recharge: (data) =>
|
||||||
request({
|
request({
|
||||||
url: 'trade/order/recharge',
|
url: '/app-api/pay/wallet-recharge/create',
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
data,
|
data,
|
||||||
}),
|
}),
|
||||||
|
|
|
@ -29,6 +29,16 @@ const AfterSaleApi = {
|
||||||
id,
|
id,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
},
|
||||||
|
// 获得售后日志列表
|
||||||
|
getAfterSaleLogList: (afterSaleId) => {
|
||||||
|
return request2({
|
||||||
|
url: `/app-api/trade/after-sale-log/list`,
|
||||||
|
method: 'GET',
|
||||||
|
params: {
|
||||||
|
afterSaleId,
|
||||||
|
},
|
||||||
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,47 +0,0 @@
|
||||||
import request2 from '@/sheep/request2';
|
|
||||||
|
|
||||||
const CartApi = {
|
|
||||||
addCart: (data) => {
|
|
||||||
return request2({
|
|
||||||
url: '/app-api/trade/cart/add',
|
|
||||||
method: 'POST',
|
|
||||||
data: data,
|
|
||||||
// TODO 芋艿:这里没提示
|
|
||||||
custom: {
|
|
||||||
showSuccess: true,
|
|
||||||
successMsg: '已添加到购物车~',
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
updateCartCount: (data) => {
|
|
||||||
return request2({
|
|
||||||
url: '/app-api/trade/cart/update-count',
|
|
||||||
method: 'PUT',
|
|
||||||
data: data
|
|
||||||
});
|
|
||||||
},
|
|
||||||
updateCartSelected: (data) => {
|
|
||||||
return request2({
|
|
||||||
url: '/app-api/trade/cart/update-selected',
|
|
||||||
method: 'PUT',
|
|
||||||
data: data
|
|
||||||
});
|
|
||||||
},
|
|
||||||
deleteCart: (ids) => {
|
|
||||||
return request2({
|
|
||||||
url: '/app-api/trade/cart/delete',
|
|
||||||
method: 'DELETE',
|
|
||||||
params: {
|
|
||||||
ids
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
getCartList: () => {
|
|
||||||
return request2({
|
|
||||||
url: '/app-api/trade/cart/list',
|
|
||||||
method: 'GET',
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default CartApi;
|
|
|
@ -1,95 +0,0 @@
|
||||||
import request2 from '@/sheep/request2';
|
|
||||||
import request from '@/sheep/request';
|
|
||||||
|
|
||||||
const OrderApi = {
|
|
||||||
// 计算订单信息
|
|
||||||
settlementOrder: (data) => {
|
|
||||||
const data2 = {
|
|
||||||
...data,
|
|
||||||
};
|
|
||||||
// 移除多余字段
|
|
||||||
if (!(data.couponId > 0)) {
|
|
||||||
delete data2.couponId;
|
|
||||||
}
|
|
||||||
if (!(data.addressId > 0)) {
|
|
||||||
delete data2.addressId;
|
|
||||||
}
|
|
||||||
// 解决 SpringMVC 接受 List<Item> 参数的问题
|
|
||||||
delete data2.items;
|
|
||||||
for (let i = 0; i < data.items.length; i++) {
|
|
||||||
data2[encodeURIComponent('items[' + i + '' + '].skuId')] = data.items[i].skuId + '';
|
|
||||||
data2[encodeURIComponent('items[' + i + '' + '].count')] = data.items[i].count + '';
|
|
||||||
if (data.items[i].cartId) {
|
|
||||||
data2[encodeURIComponent('items[' + i + '' + '].cartId')] = data.items[i].cartId + '';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
const queryString = Object.keys(data2)
|
|
||||||
.map((key) => key + '=' + data2[key])
|
|
||||||
.join('&');
|
|
||||||
return request2({
|
|
||||||
url: `trade/order/settlement?${queryString}`,
|
|
||||||
method: 'GET',
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// 创建订单
|
|
||||||
createOrder: (data) => {
|
|
||||||
return request2({
|
|
||||||
url: `trade/order/create`,
|
|
||||||
method: 'POST',
|
|
||||||
data,
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// 获得订单
|
|
||||||
getOrder: (id) => {
|
|
||||||
return request2({
|
|
||||||
url: `trade/order/get-detail`,
|
|
||||||
method: 'GET',
|
|
||||||
params: {
|
|
||||||
id,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// 订单列表
|
|
||||||
getOrderPage: (params) => {
|
|
||||||
return request({
|
|
||||||
url: '/app-api/trade/order/page',
|
|
||||||
method: 'GET',
|
|
||||||
params,
|
|
||||||
custom: {
|
|
||||||
showLoading: false,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// 确认收货
|
|
||||||
receiveOrder: (id) => {
|
|
||||||
return request2({
|
|
||||||
url: `/app-api/trade/order/receive`,
|
|
||||||
method: 'PUT',
|
|
||||||
params: {
|
|
||||||
id,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// 取消订单
|
|
||||||
cancelOrder: (id) => {
|
|
||||||
return request2({
|
|
||||||
url: `/app-api/trade/order/cancel`,
|
|
||||||
method: 'DELETE',
|
|
||||||
params: {
|
|
||||||
id,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
},
|
|
||||||
// 删除订单
|
|
||||||
deleteOrder: (id) => {
|
|
||||||
return request2({
|
|
||||||
url: `/app-api/trade/order/delete`,
|
|
||||||
method: 'DELETE',
|
|
||||||
params: {
|
|
||||||
id,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default OrderApi;
|
|
|
@ -1,10 +1,11 @@
|
||||||
import request from '@/sheep/request';
|
import request from '@/sheep/request';
|
||||||
|
import request2 from '@/sheep/request2';
|
||||||
import $platform from '@/sheep/platform';
|
import $platform from '@/sheep/platform';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
getUnused: () =>
|
getUnused: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/promotion/coupon/get-unused-count',
|
url: 'promotion/coupon/get-unused-count',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
custom: {
|
custom: {
|
||||||
showLoading: false,
|
showLoading: false,
|
||||||
|
@ -12,8 +13,8 @@ export default {
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
profile: () =>
|
profile: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/user/get',
|
url: 'member/user/get',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
custom: {
|
custom: {
|
||||||
showLoading: false,
|
showLoading: false,
|
||||||
|
@ -21,7 +22,7 @@ export default {
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
balance: () =>
|
balance: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/pay/wallet/get',
|
url: '/app-api/pay/wallet/get',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
custom: {
|
custom: {
|
||||||
|
@ -29,9 +30,28 @@ export default {
|
||||||
auth: true,
|
auth: true,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
// profile: () =>
|
||||||
|
// request({
|
||||||
|
// url: '/user/api/user/profile',
|
||||||
|
// method: 'GET',
|
||||||
|
// custom: {
|
||||||
|
// showLoading: false,
|
||||||
|
// auth: true,
|
||||||
|
// },
|
||||||
|
// }),
|
||||||
|
// update: (data) =>
|
||||||
|
// request({
|
||||||
|
// url: '/user/api/user/update',
|
||||||
|
// method: 'POST',
|
||||||
|
// custom: {
|
||||||
|
// showSuccess: true,
|
||||||
|
// auth: true,
|
||||||
|
// },
|
||||||
|
// data,
|
||||||
|
// }),
|
||||||
update: (data) =>
|
update: (data) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/user/update',
|
url: 'member/user/update',
|
||||||
method: 'PUT',
|
method: 'PUT',
|
||||||
custom: {
|
custom: {
|
||||||
showSuccess: true,
|
showSuccess: true,
|
||||||
|
@ -176,48 +196,90 @@ export default {
|
||||||
}),
|
}),
|
||||||
|
|
||||||
address: {
|
address: {
|
||||||
|
// default: () =>
|
||||||
|
// request({
|
||||||
|
// url: 'user/address/default',
|
||||||
|
// method: 'GET',
|
||||||
|
// custom: {
|
||||||
|
// showError: false,
|
||||||
|
// },
|
||||||
|
// }),
|
||||||
default: () =>
|
default: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/address/get-default',
|
url: 'member/address/get-default',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
custom: {
|
custom: {
|
||||||
showError: false,
|
showError: false,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
list: () =>
|
list: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/address/list',
|
url: 'member/address/list',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
custom: {},
|
custom: {},
|
||||||
}),
|
}),
|
||||||
|
// list: () =>
|
||||||
|
// request({
|
||||||
|
// url: 'user/address',
|
||||||
|
// method: 'GET',
|
||||||
|
// custom: {},
|
||||||
|
// }),
|
||||||
create: (data) =>
|
create: (data) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/address/create',
|
url: 'member/address/create',
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
data,
|
data,
|
||||||
custom: {
|
custom: {
|
||||||
showSuccess: true,
|
showSuccess: true,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
// create: (data) =>
|
||||||
|
// request({
|
||||||
|
// url: 'user/address',
|
||||||
|
// method: 'POST',
|
||||||
|
// data,
|
||||||
|
// custom: {
|
||||||
|
// showSuccess: true,
|
||||||
|
// },
|
||||||
|
// }),
|
||||||
update: (data) =>
|
update: (data) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/address/update',
|
url: 'member/address/update',
|
||||||
method: 'PUT',
|
method: 'PUT',
|
||||||
data,
|
data,
|
||||||
custom: {
|
custom: {
|
||||||
showSuccess: true,
|
showSuccess: true,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
// update: (id, data) =>
|
||||||
|
// request({
|
||||||
|
// url: 'user/address/' + id,
|
||||||
|
// method: 'PUT',
|
||||||
|
// data,
|
||||||
|
// custom: {
|
||||||
|
// showSuccess: true,
|
||||||
|
// },
|
||||||
|
// }),
|
||||||
detail: (id) =>
|
detail: (id) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/address/get?id=' + id,
|
url: 'member/address/get?id=' + id,
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
}),
|
}),
|
||||||
|
// detail: (id) =>
|
||||||
|
// request({
|
||||||
|
// url: 'user/address/' + id,
|
||||||
|
// method: 'GET',
|
||||||
|
// }),
|
||||||
delete: (id) =>
|
delete: (id) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/address/delete?id=' + id,
|
url: 'member/address/delete?id=' + id,
|
||||||
method: 'DELETE',
|
method: 'DELETE',
|
||||||
}),
|
}),
|
||||||
|
// delete: (id) =>
|
||||||
|
// request({
|
||||||
|
// url: 'user/address/' + id,
|
||||||
|
// method: 'DELETE',
|
||||||
|
// }),
|
||||||
},
|
},
|
||||||
invoice: {
|
invoice: {
|
||||||
list: () =>
|
list: () =>
|
||||||
|
@ -257,29 +319,17 @@ export default {
|
||||||
},
|
},
|
||||||
favorite: {
|
favorite: {
|
||||||
list: (params) =>
|
list: (params) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/product/favorite/page',
|
url: 'product/favorite/page',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
}),
|
}),
|
||||||
do: (id) =>
|
do: (id) =>
|
||||||
request({
|
request({
|
||||||
url: '/app-api/product/favorite/create',
|
url: 'user/goodsLog/favorite',
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
data: {
|
data: {
|
||||||
spuId: id,
|
goods_id: id,
|
||||||
},
|
|
||||||
custom: {
|
|
||||||
showSuccess: true,
|
|
||||||
auth: true,
|
|
||||||
},
|
|
||||||
}),
|
|
||||||
dos: (id) =>
|
|
||||||
request({
|
|
||||||
url: '/app-api/product/favorite/delete',
|
|
||||||
method: 'DELETE',
|
|
||||||
data: {
|
|
||||||
spuId: id,
|
|
||||||
},
|
},
|
||||||
custom: {
|
custom: {
|
||||||
showSuccess: true,
|
showSuccess: true,
|
||||||
|
@ -288,8 +338,8 @@ export default {
|
||||||
}),
|
}),
|
||||||
// 取消收藏
|
// 取消收藏
|
||||||
cancel: (id) =>
|
cancel: (id) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/product/favorite/delete-list',
|
url: 'product/favorite/delete-list',
|
||||||
method: 'DELETE',
|
method: 'DELETE',
|
||||||
data: {
|
data: {
|
||||||
spuIds: id.split(',').map(item => item * 1),
|
spuIds: id.split(',').map(item => item * 1),
|
||||||
|
@ -300,6 +350,18 @@ export default {
|
||||||
auth: true,
|
auth: true,
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
// cancel: (id) =>
|
||||||
|
// request({
|
||||||
|
// url: 'user/goodsLog/favorite',
|
||||||
|
// method: 'POST',
|
||||||
|
// data: {
|
||||||
|
// goods_ids: id,
|
||||||
|
// },
|
||||||
|
// custom: {
|
||||||
|
// showSuccess: true,
|
||||||
|
// auth: true,
|
||||||
|
// },
|
||||||
|
// }),
|
||||||
},
|
},
|
||||||
view: {
|
view: {
|
||||||
list: (params) =>
|
list: (params) =>
|
||||||
|
@ -321,21 +383,28 @@ export default {
|
||||||
},
|
},
|
||||||
wallet: {
|
wallet: {
|
||||||
log: (params) =>
|
log: (params) =>
|
||||||
request({
|
request2({
|
||||||
// url: 'member/point/record/page',
|
// url: 'member/point/record/page',
|
||||||
url: '/app-api/pay/wallet-transaction/page',
|
url: 'pay/wallet-transaction/page',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
custom: {},
|
custom: {},
|
||||||
}),
|
}),
|
||||||
log2: (params) =>
|
log2: (params) =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/member/point/record/page',
|
url: 'member/point/record/page',
|
||||||
// url: 'pay/wallet-transaction/page',
|
// url: 'pay/wallet-transaction/page',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
params,
|
params,
|
||||||
custom: {},
|
custom: {},
|
||||||
}),
|
}),
|
||||||
|
// log: (params) =>
|
||||||
|
// request({
|
||||||
|
// url: '/user/api/walletLog',
|
||||||
|
// method: 'GET',
|
||||||
|
// params,
|
||||||
|
// custom: {},
|
||||||
|
// }),
|
||||||
},
|
},
|
||||||
account: {
|
account: {
|
||||||
info: (params) =>
|
info: (params) =>
|
||||||
|
@ -360,9 +429,18 @@ export default {
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
//数量接口
|
//数量接口
|
||||||
|
// data: () =>
|
||||||
|
// request({
|
||||||
|
// url: 'user/user/data',
|
||||||
|
// method: 'GET',
|
||||||
|
// custom: {
|
||||||
|
// showLoading: false,
|
||||||
|
// auth: true,
|
||||||
|
// },
|
||||||
|
// }),
|
||||||
data: () =>
|
data: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/trade/order/get-count',
|
url: 'trade/order/get-count',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
custom: {
|
custom: {
|
||||||
showLoading: false,
|
showLoading: false,
|
||||||
|
@ -370,8 +448,8 @@ export default {
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
data2: () =>
|
data2: () =>
|
||||||
request({
|
request2({
|
||||||
url: '/app-api/trade/after-sale/get-applying-count',
|
url: 'trade/after-sale/get-applying-count',
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
custom: {
|
custom: {
|
||||||
showLoading: false,
|
showLoading: false,
|
||||||
|
|
|
@ -1,17 +1,32 @@
|
||||||
<template>
|
<template>
|
||||||
<su-popup :show="show" type="bottom" round="20" @close="emits('close')" showClose backgroundColor="#f2f2f2">
|
<su-popup
|
||||||
|
:show="show"
|
||||||
|
type="bottom"
|
||||||
|
round="20"
|
||||||
|
@close="emits('close')"
|
||||||
|
showClose
|
||||||
|
backgroundColor="#f2f2f2"
|
||||||
|
>
|
||||||
<view class="model-box">
|
<view class="model-box">
|
||||||
<view class="title ss-m-t-16 ss-m-l-20 ss-flex">优惠券</view>
|
<view class="title ss-m-t-16 ss-m-l-20 ss-flex">优惠券</view>
|
||||||
<scroll-view class="model-content" scroll-y :scroll-with-animation="false" :enable-back-to-top="true">
|
<scroll-view
|
||||||
|
class="model-content"
|
||||||
|
scroll-y
|
||||||
|
:scroll-with-animation="false"
|
||||||
|
:enable-back-to-top="true"
|
||||||
|
>
|
||||||
<view class="subtitle ss-m-l-20">可使用优惠券</view>
|
<view class="subtitle ss-m-l-20">可使用优惠券</view>
|
||||||
<view v-for="item in state.couponInfo" :key="item.id">
|
<view v-for="item in state.couponInfo" :key="item.id">
|
||||||
<s-coupon-list :data="item">
|
<s-coupon-list :data="item">
|
||||||
<template #default>
|
<template #default>
|
||||||
<button class="ss-reset-button card-btn ss-flex ss-row-center ss-col-center" :class="
|
<button
|
||||||
|
class="ss-reset-button card-btn ss-flex ss-row-center ss-col-center"
|
||||||
|
:class="
|
||||||
item.get_status != 'can_get' && item.get_status != 'can_use' ? 'boder-btn' : ''
|
item.get_status != 'can_get' && item.get_status != 'can_use' ? 'boder-btn' : ''
|
||||||
" @click.stop="getBuy(item.id)">
|
"
|
||||||
<!-- 此处对接领取优惠券先将限制解除 -->
|
@click.stop="getBuy(item.id)"
|
||||||
<!-- :disabled="item.get_status != 'can_get' && item.get_status != 'can_use'" -->
|
:disabled="item.get_status != 'can_get' && item.get_status != 'can_use'"
|
||||||
|
>
|
||||||
{{ item.get_status_text }}
|
{{ item.get_status_text }}
|
||||||
</button>
|
</button>
|
||||||
</template>
|
</template>
|
||||||
|
@ -22,10 +37,7 @@
|
||||||
</su-popup>
|
</su-popup>
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
import {
|
import { computed, reactive } from 'vue';
|
||||||
computed,
|
|
||||||
reactive
|
|
||||||
} from 'vue';
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
modelValue: {
|
modelValue: {
|
||||||
type: Object,
|
type: Object,
|
||||||
|
@ -43,7 +55,6 @@
|
||||||
couponId: '',
|
couponId: '',
|
||||||
});
|
});
|
||||||
const getBuy = (id) => {
|
const getBuy = (id) => {
|
||||||
console.log('应该是详情页领取优惠券')
|
|
||||||
emits('get', id);
|
emits('get', id);
|
||||||
};
|
};
|
||||||
//立即领取
|
//立即领取
|
||||||
|
@ -51,31 +62,26 @@
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.model-box {
|
.model-box {
|
||||||
height: 60vh;
|
height: 60vh;
|
||||||
|
|
||||||
.title {
|
.title {
|
||||||
font-size: 36rpx;
|
font-size: 36rpx;
|
||||||
height: 80rpx;
|
height: 80rpx;
|
||||||
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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.model-content {
|
.model-content {
|
||||||
height: 54vh;
|
height: 54vh;
|
||||||
}
|
}
|
||||||
|
|
||||||
.modal-footer {
|
.modal-footer {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 120rpx;
|
height: 120rpx;
|
||||||
background: #fff;
|
background: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
.confirm-btn {
|
.confirm-btn {
|
||||||
width: 710rpx;
|
width: 710rpx;
|
||||||
margin-left: 20rpx;
|
margin-left: 20rpx;
|
||||||
|
@ -84,7 +90,6 @@
|
||||||
border-radius: 40rpx;
|
border-radius: 40rpx;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 优惠券按钮
|
// 优惠券按钮
|
||||||
.card-btn {
|
.card-btn {
|
||||||
// width: 144rpx;
|
// width: 144rpx;
|
||||||
|
@ -96,7 +101,6 @@
|
||||||
font-size: 24rpx;
|
font-size: 24rpx;
|
||||||
font-weight: 400;
|
font-weight: 400;
|
||||||
}
|
}
|
||||||
|
|
||||||
.boder-btn {
|
.boder-btn {
|
||||||
background: linear-gradient(90deg, var(--ui-BG-Main-opacity-4), var(--ui-BG-Main-light));
|
background: linear-gradient(90deg, var(--ui-BG-Main-opacity-4), var(--ui-BG-Main-light));
|
||||||
color: #fff !important;
|
color: #fff !important;
|
||||||
|
|
|
@ -1,9 +1,13 @@
|
||||||
<template>
|
<template>
|
||||||
<view class="ss-m-20" :style="{ opacity: disabled ? '0.5' : '1' }">
|
<view class="ss-m-20" :style="{ opacity: disabled ? '0.5' : '1' }">
|
||||||
<view class="content">
|
<view class="content">
|
||||||
<view class="tag ss-flex ss-row-center" :class="
|
<!-- <view
|
||||||
|
class="tag ss-flex ss-row-center"
|
||||||
|
:class="
|
||||||
data.status == 'expired' || data.status == 'used' ? 'disabled-bg-color' : 'info-bg-color'
|
data.status == 'expired' || data.status == 'used' ? 'disabled-bg-color' : 'info-bg-color'
|
||||||
">{{ data.type_text }}</view>
|
"
|
||||||
|
>{{ data.type_text }}</view
|
||||||
|
> -->
|
||||||
<view class="title ss-m-x-30 ss-p-t-18">
|
<view class="title ss-m-x-30 ss-p-t-18">
|
||||||
<view class="ss-flex ss-row-between">
|
<view class="ss-flex ss-row-between">
|
||||||
<view class="value-text ss-flex-1 ss-m-r-10" :class="
|
<view class="value-text ss-flex-1 ss-m-r-10" :class="
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
<!-- 订单确认的优惠劵选择弹窗 -->
|
|
||||||
<template>
|
<template>
|
||||||
<su-popup
|
<su-popup
|
||||||
:show="show"
|
:show="show"
|
||||||
|
@ -17,21 +16,20 @@
|
||||||
:enable-back-to-top="true"
|
:enable-back-to-top="true"
|
||||||
>
|
>
|
||||||
<view class="subtitle ss-m-l-20">可使用优惠券</view>
|
<view class="subtitle ss-m-l-20">可使用优惠券</view>
|
||||||
<view v-for="(item, index) in state.couponInfo" :key="index">
|
<view v-for="(item, index) in state.couponInfo.can_use" :key="index">
|
||||||
<s-coupon-list :data="item" type="user" :disabled="false">
|
<s-coupon-list :data="item" type="user" :disabled="false">
|
||||||
<template #default>
|
<template #default>
|
||||||
<label class="ss-flex ss-col-center" @tap="radioChange(item.id)">
|
<label class="ss-flex ss-col-center" @tap="radioChange(item.id)">
|
||||||
<radio
|
<radio
|
||||||
color="var(--ui-BG-Main)"
|
color="var(--ui-BG-Main)"
|
||||||
style="transform: scale(0.8)"
|
style="transform: scale(0.8)"
|
||||||
:checked="state.couponId === item.id"
|
:checked="state.couponId == item.id"
|
||||||
@tap.stop="radioChange(item.id)"
|
@tap.stop="radioChange(item.id)"
|
||||||
/>
|
/>
|
||||||
</label>
|
</label>
|
||||||
</template>
|
</template>
|
||||||
</s-coupon-list>
|
</s-coupon-list>
|
||||||
</view>
|
</view>
|
||||||
<!-- TODO 芋艿:未来接口需要支持下
|
|
||||||
<view class="subtitle ss-m-t-40 ss-m-l-20">不可使用优惠券</view>
|
<view class="subtitle ss-m-t-40 ss-m-l-20">不可使用优惠券</view>
|
||||||
<view v-for="item in state.couponInfo.cannot_use" :key="item.id">
|
<view v-for="item in state.couponInfo.cannot_use" :key="item.id">
|
||||||
<s-coupon-list :data="item" type="user" :disabled="true">
|
<s-coupon-list :data="item" type="user" :disabled="true">
|
||||||
|
@ -43,7 +41,6 @@
|
||||||
</template>
|
</template>
|
||||||
</s-coupon-list>
|
</s-coupon-list>
|
||||||
</view>
|
</view>
|
||||||
-->
|
|
||||||
</scroll-view>
|
</scroll-view>
|
||||||
</view>
|
</view>
|
||||||
<view class="modal-footer ss-flex">
|
<view class="modal-footer ss-flex">
|
||||||
|
@ -53,9 +50,8 @@
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
import { computed, reactive } from 'vue';
|
import { computed, reactive } from 'vue';
|
||||||
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
modelValue: { // 优惠劵列表
|
modelValue: {
|
||||||
type: Object,
|
type: Object,
|
||||||
default() {},
|
default() {},
|
||||||
},
|
},
|
||||||
|
@ -64,27 +60,21 @@
|
||||||
default: false,
|
default: false,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const emits = defineEmits(['confirm', 'close']);
|
const emits = defineEmits(['confirm', 'close']);
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
couponInfo: computed(() => props.modelValue), // 优惠劵列表
|
couponInfo: computed(() => props.modelValue),
|
||||||
couponId: 0, // 选中的优惠劵编号
|
couponId: 0,
|
||||||
});
|
});
|
||||||
|
|
||||||
// 选中优惠劵
|
|
||||||
function radioChange(couponId) {
|
function radioChange(couponId) {
|
||||||
if (state.couponId === couponId) {
|
if (state.couponId == couponId) {
|
||||||
state.couponId = 0;
|
state.couponId = 0;
|
||||||
} else {
|
} else {
|
||||||
state.couponId = couponId;
|
state.couponId = couponId;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 确认优惠劵
|
|
||||||
const onConfirm = () => {
|
const onConfirm = () => {
|
||||||
emits('confirm', state.couponId);
|
emits('confirm', state.couponId);
|
||||||
}
|
};
|
||||||
</script>
|
</script>
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
:deep() {
|
:deep() {
|
||||||
|
|
|
@ -54,7 +54,7 @@
|
||||||
<script setup>
|
<script setup>
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import { computed } from 'vue';
|
import { computed } from 'vue';
|
||||||
import { fen2yuan } from '../../hooks/useGoods';
|
import { fen2yuan } from '@/sheep/hooks/useGoods';
|
||||||
/**
|
/**
|
||||||
* 订单卡片
|
* 订单卡片
|
||||||
*
|
*
|
||||||
|
|
|
@ -3,17 +3,14 @@
|
||||||
<view>
|
<view>
|
||||||
<su-popup :show="state.showShareGuide" :showClose="false" @close="onCloseGuide"></su-popup>
|
<su-popup :show="state.showShareGuide" :showClose="false" @close="onCloseGuide"></su-popup>
|
||||||
<view v-if="state.showShareGuide" class="guide-wrap">
|
<view v-if="state.showShareGuide" class="guide-wrap">
|
||||||
<image
|
<image class="guide-image" :src="sheep.$url.static('/static/img/shop/share/share_guide.png')"></image>
|
||||||
class="guide-image"
|
|
||||||
:src="sheep.$url.static('/static/img/shop/share/share_guide.png')"
|
|
||||||
></image>
|
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<su-popup :show="show" round="10" :showClose="false" @close="closeShareModal">
|
<su-popup :show="show" round="10" :showClose="false" @close="closeShareModal">
|
||||||
<!-- 分享tools -->
|
<!-- 分享tools -->
|
||||||
<view class="share-box">
|
<view class="share-box">
|
||||||
<view class="share-list-box ss-flex">
|
<view class="share-list-box ss-flex">
|
||||||
<button
|
<!-- <button
|
||||||
v-if="shareConfig.methods.includes('forward')"
|
v-if="shareConfig.methods.includes('forward')"
|
||||||
class="share-item share-btn ss-flex-col ss-col-center"
|
class="share-item share-btn ss-flex-col ss-col-center"
|
||||||
open-type="share"
|
open-type="share"
|
||||||
|
@ -25,20 +22,14 @@
|
||||||
mode=""
|
mode=""
|
||||||
></image>
|
></image>
|
||||||
<text class="share-title">微信好友</text>
|
<text class="share-title">微信好友</text>
|
||||||
</button>
|
</button> -->
|
||||||
<button
|
<button v-if="shareConfig.methods.includes('poster')"
|
||||||
v-if="shareConfig.methods.includes('poster')"
|
class="share-item share-btn ss-flex-col ss-col-center" @tap="onShareByPoster">
|
||||||
class="share-item share-btn ss-flex-col ss-col-center"
|
<image class="share-img" :src="sheep.$url.static('/static/img/shop/share/share_poster.png')"
|
||||||
@tap="onShareByPoster"
|
mode=""></image>
|
||||||
>
|
|
||||||
<image
|
|
||||||
class="share-img"
|
|
||||||
:src="sheep.$url.static('/static/img/shop/share/share_poster.png')"
|
|
||||||
mode=""
|
|
||||||
></image>
|
|
||||||
<text class="share-title">生成海报</text>
|
<text class="share-title">生成海报</text>
|
||||||
</button>
|
</button>
|
||||||
|
<!--
|
||||||
<button
|
<button
|
||||||
v-if="shareConfig.methods.includes('link')"
|
v-if="shareConfig.methods.includes('link')"
|
||||||
class="share-item share-btn ss-flex-col ss-col-center"
|
class="share-item share-btn ss-flex-col ss-col-center"
|
||||||
|
@ -50,7 +41,7 @@
|
||||||
mode=""
|
mode=""
|
||||||
></image>
|
></image>
|
||||||
<text class="share-title">复制链接</text>
|
<text class="share-title">复制链接</text>
|
||||||
</button>
|
</button> -->
|
||||||
</view>
|
</view>
|
||||||
<view class="share-foot ss-flex ss-row-center ss-col-center" @tap="closeShareModal">
|
<view class="share-foot ss-flex ss-row-center ss-col-center" @tap="closeShareModal">
|
||||||
取消
|
取消
|
||||||
|
@ -58,22 +49,27 @@
|
||||||
</view>
|
</view>
|
||||||
</su-popup>
|
</su-popup>
|
||||||
<!-- 分享海报 -->
|
<!-- 分享海报 -->
|
||||||
<canvas-poster
|
<canvas-poster ref="SharePosterRef" :show="state.showPosterModal" :shareInfo="shareInfo"
|
||||||
ref="SharePosterRef"
|
@close="state.showPosterModal = false" />
|
||||||
:show="state.showPosterModal"
|
|
||||||
:shareInfo="shareInfo"
|
|
||||||
@close="state.showPosterModal = false"
|
|
||||||
/>
|
|
||||||
</view>
|
</view>
|
||||||
</template>
|
</template>
|
||||||
<script setup>
|
<script setup>
|
||||||
/**
|
/**
|
||||||
* 分享弹窗
|
* 分享弹窗
|
||||||
*/
|
*/
|
||||||
import { ref, unref, reactive, computed } from 'vue';
|
import {
|
||||||
|
ref,
|
||||||
|
unref,
|
||||||
|
reactive,
|
||||||
|
computed
|
||||||
|
} from 'vue';
|
||||||
import sheep from '@/sheep';
|
import sheep from '@/sheep';
|
||||||
import canvasPoster from './canvas-poster/index.vue';
|
import canvasPoster from './canvas-poster/index.vue';
|
||||||
import { showShareModal, closeShareModal, showAuthModal } from '@/sheep/hooks/useModal';
|
import {
|
||||||
|
showShareModal,
|
||||||
|
closeShareModal,
|
||||||
|
showAuthModal
|
||||||
|
} from '@/sheep/hooks/useModal';
|
||||||
|
|
||||||
const show = computed(() => sheep.$store('modal').share);
|
const show = computed(() => sheep.$store('modal').share);
|
||||||
const shareConfig = computed(() => sheep.$store('app').platform.share);
|
const shareConfig = computed(() => sheep.$store('app').platform.share);
|
||||||
|
|
|
@ -3,20 +3,19 @@ import sheep from '@/sheep';
|
||||||
import $wxsdk from '@/sheep/libs/sdk-h5-weixin';
|
import $wxsdk from '@/sheep/libs/sdk-h5-weixin';
|
||||||
// #endif
|
// #endif
|
||||||
import { getRootUrl } from '@/sheep/helper';
|
import { getRootUrl } from '@/sheep/helper';
|
||||||
import PayOrderApi from '@/sheep/api/pay/order';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 支付
|
* 支付
|
||||||
*
|
*
|
||||||
* @param {String} payment = ['wechat','alipay','wallet','offline'] - 支付方式
|
* @param {String} payment = ['wechat','alipay','wallet','offline'] - 支付方式
|
||||||
* @param {String} orderType = ['goods','recharge','groupon'] - 订单类型
|
* @param {String} orderType = ['goods','recharge','groupon'] - 订单类型
|
||||||
* @param {String} id - 订单号
|
* @param {String} orderSN - 订单号
|
||||||
*/
|
*/
|
||||||
|
|
||||||
export default class SheepPay {
|
export default class SheepPay {
|
||||||
constructor(payment, orderType, id) {
|
constructor(payment, orderType, orderSN) {
|
||||||
this.payment = payment;
|
this.payment = payment;
|
||||||
this.id = id;
|
this.orderSN = orderSN;
|
||||||
this.orderType = orderType;
|
this.orderType = orderType;
|
||||||
this.payAction();
|
this.payAction();
|
||||||
}
|
}
|
||||||
|
@ -30,8 +29,8 @@ export default class SheepPay {
|
||||||
alipay: () => {
|
alipay: () => {
|
||||||
this.redirectPay(); // 现在公众号可以直接跳转支付宝页面
|
this.redirectPay(); // 现在公众号可以直接跳转支付宝页面
|
||||||
},
|
},
|
||||||
wallet: () => {
|
money: () => {
|
||||||
this.walletPay();
|
this.moneyPay();
|
||||||
},
|
},
|
||||||
offline: () => {
|
offline: () => {
|
||||||
this.offlinePay();
|
this.offlinePay();
|
||||||
|
@ -44,8 +43,8 @@ export default class SheepPay {
|
||||||
alipay: () => {
|
alipay: () => {
|
||||||
this.copyPayLink();
|
this.copyPayLink();
|
||||||
},
|
},
|
||||||
wallet: () => {
|
money: () => {
|
||||||
this.walletPay();
|
this.moneyPay();
|
||||||
},
|
},
|
||||||
offline: () => {
|
offline: () => {
|
||||||
this.offlinePay();
|
this.offlinePay();
|
||||||
|
@ -58,8 +57,8 @@ export default class SheepPay {
|
||||||
alipay: () => {
|
alipay: () => {
|
||||||
this.alipay();
|
this.alipay();
|
||||||
},
|
},
|
||||||
wallet: () => {
|
money: () => {
|
||||||
this.walletPay();
|
this.moneyPay();
|
||||||
},
|
},
|
||||||
offline: () => {
|
offline: () => {
|
||||||
this.offlinePay();
|
this.offlinePay();
|
||||||
|
@ -72,8 +71,8 @@ export default class SheepPay {
|
||||||
alipay: () => {
|
alipay: () => {
|
||||||
this.redirectPay();
|
this.redirectPay();
|
||||||
},
|
},
|
||||||
wallet: () => {
|
money: () => {
|
||||||
this.walletPay();
|
this.moneyPay();
|
||||||
},
|
},
|
||||||
offline: () => {
|
offline: () => {
|
||||||
this.offlinePay();
|
this.offlinePay();
|
||||||
|
@ -84,21 +83,18 @@ export default class SheepPay {
|
||||||
}
|
}
|
||||||
|
|
||||||
// 预支付
|
// 预支付
|
||||||
prepay(channel) {
|
prepay() {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
let data = {
|
let data = {
|
||||||
id: this.id,
|
order_sn: this.orderSN,
|
||||||
channelCode: channel,
|
payment: this.payment,
|
||||||
channelExtras: {}
|
|
||||||
};
|
};
|
||||||
if (uni.getStorageSync('openid')) {
|
if (uni.getStorageSync('openid')) {
|
||||||
data.openid = uni.getStorageSync('openid');
|
data.openid = uni.getStorageSync('openid');
|
||||||
}
|
}
|
||||||
PayOrderApi.submitOrder(data).then((res) => {
|
sheep.$api.pay.prepay(data).then((res) => {
|
||||||
// 成功时
|
res.error === 0 && resolve(res);
|
||||||
res.code === 0 && resolve(res);
|
if (res.error === -1 && res.msg === 'miss_openid') {
|
||||||
// 失败时
|
|
||||||
if (res.code !== 0 && res.msg === 'miss_openid') {
|
|
||||||
uni.showModal({
|
uni.showModal({
|
||||||
title: '微信支付',
|
title: '微信支付',
|
||||||
content: '请先绑定微信再使用微信支付',
|
content: '请先绑定微信再使用微信支付',
|
||||||
|
@ -113,7 +109,7 @@ export default class SheepPay {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// #ifdef H5
|
// #ifdef H5
|
||||||
// 微信公众号JSSDK支付 TODO 芋艿:待接入
|
// 微信公众号JSSDK支付
|
||||||
async wechatOfficialAccountPay() {
|
async wechatOfficialAccountPay() {
|
||||||
let that = this;
|
let that = this;
|
||||||
let { error, data, msg } = await this.prepay();
|
let { error, data, msg } = await this.prepay();
|
||||||
|
@ -134,21 +130,21 @@ export default class SheepPay {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
//浏览器微信H5支付 TODO 芋艿:待接入
|
//浏览器微信H5支付
|
||||||
async wechatWapPay() {
|
async wechatWapPay() {
|
||||||
const { error, data } = await this.prepay();
|
const { error, data } = await this.prepay();
|
||||||
if (error === 0) {
|
if (error === 0) {
|
||||||
const redirect_url = `${getRootUrl()}pages/pay/result?id=${this.id}&payment=${this.payment
|
const redirect_url = `${getRootUrl()}pages/pay/result?orderSN=${this.orderSN}&payment=${this.payment
|
||||||
}&orderType=${this.orderType}`;
|
}&orderType=${this.orderType}`;
|
||||||
location.href = `${data.pay_data.h5_url}&redirect_url=${encodeURIComponent(redirect_url)}`;
|
location.href = `${data.pay_data.h5_url}&redirect_url=${encodeURIComponent(redirect_url)}`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 支付链接 TODO 芋艿:待接入
|
// 支付链接
|
||||||
async redirectPay() {
|
async redirectPay() {
|
||||||
let { error, data } = await this.prepay();
|
let { error, data } = await this.prepay();
|
||||||
if (error === 0) {
|
if (error === 0) {
|
||||||
const redirect_url = `${getRootUrl()}pages/pay/result?id=${this.id}&payment=${this.payment
|
const redirect_url = `${getRootUrl()}pages/pay/result?orderSN=${this.orderSN}&payment=${this.payment
|
||||||
}&orderType=${this.orderType}`;
|
}&orderType=${this.orderType}`;
|
||||||
location.href = data.pay_data + encodeURIComponent(redirect_url);
|
location.href = data.pay_data + encodeURIComponent(redirect_url);
|
||||||
}
|
}
|
||||||
|
@ -156,7 +152,7 @@ export default class SheepPay {
|
||||||
|
|
||||||
// #endif
|
// #endif
|
||||||
|
|
||||||
// 微信小程序支付 TODO 芋艿:待接入
|
// 微信小程序支付
|
||||||
async wechatMiniProgramPay() {
|
async wechatMiniProgramPay() {
|
||||||
let that = this;
|
let that = this;
|
||||||
let result = await this.prepay();
|
let result = await this.prepay();
|
||||||
|
@ -177,18 +173,18 @@ export default class SheepPay {
|
||||||
}
|
}
|
||||||
|
|
||||||
// 余额支付
|
// 余额支付
|
||||||
async walletPay() {
|
async moneyPay() {
|
||||||
const { code } = await this.prepay('wallet');
|
const { error } = await this.prepay();
|
||||||
code === 0 && this.payResult('success');
|
error === 0 && this.payResult('success');
|
||||||
}
|
}
|
||||||
|
|
||||||
// 货到付款 TODO 芋艿:待接入
|
// 货到付款
|
||||||
async offlinePay() {
|
async offlinePay() {
|
||||||
const { error } = await this.prepay();
|
const { error } = await this.prepay();
|
||||||
error === 0 && this.payResult('success');
|
error === 0 && this.payResult('success');
|
||||||
}
|
}
|
||||||
|
|
||||||
// 支付宝复制链接支付 TODO 芋艿:待接入
|
// 支付宝复制链接支付
|
||||||
async copyPayLink() {
|
async copyPayLink() {
|
||||||
let that = this;
|
let that = this;
|
||||||
let { error, data } = await this.prepay();
|
let { error, data } = await this.prepay();
|
||||||
|
@ -207,7 +203,7 @@ export default class SheepPay {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 支付宝支付 TODO 芋艿:待接入
|
// 支付宝支付
|
||||||
async alipay() {
|
async alipay() {
|
||||||
let that = this;
|
let that = this;
|
||||||
const { error, data } = await this.prepay();
|
const { error, data } = await this.prepay();
|
||||||
|
@ -229,7 +225,7 @@ export default class SheepPay {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 微信支付 TODO 芋艿:待接入
|
// 微信支付
|
||||||
async wechatAppPay() {
|
async wechatAppPay() {
|
||||||
let that = this;
|
let that = this;
|
||||||
let { error, data } = await this.prepay();
|
let { error, data } = await this.prepay();
|
||||||
|
@ -250,72 +246,10 @@ export default class SheepPay {
|
||||||
// 支付结果跳转,success:成功,fail:失败
|
// 支付结果跳转,success:成功,fail:失败
|
||||||
payResult(resultType) {
|
payResult(resultType) {
|
||||||
sheep.$router.redirect('/pages/pay/result', {
|
sheep.$router.redirect('/pages/pay/result', {
|
||||||
id: this.id,
|
orderSN: this.orderSN,
|
||||||
|
payment: this.payment, //重新支付的时候使用
|
||||||
|
payState: resultType,
|
||||||
orderType: this.orderType,
|
orderType: this.orderType,
|
||||||
payState: resultType
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getPayMethods(channels) {
|
|
||||||
const payMethods = [
|
|
||||||
{
|
|
||||||
icon: '/static/img/shop/pay/wechat.png',
|
|
||||||
title: '微信支付',
|
|
||||||
value: 'wechat',
|
|
||||||
disabled: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
icon: '/static/img/shop/pay/alipay.png',
|
|
||||||
title: '支付宝支付',
|
|
||||||
value: 'alipay',
|
|
||||||
disabled: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
icon: '/static/img/shop/pay/wallet.png',
|
|
||||||
title: '余额支付',
|
|
||||||
value: 'wallet',
|
|
||||||
disabled: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
icon: '/static/img/shop/pay/apple.png',
|
|
||||||
title: 'Apple Pay',
|
|
||||||
value: 'apple',
|
|
||||||
disabled: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
icon: '/static/img/shop/pay/wallet.png',
|
|
||||||
title: '模拟支付',
|
|
||||||
value: 'mock',
|
|
||||||
disabled: true,
|
|
||||||
}
|
|
||||||
];
|
|
||||||
const platform = sheep.$platform.name
|
|
||||||
|
|
||||||
// 1. 处理【微信支付】
|
|
||||||
const wechatMethod = payMethods[0];
|
|
||||||
if ((platform === 'WechatOfficialAccount' && channels.includes('wx_pub'))
|
|
||||||
|| platform === 'WechatMiniProgram' && channels.includes('wx_lite')
|
|
||||||
|| platform === 'App' && channels.includes('wx_app')) {
|
|
||||||
wechatMethod.disabled = false;
|
|
||||||
}
|
|
||||||
// 2. 处理【支付宝支付】
|
|
||||||
const alipayMethod = payMethods[1];
|
|
||||||
if ((platform === 'WechatOfficialAccount' && channels.includes('alipay_wap'))
|
|
||||||
|| platform === 'WechatMiniProgram' && channels.includes('alipay_wap')
|
|
||||||
|| platform === 'App' && channels.includes('alipay_app')) {
|
|
||||||
alipayMethod.disabled = false;
|
|
||||||
}
|
|
||||||
// 3. 处理【余额支付】
|
|
||||||
const walletMethod = payMethods[2];
|
|
||||||
if (channels.includes('wallet')) {
|
|
||||||
walletMethod.disabled = false;
|
|
||||||
}
|
|
||||||
// 4. 处理【苹果支付】TODO 芋艿:未来接入
|
|
||||||
// 5. 处理【模拟支付】
|
|
||||||
const mockMethod = payMethods[4];
|
|
||||||
if (channels.includes('mock')) {
|
|
||||||
mockMethod.disabled = false;
|
|
||||||
}
|
|
||||||
return payMethods;
|
|
||||||
}
|
|
|
@ -55,8 +55,7 @@ const http = new Request({
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
header: {
|
header: {
|
||||||
Accept: 'text/json',
|
Accept: 'text/json',
|
||||||
'Content-Type': 'application/json',
|
'Content-Type': 'application/json;charset=UTF-8',
|
||||||
// ;charset=UTF-8
|
|
||||||
platform: $platform.name,
|
platform: $platform.name,
|
||||||
},
|
},
|
||||||
// #ifdef APP-PLUS
|
// #ifdef APP-PLUS
|
||||||
|
@ -99,7 +98,6 @@ http.interceptors.request.use(
|
||||||
config.header['terminal'] = '20';
|
config.header['terminal'] = '20';
|
||||||
config.header['Authorization'] = 'Bearer test247';
|
config.header['Authorization'] = 'Bearer test247';
|
||||||
}
|
}
|
||||||
// console.log(config, '看参数')
|
|
||||||
return config;
|
return config;
|
||||||
},
|
},
|
||||||
(error) => {
|
(error) => {
|
||||||
|
|
|
@ -23,8 +23,8 @@ const app = defineStore({
|
||||||
copytime: '', // 版权信息 II
|
copytime: '', // 版权信息 II
|
||||||
},
|
},
|
||||||
platform: {
|
platform: {
|
||||||
payment: [], // 支持的支付方式 TODO 芋艿:可删除
|
payment: [], // 支持的支付方式
|
||||||
recharge_payment: [], // 支持的充值支付方式 TODO 芋艿:可删除
|
recharge_payment: [], // 支持的充值支付方式
|
||||||
share: {
|
share: {
|
||||||
methods: [], // 支持的分享方式
|
methods: [], // 支持的分享方式
|
||||||
forwardInfo: {}, // 默认转发信息
|
forwardInfo: {}, // 默认转发信息
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { defineStore } from 'pinia';
|
import { defineStore } from 'pinia';
|
||||||
import CartApi from '@/sheep/api/trade/cart';
|
import cartApi from '@/sheep/api/cart';
|
||||||
|
|
||||||
const cart = defineStore({
|
const cart = defineStore({
|
||||||
id: 'cart',
|
id: 'cart',
|
||||||
|
@ -7,87 +7,92 @@ const cart = defineStore({
|
||||||
list: [], // 购物车列表
|
list: [], // 购物车列表
|
||||||
selectedIds: [], // 已选列表
|
selectedIds: [], // 已选列表
|
||||||
isAllSelected: false, //是否全选
|
isAllSelected: false, //是否全选
|
||||||
totalPriceSelected: 0, // 选中项总金额
|
cartSelectedTotalPrice: '0.00', // 选中项总金额
|
||||||
}),
|
}),
|
||||||
|
getters: {
|
||||||
|
totalPriceSelected: (state) => {
|
||||||
|
let price = 0;
|
||||||
|
if (!state.selectedIds.length) return price.toFixed(2);
|
||||||
|
state.list.forEach((item) => {
|
||||||
|
price += state.selectedIds.includes(item.id)
|
||||||
|
? Number(item.sku.price/100) * item.count
|
||||||
|
: 0;
|
||||||
|
});
|
||||||
|
return price.toFixed(2);
|
||||||
|
},
|
||||||
|
},
|
||||||
actions: {
|
actions: {
|
||||||
// 获取购物车列表
|
// 获取购物车列表
|
||||||
async getList() {
|
async getList() {
|
||||||
const { data, code } = await CartApi.getCartList();
|
const { data, code } = await cartApi.list();
|
||||||
if (code === 0) {
|
if (code === 0) {
|
||||||
this.list = data.validList;
|
this.list = data.validList;
|
||||||
|
|
||||||
// 计算各种关联属性
|
|
||||||
this.selectedIds = [];
|
|
||||||
this.isAllSelected = true;
|
|
||||||
this.totalPriceSelected = 0;
|
|
||||||
this.list.forEach((item) => {
|
|
||||||
if (item.selected) {
|
|
||||||
this.selectedIds.push(item.id);
|
|
||||||
this.totalPriceSelected += item.count * item.sku.price;
|
|
||||||
} else {
|
|
||||||
this.isAllSelected = false;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// 添加购物车
|
// 添加购物车
|
||||||
async add(goodsInfo) {
|
async add(goodsInfo) {
|
||||||
// 添加购物项
|
const { error } = await cartApi.append({
|
||||||
const { code } = await CartApi.addCart({
|
goods_id: goodsInfo.goods_id,
|
||||||
skuId: goodsInfo.id,
|
goods_num: goodsInfo.goods_num,
|
||||||
count: goodsInfo.goods_num,
|
goods_sku_price_id: goodsInfo.id,
|
||||||
});
|
});
|
||||||
// 刷新购物车列表
|
if (error === 0) {
|
||||||
if (code === 0) {
|
this.getList();
|
||||||
await this.getList();
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// 更新购物车
|
// 更新购物车
|
||||||
async update(goodsInfo) {
|
async update(goodsInfo) {
|
||||||
const { code } = await CartApi.updateCartCount({
|
const { error } = await cartApi.update({
|
||||||
id: goodsInfo.goods_id,
|
id: goodsInfo.goods_id,
|
||||||
count: goodsInfo.goods_num,
|
count: goodsInfo.goods_num,
|
||||||
|
goods_sku_price_id: goodsInfo.goods_sku_price_id,
|
||||||
});
|
});
|
||||||
if (code === 0) {
|
if (error === 0) {
|
||||||
await this.getList();
|
// this.getList();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// 移除购物车
|
// 移除购物车
|
||||||
async delete(ids) {
|
async delete(ids) {
|
||||||
const { code } = await CartApi.deleteCart(ids.join(','));
|
if (typeof ids === 'array') {
|
||||||
|
ids = ids.join(',');
|
||||||
|
}
|
||||||
|
const { code } = await cartApi.delete(ids);
|
||||||
if (code === 0) {
|
if (code === 0) {
|
||||||
await this.getList();
|
this.selectAll(false);
|
||||||
|
this.getList();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// 单选购物车商品
|
// 选择购物车商品
|
||||||
async selectSingle(goodsId) {
|
selectSingle(goodsId) {
|
||||||
const { code } = await CartApi.updateCartSelected({
|
if (!this.selectedIds.includes(goodsId)) {
|
||||||
ids: [goodsId],
|
this.selectedIds.push(goodsId);
|
||||||
selected: !this.selectedIds.includes(goodsId), // 取反
|
} else {
|
||||||
});
|
this.selectedIds.splice(this.selectedIds.indexOf(goodsId), 1);
|
||||||
if (code === 0) {
|
|
||||||
await this.getList();
|
|
||||||
}
|
}
|
||||||
|
this.isAllSelected = this.selectedIds.length === this.list.length;
|
||||||
},
|
},
|
||||||
|
|
||||||
// 全选购物车商品
|
// 全选
|
||||||
async selectAll(flag) {
|
selectAll(flag) {
|
||||||
const { code } = await CartApi.updateCartSelected({
|
this.isAllSelected = flag;
|
||||||
ids: this.list.map((item) => item.id),
|
if (!flag) {
|
||||||
selected: flag
|
this.selectedIds = [];
|
||||||
|
} else {
|
||||||
|
this.list.forEach((item) => {
|
||||||
|
this.selectedIds.push(item.id);
|
||||||
});
|
});
|
||||||
if (code === 0) {
|
|
||||||
await this.getList();
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// 清空购物车
|
// 清空购物车
|
||||||
async emptyList() {
|
emptyList() {
|
||||||
await this.delete(this.list.map((item) => item.id));
|
this.list = [];
|
||||||
|
this.selectedIds = [];
|
||||||
|
this.isAllSelected = false;
|
||||||
|
this.cartSelectedTotalPrice = '0.00';
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
persist: {
|
persist: {
|
||||||
|
|
|
@ -100,3 +100,16 @@ export function handleTree(data, id = 'id', parentId = 'parentId', children = 'c
|
||||||
});
|
});
|
||||||
return treeData !== '' ? treeData : data;
|
return treeData !== '' ? treeData : data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 重置分页对象
|
||||||
|
*
|
||||||
|
* TODO 芋艿:需要处理其它页面
|
||||||
|
*
|
||||||
|
* @param pagination 分页对象
|
||||||
|
*/
|
||||||
|
export function resetPagination(pagination) {
|
||||||
|
pagination.list = [];
|
||||||
|
pagination.total = 0;
|
||||||
|
pagination.pageNo = 1;
|
||||||
|
}
|
|
@ -5,9 +5,7 @@
|
||||||
// 配置
|
// 配置
|
||||||
const config = {
|
const config = {
|
||||||
// 信任的标签(保持标签名不变)
|
// 信任的标签(保持标签名不变)
|
||||||
trustTags: makeMap(
|
trustTags: makeMap('a,abbr,ad,audio,b,blockquote,br,code,col,colgroup,dd,del,dl,dt,div,em,fieldset,h1,h2,h3,h4,h5,h6,hr,i,img,ins,label,legend,li,ol,p,q,ruby,rt,source,span,strong,sub,sup,table,tbody,td,tfoot,th,thead,tr,title,ul,video'),
|
||||||
'a,abbr,ad,audio,b,blockquote,br,code,col,colgroup,dd,del,dl,dt,div,em,fieldset,h1,h2,h3,h4,h5,h6,hr,i,img,ins,label,legend,li,ol,p,q,ruby,rt,source,span,strong,sub,sup,table,tbody,td,tfoot,th,thead,tr,title,ul,video'
|
|
||||||
),
|
|
||||||
|
|
||||||
// 块级标签(转为 div,其他的非信任标签转为 span)
|
// 块级标签(转为 div,其他的非信任标签转为 span)
|
||||||
blockTags: makeMap('address,article,aside,body,caption,center,cite,footer,header,html,nav,pre,section'),
|
blockTags: makeMap('address,article,aside,body,caption,center,cite,footer,header,html,nav,pre,section'),
|
||||||
|
@ -18,14 +16,10 @@ const config = {
|
||||||
// #endif
|
// #endif
|
||||||
|
|
||||||
// 要移除的标签
|
// 要移除的标签
|
||||||
ignoreTags: makeMap(
|
ignoreTags: makeMap('area,base,canvas,embed,frame,head,iframe,input,link,map,meta,param,rp,script,source,style,textarea,title,track,wbr'),
|
||||||
'area,base,canvas,embed,frame,head,iframe,input,link,map,meta,param,rp,script,source,style,textarea,title,track,wbr'
|
|
||||||
),
|
|
||||||
|
|
||||||
// 自闭合的标签
|
// 自闭合的标签
|
||||||
voidTags: makeMap(
|
voidTags: makeMap('area,base,br,col,circle,ellipse,embed,frame,hr,img,input,line,link,meta,param,path,polygon,rect,source,track,use,wbr'),
|
||||||
'area,base,br,col,circle,ellipse,embed,frame,hr,img,input,line,link,meta,param,path,polygon,rect,source,track,use,wbr'
|
|
||||||
),
|
|
||||||
|
|
||||||
// html 实体
|
// html 实体
|
||||||
entities: {
|
entities: {
|
||||||
|
@ -151,8 +145,7 @@ function decodeEntity(str, amp) {
|
||||||
function mergeNodes (nodes) {
|
function mergeNodes (nodes) {
|
||||||
let i = nodes.length - 1
|
let i = nodes.length - 1
|
||||||
for (let j = i; j >= -1; j--) {
|
for (let j = i; j >= -1; j--) {
|
||||||
if (j === -1 || nodes[j].c || !nodes[j].name || (nodes[j].name !== 'div' && nodes[j].name !== 'p' && nodes[j]
|
if (j === -1 || nodes[j].c || !nodes[j].name || (nodes[j].name !== 'div' && nodes[j].name !== 'p' && nodes[j].name[0] !== 'h') || (nodes[j].attrs.style || '').includes('inline')) {
|
||||||
.name[0] !== 'h') || (nodes[j].attrs.style || '').includes('inline')) {
|
|
||||||
if (i - j >= 5) {
|
if (i - j >= 5) {
|
||||||
nodes.splice(j + 1, i - j, {
|
nodes.splice(j + 1, i - j, {
|
||||||
name: 'div',
|
name: 'div',
|
||||||
|
@ -178,8 +171,7 @@ function Parser(vm) {
|
||||||
this.attrs = Object.create(null)
|
this.attrs = Object.create(null)
|
||||||
this.stack = []
|
this.stack = []
|
||||||
this.nodes = []
|
this.nodes = []
|
||||||
this.pre = (this.options.containerStyle || '').includes('white-space') && this.options.containerStyle.includes(
|
this.pre = (this.options.containerStyle || '').includes('white-space') && this.options.containerStyle.includes('pre') ? 2 : 0
|
||||||
'pre') ? 2 : 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -246,15 +238,13 @@ Parser.prototype.getUrl = function(url) {
|
||||||
} else if (domain) {
|
} else if (domain) {
|
||||||
// 否则补充整个域名
|
// 否则补充整个域名
|
||||||
url = domain + url
|
url = domain + url
|
||||||
} /* #ifdef APP-PLUS */
|
} /* #ifdef APP-PLUS */ else {
|
||||||
else {
|
|
||||||
url = plus.io.convertLocalFileSystemURL(url)
|
url = plus.io.convertLocalFileSystemURL(url)
|
||||||
} /* #endif */
|
} /* #endif */
|
||||||
} else if (!url.includes('data:') && !url.includes('://')) {
|
} else if (!url.includes('data:') && !url.includes('://')) {
|
||||||
if (domain) {
|
if (domain) {
|
||||||
url = domain + '/' + url
|
url = domain + '/' + url
|
||||||
} /* #ifdef APP-PLUS */
|
} /* #ifdef APP-PLUS */ else {
|
||||||
else {
|
|
||||||
url = plus.io.convertLocalFileSystemURL(url)
|
url = plus.io.convertLocalFileSystemURL(url)
|
||||||
} /* #endif */
|
} /* #endif */
|
||||||
}
|
}
|
||||||
|
@ -364,7 +354,6 @@ Parser.prototype.onAttrName = function(name) {
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
Parser.prototype.onAttrVal = function (val) {
|
Parser.prototype.onAttrVal = function (val) {
|
||||||
// console.log(val, '解码转码')
|
|
||||||
const name = this.attrName || ''
|
const name = this.attrName || ''
|
||||||
if (name === 'style' || name === 'href') {
|
if (name === 'style' || name === 'href') {
|
||||||
// 部分属性进行实体解码
|
// 部分属性进行实体解码
|
||||||
|
@ -408,11 +397,9 @@ Parser.prototype.onOpenTag = function(selfClose) {
|
||||||
// #ifndef H5 || APP-PLUS
|
// #ifndef H5 || APP-PLUS
|
||||||
const src = attrs.src || ''
|
const src = attrs.src || ''
|
||||||
// 按照后缀名和 type 将 embed 转为 video 或 audio
|
// 按照后缀名和 type 将 embed 转为 video 或 audio
|
||||||
if (src.includes('.mp4') || src.includes('.3gp') || src.includes('.m3u8') || (attrs.type || '').includes(
|
if (src.includes('.mp4') || src.includes('.3gp') || src.includes('.m3u8') || (attrs.type || '').includes('video')) {
|
||||||
'video')) {
|
|
||||||
node.name = 'video'
|
node.name = 'video'
|
||||||
} else if (src.includes('.mp3') || src.includes('.wav') || src.includes('.aac') || src.includes('.m4a') || (
|
} else if (src.includes('.mp3') || src.includes('.wav') || src.includes('.aac') || src.includes('.m4a') || (attrs.type || '').includes('audio')) {
|
||||||
attrs.type || '').includes('audio')) {
|
|
||||||
node.name = 'audio'
|
node.name = 'audio'
|
||||||
}
|
}
|
||||||
if (attrs.autostart) {
|
if (attrs.autostart) {
|
||||||
|
@ -452,9 +439,7 @@ Parser.prototype.onOpenTag = function(selfClose) {
|
||||||
// 通过 base 标签设置主域名
|
// 通过 base 标签设置主域名
|
||||||
if (node.name === 'base' && !this.options.domain) {
|
if (node.name === 'base' && !this.options.domain) {
|
||||||
this.options.domain = attrs.href
|
this.options.domain = attrs.href
|
||||||
} /* #ifndef APP-PLUS-NVUE */
|
} /* #ifndef APP-PLUS-NVUE */ else if (node.name === 'source' && parent && (parent.name === 'video' || parent.name === 'audio') && attrs.src) {
|
||||||
else if (node.name === 'source' && parent && (parent.name === 'video' || parent.name === 'audio') &&
|
|
||||||
attrs.src) {
|
|
||||||
// 设置 source 标签(仅父节点为 video 或 audio 时有效)
|
// 设置 source 标签(仅父节点为 video 或 audio 时有效)
|
||||||
parent.src.push(attrs.src)
|
parent.src.push(attrs.src)
|
||||||
} /* #endif */
|
} /* #endif */
|
||||||
|
@ -491,8 +476,7 @@ Parser.prototype.onOpenTag = function(selfClose) {
|
||||||
}
|
}
|
||||||
// #ifndef H5 || APP-PLUS
|
// #ifndef H5 || APP-PLUS
|
||||||
const style = item.attrs.style || ''
|
const style = item.attrs.style || ''
|
||||||
if (style.includes('flex:') && !style.includes('flex:0') && !style.includes('flex: 0') && (!
|
if (style.includes('flex:') && !style.includes('flex:0') && !style.includes('flex: 0') && (!styleObj.width || parseInt(styleObj.width) > 100)) {
|
||||||
styleObj.width || parseInt(styleObj.width) > 100)) {
|
|
||||||
styleObj.width = '100% !important'
|
styleObj.width = '100% !important'
|
||||||
styleObj.height = ''
|
styleObj.height = ''
|
||||||
for (let j = i + 1; j < this.stack.length; j++) {
|
for (let j = i + 1; j < this.stack.length; j++) {
|
||||||
|
@ -501,8 +485,7 @@ Parser.prototype.onOpenTag = function(selfClose) {
|
||||||
} else if (style.includes('flex') && styleObj.width === '100%') {
|
} else if (style.includes('flex') && styleObj.width === '100%') {
|
||||||
for (let j = i + 1; j < this.stack.length; j++) {
|
for (let j = i + 1; j < this.stack.length; j++) {
|
||||||
const style = this.stack[j].attrs.style || ''
|
const style = this.stack[j].attrs.style || ''
|
||||||
if (!style.includes(';width') && !style.includes(' width') && style.indexOf(
|
if (!style.includes(';width') && !style.includes(' width') && style.indexOf('width') !== 0) {
|
||||||
'width') !== 0) {
|
|
||||||
styleObj.width = ''
|
styleObj.width = ''
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
@ -565,8 +548,7 @@ Parser.prototype.onOpenTag = function(selfClose) {
|
||||||
if (!isNaN(parseInt(styleObj.width))) {
|
if (!isNaN(parseInt(styleObj.width))) {
|
||||||
node.w = 'T'
|
node.w = 'T'
|
||||||
}
|
}
|
||||||
if (!isNaN(parseInt(styleObj.height)) && (!styleObj.height.includes('%') || (parent && (parent.attrs
|
if (!isNaN(parseInt(styleObj.height)) && (!styleObj.height.includes('%') || (parent && (parent.attrs.style || '').includes('height')))) {
|
||||||
.style || '').includes('height')))) {
|
|
||||||
node.h = 'T'
|
node.h = 'T'
|
||||||
}
|
}
|
||||||
} else if (node.name === 'svg') {
|
} else if (node.name === 'svg') {
|
||||||
|
@ -587,8 +569,7 @@ Parser.prototype.onOpenTag = function(selfClose) {
|
||||||
}
|
}
|
||||||
// #endif
|
// #endif
|
||||||
} else {
|
} else {
|
||||||
if ((node.name === 'pre' || ((attrs.style || '').includes('white-space') && attrs.style.includes('pre'))) &&
|
if ((node.name === 'pre' || ((attrs.style || '').includes('white-space') && attrs.style.includes('pre'))) && this.pre !== 2) {
|
||||||
this.pre !== 2) {
|
|
||||||
this.pre = node.pre = 1
|
this.pre = node.pre = 1
|
||||||
}
|
}
|
||||||
node.children = []
|
node.children = []
|
||||||
|
@ -764,9 +745,7 @@ Parser.prototype.popNode = function() {
|
||||||
} else if (size > 7) {
|
} else if (size > 7) {
|
||||||
size = 7
|
size = 7
|
||||||
}
|
}
|
||||||
styleObj['font-size'] = ['x-small', 'small', 'medium', 'large', 'x-large', 'xx-large', 'xxx-large'][
|
styleObj['font-size'] = ['x-small', 'small', 'medium', 'large', 'x-large', 'xx-large', 'xxx-large'][size - 1]
|
||||||
size - 1
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
attrs.size = undefined
|
attrs.size = undefined
|
||||||
}
|
}
|
||||||
|
@ -795,8 +774,7 @@ Parser.prototype.popNode = function() {
|
||||||
|
|
||||||
if (node.name === 'a' || node.name === 'ad'
|
if (node.name === 'a' || node.name === 'ad'
|
||||||
// #ifdef H5 || APP-PLUS
|
// #ifdef H5 || APP-PLUS
|
||||||
||
|
|| node.name === 'iframe' // eslint-disable-line
|
||||||
node.name === 'iframe' // eslint-disable-line
|
|
||||||
// #endif
|
// #endif
|
||||||
) {
|
) {
|
||||||
this.expose()
|
this.expose()
|
||||||
|
@ -812,8 +790,7 @@ Parser.prototype.popNode = function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (this.options.pauseVideo) {
|
if (this.options.pauseVideo) {
|
||||||
str +=
|
str += ' onplay="this.dispatchEvent(new CustomEvent(\'vplay\',{bubbles:!0}));for(var e=document.getElementsByTagName(\'video\'),t=0;t<e.length;t++)e[t]!=this&&e[t].pause()"'
|
||||||
' onplay="this.dispatchEvent(new CustomEvent(\'vplay\',{bubbles:!0}));for(var e=document.getElementsByTagName(\'video\'),t=0;t<e.length;t++)e[t]!=this&&e[t].pause()"'
|
|
||||||
}
|
}
|
||||||
str += '>'
|
str += '>'
|
||||||
for (let i = 0; i < node.src.length; i++) {
|
for (let i = 0; i < node.src.length; i++) {
|
||||||
|
@ -930,9 +907,7 @@ Parser.prototype.popNode = function() {
|
||||||
style += ';justify-content: right'
|
style += ';justify-content: right'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
style = (border ? `;border:${border}px ${borderstyle || 'solid'} ${bordercolor || 'gray'}` +
|
style = (border ? `;border:${border}px ${borderstyle || 'solid'} ${bordercolor || 'gray'}` + (spacing ? '' : ';border-right:0;border-bottom:0') : '') + (padding ? `;padding:${padding}px` : '') + ';' + style
|
||||||
(spacing ? '' : ';border-right:0;border-bottom:0') : '') + (padding ?
|
|
||||||
`;padding:${padding}px` : '') + ';' + style
|
|
||||||
// 处理列合并
|
// 处理列合并
|
||||||
if (td.attrs.colspan) {
|
if (td.attrs.colspan) {
|
||||||
style += `;grid-column-start:${col};grid-column-end:${col + parseInt(td.attrs.colspan)}`
|
style += `;grid-column-start:${col};grid-column-end:${col + parseInt(td.attrs.colspan)}`
|
||||||
|
@ -985,8 +960,7 @@ Parser.prototype.popNode = function() {
|
||||||
const td = nodes[i]
|
const td = nodes[i]
|
||||||
if (td.name === 'th' || td.name === 'td') {
|
if (td.name === 'th' || td.name === 'td') {
|
||||||
if (border) {
|
if (border) {
|
||||||
td.attrs.style =
|
td.attrs.style = `border:${border}px ${borderstyle || 'solid'} ${bordercolor || 'gray'};${td.attrs.style || ''}`
|
||||||
`border:${border}px ${borderstyle || 'solid'} ${bordercolor || 'gray'};${td.attrs.style || ''}`
|
|
||||||
}
|
}
|
||||||
if (padding) {
|
if (padding) {
|
||||||
td.attrs.style = `padding:${padding}px;${td.attrs.style || ''}`
|
td.attrs.style = `padding:${padding}px;${td.attrs.style || ''}`
|
||||||
|
@ -1042,8 +1016,7 @@ Parser.prototype.popNode = function() {
|
||||||
for (let i = node.children.length; i--;) {
|
for (let i = node.children.length; i--;) {
|
||||||
const child = node.children[i]
|
const child = node.children[i]
|
||||||
// #ifdef (MP-WEIXIN || MP-QQ || APP-PLUS || MP-360) && VUE3
|
// #ifdef (MP-WEIXIN || MP-QQ || APP-PLUS || MP-360) && VUE3
|
||||||
if (child.name && (config.inlineTags[child.name] || ((child.attrs.style || '').includes(
|
if (child.name && (config.inlineTags[child.name] || ((child.attrs.style || '').includes('inline') && child.children)) && !child.c) {
|
||||||
'inline') && child.children)) && !child.c) {
|
|
||||||
traversal(child)
|
traversal(child)
|
||||||
}
|
}
|
||||||
// #endif
|
// #endif
|
||||||
|
@ -1064,16 +1037,13 @@ Parser.prototype.popNode = function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// flex 布局时部分样式需要提取到 rich-text 外层
|
// flex 布局时部分样式需要提取到 rich-text 外层
|
||||||
const flex = parent && ((parent.attrs.style || '').includes('flex') || (parent.attrs.style || '').includes(
|
const flex = parent && ((parent.attrs.style || '').includes('flex') || (parent.attrs.style || '').includes('grid'))
|
||||||
'grid'))
|
|
||||||
// #ifdef MP-WEIXIN
|
// #ifdef MP-WEIXIN
|
||||||
// 检查基础库版本 virtualHost 是否可用
|
// 检查基础库版本 virtualHost 是否可用
|
||||||
&&
|
&& !(node.c && wx.getNFCAdapter) // eslint-disable-line
|
||||||
!(node.c && wx.getNFCAdapter) // eslint-disable-line
|
|
||||||
// #endif
|
// #endif
|
||||||
// #ifndef MP-WEIXIN || MP-QQ || MP-BAIDU || MP-TOUTIAO
|
// #ifndef MP-WEIXIN || MP-QQ || MP-BAIDU || MP-TOUTIAO
|
||||||
&&
|
&& !node.c // eslint-disable-line
|
||||||
!node.c // eslint-disable-line
|
|
||||||
// #endif
|
// #endif
|
||||||
if (flex) {
|
if (flex) {
|
||||||
node.f = ';max-width:100%'
|
node.f = ';max-width:100%'
|
||||||
|
@ -1088,8 +1058,7 @@ Parser.prototype.popNode = function() {
|
||||||
if (styleObj[key]) {
|
if (styleObj[key]) {
|
||||||
const val = `;${key}:${styleObj[key].replace(' !important', '')}`
|
const val = `;${key}:${styleObj[key].replace(' !important', '')}`
|
||||||
/* #ifndef APP-PLUS-NVUE */
|
/* #ifndef APP-PLUS-NVUE */
|
||||||
if (flex && ((key.includes('flex') && key !== 'flex-direction') || key === 'align-self' || key.includes(
|
if (flex && ((key.includes('flex') && key !== 'flex-direction') || key === 'align-self' || key.includes('grid') || styleObj[key][0] === '-' || (key.includes('width') && val.includes('%')))) {
|
||||||
'grid') || styleObj[key][0] === '-' || (key.includes('width') && val.includes('%')))) {
|
|
||||||
node.f += val
|
node.f += val
|
||||||
if (key === 'width') {
|
if (key === 'width') {
|
||||||
attrs.style += ';width:100%'
|
attrs.style += ';width:100%'
|
||||||
|
@ -1150,8 +1119,7 @@ Parser.prototype.onText = function(text) {
|
||||||
node.text = decodeEntity(text)
|
node.text = decodeEntity(text)
|
||||||
if (this.hook(node)) {
|
if (this.hook(node)) {
|
||||||
// #ifdef MP-WEIXIN
|
// #ifdef MP-WEIXIN
|
||||||
if (this.options.selectable === 'force' && system.includes('iOS') && !uni.canIUse(
|
if (this.options.selectable === 'force' && system.includes('iOS') && !uni.canIUse('rich-text.user-select')) {
|
||||||
'rich-text.user-select')) {
|
|
||||||
this.expose()
|
this.expose()
|
||||||
}
|
}
|
||||||
// #endif
|
// #endif
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
import {
|
import { loadEnv } from 'vite';
|
||||||
loadEnv
|
|
||||||
} from 'vite';
|
|
||||||
import uni from '@dcloudio/vite-plugin-uni';
|
import uni from '@dcloudio/vite-plugin-uni';
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
// import viteCompression from 'vite-plugin-compression';
|
// import viteCompression from 'vite-plugin-compression';
|
||||||
|
|
Loading…
Reference in New Issue