diff --git a/api/goods/index.js b/api/goods/index.js index ed4ab14..e18fa53 100644 --- a/api/goods/index.js +++ b/api/goods/index.js @@ -10,7 +10,8 @@ const api = { skuInfo: 'goods/skuInfo', recommended: 'goods/recommended', poster: 'goods/poster', - serveList:'goods.service/list' + serveList:'goods.service/list', + presale:'goods/presale' } // 商品浏览记录 @@ -36,7 +37,11 @@ export const presale = (data) => { return request.get('goods/presale', data) } -// 商品浏览记录 +// // 商品浏览记录 +// export const presale = (param, option) => { +// return request.get(api.presale, param, option) +// } +// 服务 export const serveList = (param, option) => { return request.get(api.serveList, param, option) } diff --git a/api/home/index.js b/api/home/index.js index d5f6c32..0c7d7d8 100644 --- a/api/home/index.js +++ b/api/home/index.js @@ -5,14 +5,18 @@ const api = { list: 'goods/list', chartsGoodsJing:'goods/chartsGoodsJing', brandList:'goods/brandList', - typeList:'category/list' + typeList:'category/list', + cityInfo:'goods/cityInfo' } +// 商品列表 +export const cityInfo = (param, option) => { + return request.get(api.cityInfo, param, option) +} // 商品列表 export const list = (param, option) => { return request.get(api.list, param, option) } - // 首页排行榜 export const chartsGoodsJing = (param, option) => { return request.get(api.chartsGoodsJing, param, option) diff --git a/api/preList/index.js b/api/preList/index.js new file mode 100644 index 0000000..45416e9 --- /dev/null +++ b/api/preList/index.js @@ -0,0 +1,20 @@ +import request from '@/utils/request' + +// api地址 +const api = { + list: 'goods/presaleList', + canlpresale: 'goods/canlpresale' + +} + +/** + * 获取支付订单的信息 + * @param {Number} orderId + * @param {Object} param + */ +export function list(param) { + return request.get(api.list, param) +} +export function canlpresale(param) { + return request.get(api.canlpresale, param) +} \ No newline at end of file diff --git a/pages/activity/newGoods.vue b/pages/activity/newGoods.vue index 46f97ee..0b2f861 100644 --- a/pages/activity/newGoods.vue +++ b/pages/activity/newGoods.vue @@ -308,15 +308,15 @@ position: absolute; top: -68rpx; - right: 0; + right: 20rpx; } } .price { display: flex; justify-content: flex-end; - margin-top: 14rpx; - + margin-top: 50rpx; + margin-right: 30rpx; .lowPrice { height: 50rpx; font-size: 36rpx; @@ -324,7 +324,7 @@ font-weight: 600; color: #DE041C; line-height: 50rpx; - margin-right: 30rpx; + margin-right: 20rpx; } .buyNow { diff --git a/pages/activity/newsshop.vue b/pages/activity/newsshop.vue index 645978e..f20b01b 100644 --- a/pages/activity/newsshop.vue +++ b/pages/activity/newsshop.vue @@ -8,26 +8,26 @@ - + - + iphone 15pro - + 23999 - + iphone 15pro - + 23999 @@ -40,7 +40,7 @@ - + @@ -50,10 +50,10 @@ - + iphone 15pro - + 23999 160 @@ -61,10 +61,10 @@ - + iphone 15pro - + 23999 160 @@ -80,7 +80,7 @@ - + iphone 15pro 23999 @@ -89,7 +89,7 @@ - + iphone 15pro 23999 @@ -98,7 +98,7 @@ - + iphone 15pro 23999 @@ -107,7 +107,7 @@ - + iphone 15pro 23999 @@ -124,7 +124,7 @@ - + iphone 15pro 23999 @@ -133,7 +133,7 @@ - + iphone 15pro 23999 @@ -142,7 +142,7 @@ - + iphone 15pro 23999 @@ -151,7 +151,7 @@ - + iphone 15pro 23999 @@ -447,7 +447,7 @@ overflow: hidden; border-radius: 10rpx; padding-bottom: 30rpx; - background: #fff url(@/static/news/newshop-01.png) center top no-repeat; + background: #fff url(https://www.saas.njrenzhou.com/static/news/newshop-01.png) center top no-repeat; background-size: 100% auto; .a { @@ -524,7 +524,7 @@ overflow: hidden; border-radius: 10rpx; padding-bottom: 30rpx; - background: #fff url(@/static/news/newshop-02.png) center top no-repeat; + background: #fff url(https://www.saas.njrenzhou.com/static/news/newshop-02.png) center top no-repeat; background-size: 100% auto; .a { diff --git a/pages/category/index.vue b/pages/category/index.vue index aef3e7d..ddc287f 100644 --- a/pages/category/index.vue +++ b/pages/category/index.vue @@ -26,10 +26,10 @@ 热门分类 - - + + - TCL + {{item.name}} @@ -60,7 +60,7 @@ return { secondChose:'', menuList: [], - typeName: '空调', + typeName: '', goodsList: [], isChose: '', hotList: [], @@ -76,11 +76,14 @@ this.isChose = item.category_id; this.secondMenu = item.children; this.secondChose='' + this.hotList = item.children // this.secondChose = this.secondMenu[0].category_id; this.getSonList(this.isChose) }, choseSecondMenu(item){ this.secondChose = item.category_id; + this.typeName = item.name + this.getSonList(this.secondChose) }, getGoodsTypeList() { diff --git a/pages/goods/components/SkuPopup.vue b/pages/goods/components/SkuPopup.vue index 23abfbb..86c1215 100644 --- a/pages/goods/components/SkuPopup.vue +++ b/pages/goods/components/SkuPopup.vue @@ -73,19 +73,22 @@ const app = this const { goods: { goods_name, goods_image, skuList } } = app const skuData = [] - skuList.forEach(item => { - skuData.push({ - _id: item.id, - goods_sku_id: item.goods_sku_id, - goods_id: item.goods_id, - goods_name: goods_name, - image: item.image_url ? item.image_url : goods_image, - price: item.goods_price * 100, - stock: item.stock_num, - spec_value_ids: item.spec_value_ids, - sku_name_arr: app.getSkuNameArr(item.spec_value_ids) - }) - }) + if(skuList && skuList.length > 0){ + skuList.forEach(item => { + skuData.push({ + _id: item.id, + goods_sku_id: item.goods_sku_id, + goods_id: item.goods_id, + goods_name: goods_name, + image: item.image_url ? item.image_url : goods_image, + price: item.goods_price * 100, + stock: item.stock_num, + spec_value_ids: item.spec_value_ids, + sku_name_arr: app.getSkuNameArr(item.spec_value_ids) + }) + }) + } + return skuData }, @@ -118,16 +121,18 @@ const { goods: { specList } } = this const defaultData = [{ name: '默认', list: [{ name: '默认' }] }] const specData = [] - specList.forEach(group => { - const children = [] - group.valueList.forEach(specValue => { - children.push({ name: specValue.spec_value }) - }) - specData.push({ - name: group.spec_name, - list: children - }) - }) + if(specList && specList.length > 0){ + specList.forEach(group => { + const children = [] + group.valueList.forEach(specValue => { + children.push({ name: specValue.spec_value }) + }) + specData.push({ + name: group.spec_name, + list: children + }) + }) + } return specData.length ? specData : defaultData }, @@ -168,7 +173,7 @@ // 立即购买 buyNow(selectShop) { // 跳转到订单结算页 - this.$navTo('pages/checkout/index', { + this.$navTo('pages/sureOrder/index', { mode: 'buyNow', goodsId: selectShop.goods_id, goodsSkuId: selectShop.goods_sku_id, diff --git a/pages/goods/detail.vue b/pages/goods/detail.vue index 2d2d052..5626ed4 100644 --- a/pages/goods/detail.vue +++ b/pages/goods/detail.vue @@ -3,14 +3,15 @@ - + - + + Plus 分销 - 会员 + PRO会员 开通Plus - 分销会员 预计再省 + 分销会员预计再省 - + 立即开通 @@ -61,7 +63,7 @@ {{goods.goods_name}} - + {{goods.skuList[0].goods_sku_id}} @@ -90,7 +92,7 @@ - {{}} + {{addressInfo.region.province +'-'+addressInfo.region.city+'-'+addressInfo.region.region}} @@ -107,15 +109,12 @@ 商家来源:平台认证商户 - - + 服务 - - 枪色 1件 + + {{item.name}} @@ -123,12 +122,12 @@ 相关推荐 - + - + @@ -141,9 +140,7 @@ - - - + @@ -153,6 +150,7 @@ 客服 + @@ -178,7 +176,7 @@ - + @@ -189,7 +187,7 @@ 查看预约记录 - + 设置秒杀价格 @@ -232,33 +230,33 @@ - + - 夏普4T-M70H7DA 70英寸 4K 高清进口屏智能语音平板液晶电视机6575 + {{goods.goods_name}} - ¥4980 + ¥{{goods.goods_price_min}} - + - + 复制文案 - + - 微信好友 + @@ -301,26 +299,97 @@ setPrice: false, openDialog: false, goodsId: '', - goods: {}, + goods: { + skuList: [] + }, suggestGoodsList: [], userInfo: {}, addressList: [], addressInfo: {}, + serveList:[], + token:'', } }, onLoad(options) { + this.isPre = options.isPre + this.goodsId = options.goodsId this.pre_id = options.pre_id; this.goodsId=options.goodsId; - this.getGoodsDetail(options.goodsId) }, onShow() { - this.getAddressList() - this.getSuggestGoods() - this.userInfo = uni.getStorageSync('userInfo'); - + if(uni.getStorageSync('AccessToken')){ + this.getAddressList() + this.getSuggestGoods() + this.getServeList() + this.userInfo = uni.getStorageSync('userInfo'); + }else{ + this.userInfo = {} + } + this.getGoodsDetail() }, methods: { + copyText(val){ + // 获取要复制的文本内容 + let text = val; + + uni.setClipboardData({ + data: text, + success(res) { + console.log('成功复制到剪贴板'); + }, + fail(err) { + console.error('复制失败', err); + } + }); + + + }, + shareWechat(){ + uni.share({ + provider: "weixin", + scene: "WXSceneSession", + type: 2, + imageUrl: this.goods.goods_image, + success: function (res) { + console.log("success:" + JSON.stringify(res)); + }, + fail: function (err) { + console.log("fail:" + JSON.stringify(err)); + } + }); + }, + shareImg(){ + this.openDialog =true + this.shareType= 'share' + }, + preNow(){ + const that = this + let params={ + goods_id:that.goods.goods_id, + pre_id:1 + } + GoodsApi.presale(params).then(res => { + if (res.status == 200) { + that.$toast(res.message) + } + }) + .catch() + }, + getServeList(){ + const that = this + let params = { + goodsId:that.goodsId + } + return new Promise((resolve, reject) => { + GoodsApi.serveList(params).then(res => { + if (res.status == 200) { + that.serveList = res.data.list + } + }) + .catch() + }) + }, // 预约成功去列表 onKonw(){ uni.navigateTo({ @@ -346,9 +415,9 @@ const that = this return new Promise((resolve, reject) => { address.list().then(res => { - if (res.code == 200) { + if (res.status == 200) { that.addressList = res.data.list - console.log('58555559999') + console.log('58555559999',that.addressList) that.getDefaultAddress() } }) @@ -360,10 +429,12 @@ const that = this return new Promise((resolve, reject) => { address.defaultId().then(res => { - if (res.code == 200) { + if (res.status == 200) { for (var i = 0; i < that.addressList.length; i++) { if (res.data.defaultId == that.addressList[i].address_id) { - that.addressInfo = that.addressList[i] + that.addressInfo = that.addressList[i]; + + console.log(that.addressInfo,'获取地址') } } } @@ -371,17 +442,26 @@ .catch() }) }, + toSearch() { + uni.navigateTo({ + url: "/pages/search/index" + }) + }, choseSku() { this.showSkuPopup = true }, // 获取商品信息 - getGoodsDetail(goodsId) { + getGoodsDetail() { const that = this return new Promise((resolve, reject) => { - GoodsApi.detail(goodsId) + GoodsApi.detail(this.goodsId) .then(result => { - that.goods = result.data.detail; - that.allPicture = result.data.detail.goods_images.length + let info = result.data.detail; + info.content = info.content + .replace(/style=""/g,'') + .replace(/0?that.goods.skuList[0].goods_sku_id:''), that.goods.spec_type == 20 ? 1 : 1) .then(res => { if (res.status == 200) { that.$toast(res.message) @@ -436,9 +522,27 @@ .catch() }, buyNow() { + if(!uni.getStorageSync("AccessToken")) { + uni.navigateTo({ + url: "/pages/login/index" + }) + return ; + } // 立即下单 + console.log(this.token,'登录信息') + // if(!this.token){ + // this.$toast('请登录') + // uni.navigateTo({ + // url:'/pages/login/index' + // }) + // } + if(this.goods.stock_total==0){ + return this.$toast('库存不足,请选择其他商品购买') + } + const item = JSON.stringify(this.goods) + uni.navigateTo({ - url: '/pages/sureOrder/index?goodsInfo=' + JSON.stringify(this.goods) + url: '/pages/sureOrder/index?goodsID=' +encodeURIComponent(item) }) }, shareCancel() { @@ -451,8 +555,18 @@ .detail { width: 100%; height: 100%; + + &-content{ + padding: 30rpx; + font-size: 26rpx; + line-height: 50rpx; + width: 710rpx; + margin: 0 auto; + margin-top: 30rpx; + background-color: #fff; + box-sizing: border-box; + } } - .slot-wrap { width: 400rpx; margin-left: 60rpx; @@ -498,15 +612,26 @@ } .share { - display: flex; - justify-content: space-between; - margin-top: 28rpx; - + z-index: 22; + top: 128rpx; + width: 54rpx; + height: 54rpx; + position: absolute; + right: 30rpx; .sp { width: 54rpx; height: 54rpx; + display: none; + } + button{ + width: 100%; + height: 100%; + position: absolute; + left: 0; + top: 0; + z-index: 2; + opacity: 0; } - .shareIcon { width: 54rpx; height: 54rpx; @@ -709,12 +834,11 @@ .goodsDetail { .goodsName { width: 672rpx; - height: 80rpx; font-size: 28rpx; font-family: PingFang SC, PingFang SC; font-weight: 400; color: #000000; - line-height: 33rpx; + line-height: 50rpx; margin: 28rpx 0 0 28rpx; } @@ -931,10 +1055,10 @@ display: flex; flex-wrap: wrap; margin-top: 30rpx; - + padding-bottom: 20rpx; + overflow: hidden; .goodsItem { margin-right: 18rpx; - .img { width: 204rpx; height: 168rpx; @@ -957,10 +1081,9 @@ width: 184rpx; height: 80rpx; font-size: 28rpx; - font-family: PingFang SC, PingFang SC; font-weight: 400; color: #000000; - line-height: 33rpx; + line-height: 40rpx; display: -webkit-box; overflow: hidden; text-overflow: ellipsis; @@ -1020,25 +1143,33 @@ .footerCus { margin-right: 44rpx; - + text-align: center; + position: relative; .cusIcon { width: 38rpx; height: 38rpx; - + margin: 0 auto; image { width: 100%; height: 100%; } } - + button{ + width: 100%; + height: 100%; + position: absolute; + left: 0; + top: 0; + z-index: 2; + opacity: 0; + } .customer { width: 40rpx; height: 28rpx; font-size: 20rpx; - font-family: PingFang SC, PingFang SC; font-weight: 400; color: #3D3D3D; - line-height: 28rpx; + line-height: 40rpx; } .car { diff --git a/pages/index/index.vue b/pages/index/index.vue index 91fe299..a2d57d3 100644 --- a/pages/index/index.vue +++ b/pages/index/index.vue @@ -243,45 +243,52 @@ - + - 昆明湖店·YN_k121 + {{cityInfo.shop_name}} 营业中 - 5.0 - 营业时间:9:00-21:30 + 营业时间:{{cityInfo.shop_hours}} - - 手机选购 - - - - - 咨询 + + + {{item}} - - - - - - - 电话 + + + + + + + 咨询 + + + + + + + + + 电话 + + @@ -289,15 +296,15 @@ - 昆明市盘龙区盘江路瀑布公园广场 + {{cityInfo.address}} - 距地铁2号线大道站2号口600m + {{cityInfo.summary}} - + 附近停车场 @@ -335,8 +342,8 @@ - - + + @@ -353,15 +360,15 @@ - - Shark特 + + {{cityInfo.evaluate.nickname}} 1天前 - 非常棒,讲解细致,下次还来! + {{cityInfo.evaluate.content}} @@ -377,8 +384,8 @@ - - + + @@ -393,7 +400,15 @@ - + + + + + @@ -440,6 +455,7 @@ ], goodsType: [], + cityInfo:{} } }, onShow() { @@ -447,9 +463,22 @@ this.getRankingList(); this.getbrandList(); this.getSeckill(); - this.getSuggest() + this.getSuggest(); + this.getCityInfo() }, methods: { + getCityInfo(){ + const that =this + GoodsApi.cityInfo() + .then(res => { + if (res.status == 200) { + that.cityInfo = res.data + } + + + }) + .finally(() => {}) + }, getTypeList() { const that = this GoodsApi.typeList() @@ -563,6 +592,12 @@ url: '/pages/search/index' }) }, + toPark(){ + // 停车指引 + uni.navigateTo({ + url: '/pages/news/park/index' + }) + }, goDetails(item) { uni.navigateTo({ url: '/pages/goods/detail?goodsId=' + item.goods_id @@ -1254,7 +1289,7 @@ display: block; width: 90rpx; margin: 0 auto; - text-align: center; + text-align: left; margin-top: 5rpx; } } @@ -1660,7 +1695,7 @@ font-weight: 600; text-align: left; white-space: nowrap; - line-height: 36rpx; + line-height: 50rpx; } .text_16 { @@ -1740,7 +1775,7 @@ .shopInfo { width: 698rpx; - height: 400rpx; + min-height: 400rpx; background: linear-gradient(180deg, rgba(255, 255, 255, 0.86) 0%, #FFFFFF 100%); border-radius: 8rpx 8rpx 8rpx 8rpx; opacity: 1; @@ -1801,23 +1836,49 @@ .tip { display: flex; - + justify-content: space-between; margin-top: 10rpx; - - .tipItem { - margin-right: 10rpx; - width: 116rpx; - height: 42rpx; - background: #F5F5F5; - border-radius: 4rpx 4rpx 4rpx 4rpx; - opacity: 1; - text-align: center; - line-height: 42rpx; - font-size: 24rpx; - font-weight: 400; - color: #818181; + .tipleft{ + display: flex; + .tipItem { + margin-right: 10rpx; + width: 116rpx; + height: 42rpx; + background: #F5F5F5; + border-radius: 4rpx 4rpx 4rpx 4rpx; + opacity: 1; + text-align: center; + line-height: 42rpx; + font-size: 24rpx; + font-weight: 400; + color: #818181; + } + } + .tipRight{ + display: flex; + align-items: center; + .ask { + margin-left: 16rpx; + + position: relative; + top: -20rpx; + + .weChat { + width: 32rpx; + height: 32rpx; + } + + .askText { + height: 28rpx; + font-size: 20rpx; + font-weight: 400; + color: #989898; + line-height: 28rpx; + } + } } + .al { width: 0rpx; @@ -1827,25 +1888,7 @@ margin-left: 8rpx; } - .ask { - margin-left: 16rpx; - - position: relative; - top: -20rpx; - - .weChat { - width: 32rpx; - height: 32rpx; - } - - .askText { - height: 28rpx; - font-size: 20rpx; - font-weight: 400; - color: #989898; - line-height: 28rpx; - } - } + } .hline { @@ -1871,7 +1914,7 @@ } .adInfo { - height: 40rpx; + min-height: 40rpx; font-size: 28rpx; font-family: PingFang SC, PingFang SC; font-weight: 400; diff --git a/pages/news/article/classify.vue b/pages/news/article/classify.vue index 15a8fa7..af2161c 100644 --- a/pages/news/article/classify.vue +++ b/pages/news/article/classify.vue @@ -64,7 +64,7 @@ uni.showToast({ title: "提交成功" }) - uni.$emit("reloadClasssify") + uni.$emit("reloadClasssify",{msg:'页面更新'}) setTimeout(()=>{ uni.navigateBack({ delta: 1 diff --git a/pages/news/coupon/list.vue b/pages/news/coupon/list.vue index f5cadc9..4342303 100644 --- a/pages/news/coupon/list.vue +++ b/pages/news/coupon/list.vue @@ -5,7 +5,7 @@ :is-scroll="false" v-model="tabIndex" @change="change"> - + {{item.reduce_price}} {{item.discount}}折 有效期:{{item.end_time}} @@ -39,6 +39,7 @@ export default { data() { return { + choseId:'', list: [{ name: '未使用', val:'isUsable' @@ -50,13 +51,23 @@ val:'isExpire' }], tabIndex: 0, - couponList:[] + couponList:[], + isChose:false } }, + onLoad(o){ + this.isChose = o.chose + }, onShow() { this.getCoupon(this.tabIndex) }, methods: { + choseItem(item){ + if(this.isChose){ + uni.setStorageSync('couponId',item.coupon_id) + uni.navigateBack() + } + }, getCoupon(e) { const that = this let param={ diff --git a/pages/news/park/recordHistory.vue b/pages/news/park/recordHistory.vue index 404de47..f5ab41b 100644 --- a/pages/news/park/recordHistory.vue +++ b/pages/news/park/recordHistory.vue @@ -195,4 +195,4 @@ } } } - + diff --git a/pages/news/rules/rulesList.vue b/pages/news/rules/rulesList.vue index dabe8a8..1a9cf99 100644 --- a/pages/news/rules/rulesList.vue +++ b/pages/news/rules/rulesList.vue @@ -1,39 +1,39 @@ \ No newline at end of file diff --git a/pages/search/index.vue b/pages/search/index.vue index a6848fb..e6539db 100644 --- a/pages/search/index.vue +++ b/pages/search/index.vue @@ -79,10 +79,13 @@ this.searchList = uni.getStorageSync('searchList') this.searchList = Array.from(new Set(this.searchList)); } - + this.getHot() }, methods: { + getHot(){ + + }, searchGoods(item){ this.searchList.push(this.searchValue) this.searchList = Array.from(new Set(this.searchList)); diff --git a/pages/sureOrder/index.vue b/pages/sureOrder/index.vue index 68675ae..8d0e35d 100644 --- a/pages/sureOrder/index.vue +++ b/pages/sureOrder/index.vue @@ -23,7 +23,7 @@ - + 花梨服务站 @@ -33,9 +33,9 @@ - {{addressInfo.name}} + {{addressInfo.name}} {{addressInfo.region.province +addressInfo.region.city+addressInfo.region.region}} - + 距您16.39km @@ -94,7 +94,7 @@ - + + @@ -121,14 +121,14 @@ - + - iphone13 绿色 128GB + {{goodsInfo.goods_name}} - ¥ 7599 + ¥ {{goodsInfo.goods_price_min}} @@ -137,13 +137,11 @@ - + 留言 + - - 建议留言前与客服沟通确认 - - + @@ -151,7 +149,7 @@ 商品总额 - ¥7599 + ¥{{goodsInfo.goods_price_min}} @@ -159,7 +157,7 @@ 运费 - ¥7599 + ¥{{goodsInfo.goods_price_min}} @@ -174,8 +172,8 @@ 优惠券 - - 0张可用 + + {{couponList.length}}张可用 @@ -188,7 +186,7 @@ 共1件,合计: - ¥7664 + ¥{{goodsInfo.goods_price_min}} @@ -204,30 +202,32 @@ - - - 找微信好友代付 + + + + 余额支付 + + - - + - + + --> 应付款 - 7640 + {{goodsInfo.goods_price_min}} - + 提交订单 @@ -239,9 +239,16 @@ import img from "@/static/member/head.png" import * as storeShop from '@/api/shop.js' import * as address from '@/api/address.js' + import * as cashier from '@/api/cashier/index.js' + import * as CouponApi from '@/api/coupon' + import { + Wechat + } from '@/core/payment' export default { data() { return { + remark: '', + payType: 'weChat', buyType: 'sm', background: { background: 'url(' + img + ') center top no-repeat', @@ -250,31 +257,61 @@ goodsInfo: {}, shopInfo: {}, addressList: [], - addressInfo: {} + addressInfo: {}, + payMethList: [], + orderID: '', + couponList: [], } }, onLoad(options) { - if (options.goodsInfo) { - this.goodsInfo = JSON.parse(options.goodsInfo) - } + console.log(options, 'kkkkkk') + // if (options.goodsInfo) { + let goodsInfo = options.goodsID; + console.log(goodsInfo, '5555555', typeof(goodsInfo)); + this.goodsInfo = JSON.parse(decodeURIComponent(goodsInfo)) + console.log(this.goodsInfo, '666666'); + // } }, onShow() { - this.getGoodsInfo() + this.getShopInfo() this.getAddressList(); + this.orderSubmit() + this.getCoupon() }, methods: { + getCoupon() { + const that =this + let param = { + dataType:'isUsable' + } + CouponApi.myCouponList(param) + .then(res => { + that.couponList = res.data.list.data + }) + .finally() + }, + choseCoupon() { + // 选择优惠券 + uni.navigateTo({ + url: '/pages/news/coupon/list?chose=true', + }) + }, + chosePayType(item) { + this.payType = item.method + }, choseType(val) { this.buyType = val }, getDefaultAddress() { + const that = this return new Promise((resolve, reject) => { address.defaultId().then(res => { - if (res.code == 200) { + if (res.status == 200) { for (var i = 0; i < that.addressList.length; i++) { if (res.data.defaultId == that.addressList[i].address_id) { that.addressInfo = that.addressList[i] - that.getOrderInfo() + console.log(that.addressInfo, '获取收货地址') } } } @@ -282,23 +319,11 @@ .catch() }) }, - getOrderInfo() { - const that = this - return new Promise((resolve, reject) => { - address.list().then(res => { - if (res.code == 200) { - that.addressList = res.data.list - that.getDefaultAddress() - } - }) - .catch() - }) - }, getAddressList() { const that = this return new Promise((resolve, reject) => { address.list().then(res => { - if (res.code == 200) { + if (res.status == 200) { that.addressList = res.data.list that.getDefaultAddress() } @@ -306,7 +331,7 @@ .catch() }) }, - getGoodsInfo() { + getShopInfo() { return new Promise((resolve, reject) => { storeShop.list().then(res => { console.log(res, '获取店铺信息') @@ -316,25 +341,131 @@ }, orderSubmit() { - const that = this + const that = this; + console.log(that.goodsInfo, '55555') let params = { - mode: '结算模式', - delivery: '配送方式(10快递配送 20上门自提', + mode: 'buyNow', + delivery: '10', couponId: '', isUsePoints: 0, - remark: '留言', + remark: that.remark, shopId: '', - linkman: '姓名', - phone: '手机哈', - goodsId: '商品id', + linkman: '', + phone: '', + goodsId: that.goodsInfo.goods_id, goodsNum: 1, - goodsSkuId: '', + goodsSkuId: that.goodsInfo.skuList[0].goods_sku_id, cartIds: '' } - order.submit(params) + order.submit('buyNow', params) + .then(res => { + if (res.status == 200) { + that.orderId = res.data.orderId + that.getOrderInfoPay(res.data.orderId) + } + }) + .catch() + }, + getOrderInfoPay(val) { + cashier.orderInfo(val).then(res => { + if (res.status == 200) { + this.payMethList = res.data.paymentMethods + } + }) + .catch() + }, + onShowSuccess(res) { + this.$toast(message || '订单支付成功') + uni.navigateTo({ + url: '/pages/news/recycling/orderList' + }) + }, + orderPay() { + const that = this + if (that.payType == 'balance') { + that.payBanlance() + return + } + cashier.orderPay(that.orderID).then(res => { + if (res.status == 200) { + + let paymentData = res.data.payment + Wechat.payment({ + orderKey: res.data.payment.out_trade_no, + ...paymentData + }) + .then((result) => { + console.log(result) + that.onShowSuccess(result) + }) + .catch(err => { + console.log(err) + }) + + + } + }) + .catch() + + }, + payBanlance() { + const that = this + let params = { + extra: {}, + method: 'balance', + client: 'weChat' + } + cashier.orderPay(that.orderID, params).then(res => { + that.$toast(res.message) + if (res.status == 200) { + + setTimeout(() => { + uni.navigateTo({ + url: '/pages/news/recycling/orderList' + }) + }, 1000) + + } + }) + .catch() + + }, + // getOrderInfo() { + // const that = this + // let params = { + // orderId: 10202, + // client: 'wechat' + // } + // cashier.orderInfo(params) + // .then(res => { + // if (res.status == 200) { + // that.payOrderInfo() + // } + // }) + // .catch() + // }, + payOrderInfo() { + const that = this + let form = { + client: 'wechat', + method: 'wechat', + extra: {} + } + cashier.orderInfo(10202, form) .then(res => { if (res.status == 200) { - // that.$toast(res.message) + + let paymentData = res.data.payment + Wechat.payment({ + orderKey: res.data.payment.out_trade_no, + ...paymentData + }) + .then((result) => { + console.log(result) + }) + .catch(err => { + console.log(err) + }) } }) .catch() @@ -607,7 +738,7 @@ .goodsDetail { width: 694rpx; - height: 266rpx; + min-height: 266rpx; background: #FFFFFF; border-radius: 10rpx 10rpx 10rpx 10rpx; opacity: 1; @@ -656,7 +787,7 @@ margin-left: 20rpx; .goodsName { - height: 40rpx; + min-height: 40rpx; font-size: 28rpx; font-family: PingFang SC, PingFang SC; font-weight: 400; diff --git a/pages/user/index.vue b/pages/user/index.vue index 572e490..9bd66d5 100644 --- a/pages/user/index.vue +++ b/pages/user/index.vue @@ -127,7 +127,7 @@ - + 235 @@ -486,6 +486,11 @@ this.getSuggest() }, methods: { + preList(){ + uni.navigateTo({ + url:'/pages/news/park/recordHistory' + }) + }, getSuggest() { // 获取推荐商品 const that = this