Commit 38709b6662a3719006dbbc6bb4a9dc3e111e8b02
Merge branch 'dev' of http://git.vipzhuang.cn/wxd/MShopWeApp into dev
Showing
12 changed files
with
980 additions
and
690 deletions
custom-tab-bar/index.js
| ... | ... | @@ -12,7 +12,6 @@ Component({ |
| 12 | 12 | |
| 13 | 13 | lifetimes: { |
| 14 | 14 | attached: function() { |
| 15 | - | |
| 16 | 15 | var th=this; |
| 17 | 16 | getApp().promiseGet("/api/weshop/storeDistribut/get/"+os.stoid,{}).then(rs=>{ |
| 18 | 17 | var dis=rs.data.data; |
| ... | ... | @@ -99,7 +98,7 @@ Component({ |
| 99 | 98 | //设置自定义页面的列表 |
| 100 | 99 | set_list:function(data){ |
| 101 | 100 | var itemList = data.data; |
| 102 | - itemList = JSON.parse(itemList); | |
| 101 | + itemList = JSON.parse(itemList); | |
| 103 | 102 | this.setData({ |
| 104 | 103 | list:itemList, |
| 105 | 104 | backgroundColor: data.bkcolor, | ... | ... |
packageA/pages/cart2_ser/cart2_ser.js
| ... | ... | @@ -477,16 +477,34 @@ Page({ |
| 477 | 477 | getApp().showWarning("未找到门店"); |
| 478 | 478 | return false; |
| 479 | 479 | } |
| 480 | - var goods = { | |
| 481 | - 'card_id': gg.service_id, | |
| 482 | - 'itemid': gg.erpItemID, | |
| 483 | - 'qty': gg.goods_num, | |
| 484 | - 'price': gg.money, | |
| 485 | - 'pickup_id': gg.pick_id, | |
| 486 | - 'pickup_keyid': list[i].keyid, | |
| 487 | - 'prom_type': gg.prom_type, //促销活动类型 | |
| 488 | - 'prom_id': gg.prom_id, //促销活动id | |
| 489 | - }; | |
| 480 | + | |
| 481 | + | |
| 482 | + if (gg.prom_type == 1 && gg.is_pd_normal == 0) { | |
| 483 | + // 秒杀活动购买 | |
| 484 | + var goods = { | |
| 485 | + 'card_id': gg.service_id, | |
| 486 | + 'itemid': gg.erpItemID, | |
| 487 | + 'qty': gg.goods_num, | |
| 488 | + 'price': gg.money, | |
| 489 | + 'pickup_id': gg.pick_id, | |
| 490 | + 'pickup_keyid': list[i].keyid, | |
| 491 | + 'prom_type': gg.prom_type, //促销活动类型 | |
| 492 | + 'prom_id': gg.prom_id, //促销活动id | |
| 493 | + }; | |
| 494 | + } else { | |
| 495 | + // 普通购买 | |
| 496 | + var goods = { | |
| 497 | + 'card_id': gg.service_id, | |
| 498 | + 'itemid': gg.erpItemID, | |
| 499 | + 'qty': gg.goods_num, | |
| 500 | + 'price': gg.money, | |
| 501 | + 'pickup_id': gg.pick_id, | |
| 502 | + 'pickup_keyid': list[i].keyid, | |
| 503 | + }; | |
| 504 | + } | |
| 505 | + | |
| 506 | + | |
| 507 | + | |
| 490 | 508 | //--导购分享过来的id-- |
| 491 | 509 | if (gg.guide_id) { |
| 492 | 510 | goods.guide_id = gg.guide_id; | ... | ... |
packageA/pages/details_serviceCard/details_serviceCard.js
| ... | ... | @@ -228,7 +228,7 @@ Page({ |
| 228 | 228 | |
| 229 | 229 | |
| 230 | 230 | // 再来一单 |
| 231 | - buy2(t) { | |
| 231 | + buy2: async function(t) { | |
| 232 | 232 | let details = this.data.details; |
| 233 | 233 | var th = this; |
| 234 | 234 | var ind = 1; // 1:加入购物车 |
| ... | ... | @@ -236,7 +236,7 @@ Page({ |
| 236 | 236 | // var action= t.currentTarget.dataset.action; |
| 237 | 237 | var action = 'add'; // |
| 238 | 238 | // if(!ind) ind = t.currentTarget.dataset.openspecmodal_ind; |
| 239 | - | |
| 239 | + var user_id = getApp().globalData.user_id; | |
| 240 | 240 | th.setData({ |
| 241 | 241 | open_ind_store: ind |
| 242 | 242 | }); |
| ... | ... | @@ -261,95 +261,172 @@ Page({ |
| 261 | 261 | // th.buyNow(newd); |
| 262 | 262 | } else { |
| 263 | 263 | |
| 264 | - var newd = { | |
| 265 | - // service_id: th.data.data.id, | |
| 266 | - // service_sn:th.data.data.service_sn, | |
| 267 | - // service_name:th.data.data.goods_name, | |
| 268 | - // goods_num: th.data.goodsInputNum, | |
| 269 | - // pick_id: th.data.sto_sele_id, | |
| 270 | - // user_id:oo.user_id, | |
| 271 | - // store_id:os.stoid, | |
| 272 | - // money:th.data.data.shop_price, | |
| 273 | - | |
| 274 | - service_id: details.list[0].card_id, | |
| 275 | - service_sn: details.list[0].service_sn, | |
| 276 | - service_name: details.list[0].service_name, | |
| 277 | - goods_num: details.list[0].qty, | |
| 278 | - pick_id: details.list[0].pickup_id, | |
| 279 | - user_id: this.data.userInfo.user_id, | |
| 280 | - store_id: app.globalData.setting.stoid, | |
| 281 | - money: details.list[0].price, | |
| 282 | - }; | |
| 283 | - if (getApp().globalData.guide_id) { | |
| 284 | - newd['guide_id'] = getApp().globalData.guide_id; | |
| 285 | - newd['guide_type'] = 0; | |
| 286 | - }; | |
| 287 | - // 秒杀:单独购买的情况下,加入购物车显示的是零售价,否则显示秒杀活动价 | |
| 288 | - if(details.list[0].prom_type == 1) { | |
| 289 | - newd['prom_type'] = details.list[0].prom_type; | |
| 290 | - newd['prom_id'] = details.list[0].prom_id; | |
| 291 | - // if(th.data.openSpecModal_flash_normal) { | |
| 292 | - // newd['money'] = th.data.data.shop_price; | |
| 293 | - // newd['is_pd_normal'] = 1; | |
| 294 | - // } else { | |
| 295 | - // newd['money'] = th.data.prom_price; | |
| 296 | - // }; | |
| 297 | - }; | |
| 298 | - | |
| 264 | + var len = details.list.length; | |
| 265 | + // 底导航购物车红点显示的数量 | |
| 266 | + var c_num = 0; | |
| 267 | + // 多商品 | |
| 268 | + for (let i = 0; i < len; i++) { | |
| 269 | + | |
| 270 | + var newd = { | |
| 271 | + // service_id: th.data.data.id, | |
| 272 | + // service_sn:th.data.data.service_sn, | |
| 273 | + // service_name:th.data.data.goods_name, | |
| 274 | + // goods_num: th.data.goodsInputNum, | |
| 275 | + // pick_id: th.data.sto_sele_id, | |
| 276 | + // user_id:oo.user_id, | |
| 277 | + // store_id:os.stoid, | |
| 278 | + // money:th.data.data.shop_price, | |
| 279 | + | |
| 280 | + service_id: details.list[i].card_id, | |
| 281 | + service_sn: details.list[i].service_sn, | |
| 282 | + service_name: details.list[i].service_name, | |
| 283 | + goods_num: details.list[i].qty, | |
| 284 | + pick_id: details.list[i].pickup_id, | |
| 285 | + user_id: user_id, | |
| 286 | + store_id: app.globalData.setting.stoid, | |
| 287 | + money: details.list[i].price, | |
| 288 | + }; | |
| 289 | + if (getApp().globalData.guide_id) { | |
| 290 | + newd['guide_id'] = getApp().globalData.guide_id; | |
| 291 | + newd['guide_type'] = 0; | |
| 292 | + }; | |
| 293 | + // 秒杀:单独购买的情况下,加入购物车显示的是零售价,否则显示秒杀活动价 | |
| 294 | + if(details.list[i].prom_type == 1) { | |
| 295 | + newd['prom_type'] = details.list[i].prom_type; | |
| 296 | + newd['prom_id'] = details.list[i].prom_id; | |
| 297 | + }; | |
| 299 | 298 | |
| 300 | - //----先看会员在购物车中是否加入了该商品----- | |
| 301 | - app.request.get("/api/weshop/cartService/page", { | |
| 302 | - data: { | |
| 303 | - store_id: app.globalData.setting.stoid, | |
| 304 | - user_id: this.data.userInfo.user_id, | |
| 305 | - service_id: details.list[0].card_id, | |
| 306 | - pick_id: details.list[0].pickup_id, | |
| 307 | - }, | |
| 308 | - success: function(re) { | |
| 309 | - | |
| 310 | - //-------如果购物车中有相关的数据--------- | |
| 311 | - if (re.data.data.total > 0) { | |
| 312 | - var item = re.data.data.pageData[0]; | |
| 313 | - var updata = { | |
| 314 | - id: item.id, | |
| 315 | - goods_num: details.list[0].qty + item.goods_num, | |
| 316 | - money: details.list[0].price, | |
| 317 | - store_id: app.globalData.setting.stoid, | |
| 318 | - }; | |
| 299 | + var prom_id = details.list[i].prom_id > 0 ? details.list[i].prom_id : 0; | |
| 300 | + var card_id = details.list[i].card_id; | |
| 301 | + var prom_type = details.list[i].prom_type > 0 ? details.list[i].prom_type : 0; | |
| 302 | + var is_pd_normal = details.list[i].is_pd_normal; | |
| 303 | + // 库存 | |
| 304 | + var redisNums = 0; | |
| 305 | + // 限购数 | |
| 306 | + var limitNum = 0; | |
| 307 | + // 已购买数量 | |
| 308 | + var boughtNum = 0; | |
| 309 | + | |
| 310 | + // 秒杀活动中购买 | |
| 311 | + if (prom_type == 1 && !is_pd_normal) { | |
| 312 | + | |
| 313 | + // 获取已购数量 | |
| 314 | + await getApp().request.promiseGet("/api/weshop/rechargeServicelist/getUserBuyGoodsNum?store_id="+os.stoid+"&user_id="+getApp().globalData.user_id+"&card_id="+card_id+"&prom_type="+prom_type+"&prom_id="+prom_id, { | |
| 315 | + }).then(res => { | |
| 316 | + boughtNum = !res.data.data.promcardbuynum ? 0 : res.data.data.promcardbuynum; | |
| 317 | + }); | |
| 318 | + | |
| 319 | + // 获取库存 | |
| 320 | + await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + os.stoid + "/1/" + prom_id, {}).then(res => { | |
| 321 | + if (res.data.code == 0) { | |
| 322 | + redisNums = !res.data.data ? 0 : res.data.data; | |
| 323 | + }; | |
| 324 | + }); | |
| 319 | 325 | |
| 320 | - if (getApp().globalData.guide_id) { | |
| 321 | - updata['guide_id'] = getApp().globalData.guide_id; | |
| 322 | - updata['guide_type'] = 1; | |
| 323 | - } | |
| 324 | - getApp().request.put("/api/weshop/cartService/update", { | |
| 325 | - data: updata, | |
| 326 | - success: function(t) { | |
| 327 | - // getApp().my_warnning('加入购物车成功', 1, th, 450); | |
| 328 | - var c_num = th.data.cartGoodsNum + th.data.goodsInputNum; | |
| 329 | - th.setData({ | |
| 330 | - cartGoodsNum: c_num | |
| 326 | + // 获取限购数 | |
| 327 | + var is_end = 1; | |
| 328 | + await getApp().request.promiseGet("/api/ms/flash_sale/getNew/" + os.stoid + "/" + user_id + "/" + prom_id, {}).then(res => { | |
| 329 | + if (res.data.code == 0) { | |
| 330 | + is_end = res.data.data.is_end; | |
| 331 | + limitNum = res.data.data.buy_limit; | |
| 332 | + } | |
| 333 | + }); | |
| 334 | + // 判断活动是否结束 | |
| 335 | + if (is_end == 1) { | |
| 336 | + wx.showModal({ | |
| 337 | + title: details.list[i].service_name + '\n\t活动已经结束', | |
| 331 | 338 | }); |
| 332 | - app.goto('/pages/cart/cart/cart'); | |
| 333 | - // th.closeSpecModal(); | |
| 339 | + return false; | |
| 334 | 340 | } |
| 335 | - }); | |
| 336 | - } else { | |
| 337 | 341 | |
| 338 | - getApp().request.post("/api/weshop/cartService/save", { | |
| 339 | - data: newd, | |
| 340 | - success: function(t) { | |
| 341 | - // getApp().my_warnning('加入购物车成功', 1, th, 450); | |
| 342 | - var c_num = th.data.cartGoodsNum + th.data.goodsInputNum; | |
| 343 | - th.setData({ | |
| 344 | - cartGoodsNum: c_num | |
| 342 | + | |
| 343 | + var snum = limitNum - boughtNum; | |
| 344 | + if (snum <= 0) { | |
| 345 | + wx.showModal({ | |
| 346 | + title: '超出活动限购数量', | |
| 347 | + }); | |
| 348 | + return false; | |
| 349 | + } | |
| 350 | + | |
| 351 | + } | |
| 352 | + | |
| 353 | + | |
| 354 | + //----先看会员在购物车中是否加入了该商品----- | |
| 355 | + app.request.get("/api/weshop/cartService/page", { | |
| 356 | + data: { | |
| 357 | + store_id: app.globalData.setting.stoid, | |
| 358 | + user_id: user_id, | |
| 359 | + service_id: details.list[i].card_id, | |
| 360 | + pick_id: details.list[i].pickup_id, | |
| 361 | + }, | |
| 362 | + success: function(re) { | |
| 363 | + //-------如果购物车中有相关的数据--------- | |
| 364 | + if (re.data.data.total > 0) { | |
| 365 | + var item = re.data.data.pageData[0]; | |
| 366 | + var totalNum = details.list[i].qty + item.goods_num; | |
| 367 | + | |
| 368 | + if (prom_type == 1 && !is_pd_normal) { | |
| 369 | + // 秒杀购物车购买 修正数量 剩余购买数量 | |
| 370 | + var snum = limitNum - boughtNum; | |
| 371 | + | |
| 372 | + if (totalNum >= redisNums){ | |
| 373 | + if (redisNums > snum) { | |
| 374 | + totalNum = snum; | |
| 375 | + } else { | |
| 376 | + totalNum = redisNums; | |
| 377 | + } | |
| 378 | + } else { | |
| 379 | + if (totalNum > snum) | |
| 380 | + totalNum = snum; | |
| 381 | + } | |
| 382 | + } | |
| 383 | + | |
| 384 | + var updata = { | |
| 385 | + id: item.id, | |
| 386 | + goods_num: totalNum, | |
| 387 | + money: details.list[i].price, | |
| 388 | + store_id: app.globalData.setting.stoid, | |
| 389 | + }; | |
| 390 | + | |
| 391 | + if (getApp().globalData.guide_id) { | |
| 392 | + updata['guide_id'] = getApp().globalData.guide_id; | |
| 393 | + updata['guide_type'] = 1; | |
| 394 | + } | |
| 395 | + | |
| 396 | + getApp().request.put("/api/weshop/cartService/update", { | |
| 397 | + data: updata, | |
| 398 | + success: function(t) { | |
| 399 | + // getApp().my_warnning('加入购物车成功', 1, th, 450); | |
| 400 | + c_num += th.data.cartGoodsNum + th.data.goodsInputNum; | |
| 401 | + th.setData({ | |
| 402 | + cartGoodsNum: c_num | |
| 403 | + }); | |
| 404 | + | |
| 405 | + // th.closeSpecModal(); | |
| 406 | + } | |
| 407 | + }); | |
| 408 | + | |
| 409 | + | |
| 410 | + } else { | |
| 411 | + | |
| 412 | + getApp().request.post("/api/weshop/cartService/save", { | |
| 413 | + data: newd, | |
| 414 | + success: function(t) { | |
| 415 | + // getApp().my_warnning('加入购物车成功', 1, th, 450); | |
| 416 | + c_num += th.data.cartGoodsNum + th.data.goodsInputNum; | |
| 417 | + th.setData({ | |
| 418 | + cartGoodsNum: c_num | |
| 419 | + }); | |
| 420 | + | |
| 421 | + // th.closeSpecModal(); | |
| 422 | + } | |
| 345 | 423 | }); |
| 346 | - app.goto('/pages/cart/cart/cart'); | |
| 347 | - // th.closeSpecModal(); | |
| 348 | 424 | } |
| 349 | - }); | |
| 350 | - } | |
| 351 | - } | |
| 352 | - }); | |
| 425 | + } | |
| 426 | + }); | |
| 427 | + | |
| 428 | + } | |
| 429 | + app.goto('/pages/cart/cart/cart'); | |
| 353 | 430 | |
| 354 | 431 | } |
| 355 | 432 | }, | ... | ... |
packageA/pages/goodsInfo/goodsInfo.js
| ... | ... | @@ -447,7 +447,7 @@ Page({ |
| 447 | 447 | sto_sele_name: e.pickup_name, |
| 448 | 448 | sto_sele_id: e.pickup_id, |
| 449 | 449 | sto_sele_distr: e.distr_type, |
| 450 | - sto_sele_keyid:e.keyid, | |
| 450 | + sto_sele_keyid:e.keyid, | |
| 451 | 451 | }) |
| 452 | 452 | } |
| 453 | 453 | } |
| ... | ... | @@ -562,6 +562,9 @@ Page({ |
| 562 | 562 | // <---- 秒杀 |
| 563 | 563 | |
| 564 | 564 | |
| 565 | + | |
| 566 | + | |
| 567 | + | |
| 565 | 568 | |
| 566 | 569 | |
| 567 | 570 | |
| ... | ... | @@ -826,21 +829,7 @@ Page({ |
| 826 | 829 | }); |
| 827 | 830 | }, |
| 828 | 831 | |
| 829 | - //获取redis中的数量 | |
| 830 | - async getactLen(func) { | |
| 831 | - var r_num = 0, | |
| 832 | - prom_type = this.data.prom_type, | |
| 833 | - prom_id = this.data.prom_id; | |
| 834 | - await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + os.stoid + "/" + prom_type + "/" + prom_id, { | |
| 835 | - 1: 1 | |
| 836 | - }).then(res => { | |
| 837 | - var em = res; | |
| 838 | - if (em.data.code == 0) { | |
| 839 | - r_num = em.data.data; | |
| 840 | - } | |
| 841 | - }) | |
| 842 | - func(r_num); | |
| 843 | - }, | |
| 832 | + | |
| 844 | 833 | |
| 845 | 834 | //------------加入购物车-------------- |
| 846 | 835 | addCart: async function(t) { |
| ... | ... | @@ -848,8 +837,7 @@ Page({ |
| 848 | 837 | var ind = t.currentTarget.dataset.openSpecModal_ind; |
| 849 | 838 | var action= t.currentTarget.dataset.action; |
| 850 | 839 | if(!ind) ind = t.currentTarget.dataset.openspecmodal_ind; |
| 851 | - // 活动ID | |
| 852 | - var prom_id = th.data.prom_id; | |
| 840 | + | |
| 853 | 841 | th.setData({ |
| 854 | 842 | open_ind_store: ind |
| 855 | 843 | }); |
| ... | ... | @@ -859,145 +847,96 @@ Page({ |
| 859 | 847 | return false; |
| 860 | 848 | }; |
| 861 | 849 | |
| 850 | + // 库存 | |
| 851 | + var redisNums = 0; | |
| 852 | + // 限购数 | |
| 853 | + var limitNum = 0; | |
| 854 | + // 已购买数量 | |
| 855 | + var boughtNum = 0; | |
| 862 | 856 | |
| 863 | - if(this.data.prom_type == 1) { | |
| 864 | - | |
| 865 | - this.data.sele_g.viplimited = this.data.sele_g.buy_limit; | |
| 866 | - | |
| 867 | - // 每人限购数 | |
| 868 | - th.data.sele_g.viplimited = th.data.sele_g.buy_limit; | |
| 869 | - | |
| 870 | - // 已经付款的单数 | |
| 871 | - var gd_buy_num = !th.data.sele_g.buy_num ? 0 : th.data.sele_g.buy_num; | |
| 872 | - | |
| 873 | - // 检查redis库存量 | |
| 874 | - var redisNum = 0; | |
| 875 | - await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + os.stoid + "/1/" + prom_id, {}).then(res => { | |
| 876 | - if (res.data.code == 0) { | |
| 877 | - redisNum = !res.data.data ? 0 : res.data.data; | |
| 878 | - }; | |
| 879 | - }); | |
| 880 | - | |
| 881 | - // 获取购物车同款数量 判断是否超库存 | |
| 882 | - var cartGoodsNum = 0; | |
| 883 | - await getApp().request.promiseGet("/api/weshop/cartService/page?store_id="+os.stoid+"&user_id="+oo.user_id+"&service_id="+th.data.data.id+"&pick_id="+th.data.sto_sele_id, | |
| 884 | - { }).then(res => { | |
| 885 | - if (res.data.data.pageData.length > 0) { | |
| 886 | - const tmpObj = res.data.data.pageData[0]; | |
| 887 | - cartGoodsNum = !tmpObj.goods_num ? 0 : tmpObj.goods_num; | |
| 888 | - } | |
| 889 | - | |
| 890 | - }); | |
| 891 | - | |
| 892 | - // 有库存的情况下,走秒杀活动流程 否则 走正常购买流程 | |
| 893 | - // 没有库存,已抢光的情况下,走正常购买流程 | |
| 894 | - if(redisNum > 0 && !this.data.is_normal) { | |
| 895 | - // 输入的数量 | |
| 896 | - var t = th.data.goodsInputNum; | |
| 897 | - | |
| 898 | - if (t > redisNum) { | |
| 899 | - wx.showToast({ | |
| 857 | + // 秒杀活动 | |
| 858 | + if(this.data.prom_type == 1) { | |
| 859 | + // 如果是秒杀活动下的单独购买,is_normal为1 | |
| 860 | + if(this.data.openSpecModal_flash_normal) this.data.is_normal = 1; | |
| 861 | + | |
| 862 | + if(!this.data.is_normal) {// 秒杀购买 | |
| 863 | + | |
| 864 | + // 获取redis当前可以购买的数量 | |
| 865 | + // 如果数量为0,设置和显示已抢光 | |
| 866 | + // 否则,进一步判断是否超出限购或超出库存 | |
| 867 | + await this.getactLen().then(async function(res) { | |
| 868 | + redisNums = res; | |
| 869 | + let curNum = th.data.goodsInputNum; | |
| 870 | + // res: redis可购买数量 | |
| 871 | + console.log('当前可以购买的数量:', res); | |
| 872 | + if(res <= 0) { | |
| 873 | + // 可购买数量<=0, 设置和显示已抢光 | |
| 874 | + th.setData({ | |
| 875 | + prom_r_null: 1, | |
| 876 | + }); | |
| 877 | + wx.showModal({ | |
| 878 | + title: '超出活动库存', | |
| 879 | + }); | |
| 880 | + return false; | |
| 881 | + } else { | |
| 882 | + // 可购买数量>0 | |
| 883 | + // 计算自己还可以购买的数量 | |
| 884 | + // 自己还可购买的数量c = 每人活动限购数量a - 自己已经购买的数量b | |
| 885 | + // 如果限购数量a>redis可购买数量d,当增加数量t>d, 提示超出库存 | |
| 886 | + // 如果限购数量a<=redis可购买数量d, 当增加数量t>a,提示超出限购 | |
| 887 | + let actInfo = th.data.sele_g; | |
| 888 | + await th.get_buy_num2().then(function (data) { | |
| 889 | + let limited = actInfo.buy_limit; // 限购数量a | |
| 890 | + let promcardbuynum = data.data.data.promcardbuynum; | |
| 891 | + let buyedNum = promcardbuynum; // 自己已经购买的数量b | |
| 892 | + let canBuyNum = limited - buyedNum; // 自己还可购买的数量c | |
| 893 | + limitNum = limited; | |
| 894 | + boughtNum = buyedNum; | |
| 895 | + | |
| 896 | + if(canBuyNum <= 0) { | |
| 897 | + canBuyNum = 0; | |
| 898 | + }; | |
| 899 | + | |
| 900 | + if(canBuyNum > res) { | |
| 901 | + if(curNum > res) { // t当前增减的数量 | |
| 902 | + wx.showModal({ | |
| 900 | 903 | title: '超出活动库存', |
| 901 | - icon: 'none' | |
| 902 | - }); | |
| 903 | - | |
| 904 | - // 开启限购 | |
| 905 | - if (th.data.sele_g.viplimited > 0) { | |
| 906 | - | |
| 907 | - let num = th.data.sele_g.viplimited - gd_buy_num; | |
| 908 | - if (action !="buy") { | |
| 909 | - // 购物车 | |
| 910 | - if (num > redisNum) { | |
| 911 | - th.setData({goodsInputNum: redisNum - cartGoodsNum < 0 ? 0 : redisNum - cartGoodsNum}); | |
| 912 | - } else { | |
| 913 | - th.setData({goodsInputNum: num - cartGoodsNum < 0 ? 0 : num - cartGoodsNum}); | |
| 914 | - } | |
| 915 | - } else { | |
| 916 | - // 立即购买 | |
| 917 | - if (num > redisNum) { | |
| 918 | - th.setData({goodsInputNum: redisNum}); | |
| 919 | - } else { | |
| 920 | - th.setData({goodsInputNum: num}); | |
| 921 | - } | |
| 922 | - } | |
| 923 | - | |
| 924 | - | |
| 925 | - } else { | |
| 926 | - th.setData({goodsInputNum: redisNum}); | |
| 927 | - } | |
| 928 | - | |
| 929 | - return false; | |
| 930 | - } | |
| 931 | - | |
| 904 | + }); | |
| 905 | + th.setData({ | |
| 906 | + goodsInputNum: res, | |
| 907 | + }); | |
| 908 | + return false; | |
| 909 | + }; | |
| 910 | + }; | |
| 932 | 911 | |
| 933 | - | |
| 934 | - // 跳过<立即购买> 购物车 | |
| 935 | - if (action !="buy") { | |
| 936 | - | |
| 937 | - // 输入的数量 + 购物车同款商品的数量 | |
| 938 | - var maxNum = parseInt(t) + parseInt(cartGoodsNum); | |
| 939 | - | |
| 940 | - // 是否开启个人限购 | |
| 941 | - if (th.data.sele_g.viplimited > 0) { | |
| 942 | - | |
| 943 | - if (maxNum + gd_buy_num > th.data.sele_g.buy_limit) { | |
| 944 | - wx.showToast({ | |
| 945 | - title: '超出活动限购数量', | |
| 946 | - icon: 'none' | |
| 947 | - }); | |
| 948 | - | |
| 949 | - // 可购买数量 | |
| 950 | - let num = th.data.sele_g.viplimited - gd_buy_num - cartGoodsNum; | |
| 951 | - th.setData({goodsInputNum: num}); | |
| 952 | - return false; | |
| 953 | - } | |
| 954 | - | |
| 955 | - } | |
| 956 | - | |
| 957 | - if (maxNum > redisNum) { | |
| 958 | - wx.showToast({ | |
| 959 | - title: '超出活动库存', | |
| 960 | - icon: 'none' | |
| 912 | + if(canBuyNum <= res) { | |
| 913 | + if(curNum > canBuyNum) { | |
| 914 | + wx.showModal({ | |
| 915 | + title: '超出限购数量', | |
| 916 | + }); | |
| 917 | + th.setData({ | |
| 918 | + goodsInputNum: canBuyNum, | |
| 961 | 919 | }); |
| 962 | - // 可购买数量 | |
| 963 | - let num = redisNum - cartGoodsNum; | |
| 964 | - th.setData({goodsInputNum: num}); | |
| 965 | 920 | return false; |
| 966 | - } | |
| 967 | - | |
| 968 | - } else { | |
| 969 | - // 以下为立即购买 | |
| 970 | - // 是否开启个人限购 | |
| 971 | - if (th.data.sele_g.viplimited > 0) { | |
| 972 | - | |
| 973 | - if (t + gd_buy_num > th.data.sele_g.viplimited) { | |
| 974 | - wx.showToast({ | |
| 975 | - title: '超出活动限购数量', | |
| 976 | - icon: 'none' | |
| 977 | - }); | |
| 978 | - | |
| 979 | - let num = th.data.sele_g.viplimited - gd_buy_num; | |
| 980 | - if (num > redisNum) { | |
| 981 | - th.setData({goodsInputNum: redisNum}); | |
| 982 | - } else { | |
| 983 | - th.setData({goodsInputNum: num}); | |
| 984 | - } | |
| 985 | - return false; | |
| 986 | - } | |
| 987 | - | |
| 988 | - | |
| 989 | 921 | }; |
| 990 | - | |
| 991 | - } | |
| 992 | - | |
| 922 | + }; | |
| 923 | + | |
| 924 | + | |
| 925 | + }); | |
| 926 | + | |
| 927 | + | |
| 928 | + | |
| 993 | 929 | }; |
| 930 | + }); | |
| 931 | + | |
| 994 | 932 | }; |
| 995 | 933 | |
| 996 | 934 | |
| 935 | + }; | |
| 997 | 936 | |
| 998 | 937 | |
| 999 | 938 | |
| 1000 | - if(action=="buy"){ // 立即购买 | |
| 939 | + if(action=="buy"){ | |
| 1001 | 940 | //--------------此时操作的数据------------ |
| 1002 | 941 | var newd = { |
| 1003 | 942 | id: th.data.data.id, |
| ... | ... | @@ -1019,23 +958,10 @@ Page({ |
| 1019 | 958 | newd['prom_type'] = 0; |
| 1020 | 959 | newd['prom_price'] = this.data.data.shop_price; |
| 1021 | 960 | }; |
| 1022 | - | |
| 1023 | - // 判断是否为0库存的情况 | |
| 1024 | - var tmpRedisNum = 0; | |
| 1025 | - // 检查redis库存量 | |
| 1026 | - await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + os.stoid + "/1/" + prom_id, {}).then(res => { | |
| 1027 | - if (res.data.code == 0) { | |
| 1028 | - tmpRedisNum = res.data.data; | |
| 1029 | - }; | |
| 1030 | - }); | |
| 1031 | - if(this.data.prom_type == 1 && tmpRedisNum == 0) { | |
| 1032 | - newd['prom_type'] = 0; | |
| 1033 | - newd['prom_price'] = this.data.data.shop_price; | |
| 1034 | - }; | |
| 1035 | 961 | |
| 1036 | 962 | // console.log('newd++++++++', newd); |
| 1037 | 963 | th.buyNow(newd); |
| 1038 | - } else { // 购物车 | |
| 964 | + } else { | |
| 1039 | 965 | |
| 1040 | 966 | var newd = { |
| 1041 | 967 | service_id: th.data.data.id, |
| ... | ... | @@ -1062,19 +988,7 @@ Page({ |
| 1062 | 988 | newd['money'] = th.data.prom_price; |
| 1063 | 989 | }; |
| 1064 | 990 | }; |
| 1065 | - | |
| 1066 | - // 判断是否为0库存的情况 | |
| 1067 | - var tmpRedisNum = 0; | |
| 1068 | - // 检查redis库存量 | |
| 1069 | - await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + os.stoid + "/1/" + prom_id, {}).then(res => { | |
| 1070 | - if (res.data.code == 0) { | |
| 1071 | - tmpRedisNum = res.data.data; | |
| 1072 | - }; | |
| 1073 | - }); | |
| 1074 | - if(th.data.options.prom_type == 1 && tmpRedisNum == 0) { | |
| 1075 | - newd['prom_type'] = 0; | |
| 1076 | - newd['money'] = th.data.data.shop_price; | |
| 1077 | - }; | |
| 991 | + | |
| 1078 | 992 | |
| 1079 | 993 | //----先看会员在购物车中是否加入了该商品----- |
| 1080 | 994 | getApp().request.get("/api/weshop/cartService/page", { |
| ... | ... | @@ -1082,16 +996,92 @@ Page({ |
| 1082 | 996 | store_id: os.stoid, |
| 1083 | 997 | user_id: oo.user_id, |
| 1084 | 998 | service_id: th.data.data.id, |
| 1085 | - pick_id: th.data.sto_sele_id, | |
| 1086 | 999 | }, |
| 1087 | 1000 | success: function(re) { |
| 1088 | - | |
| 1089 | - //-------如果购物车中有相关的数据--------- | |
| 1001 | + //-------如果购物车中有相关的数据--------- | |
| 1090 | 1002 | if (re.data.data.total > 0) { |
| 1091 | - var item = re.data.data.pageData[0]; | |
| 1003 | + var item = null; | |
| 1004 | + // 多门店问题 | |
| 1005 | + var cartGoodsNum = 0; | |
| 1006 | + const tmpObj = re.data.data.pageData; | |
| 1007 | + for (let i = 0; i < tmpObj.length; i++) { | |
| 1008 | + if (th.data.sto_sele_id != tmpObj[i].pick_id) { | |
| 1009 | + cartGoodsNum += parseInt(tmpObj[i].goods_num); | |
| 1010 | + } else { | |
| 1011 | + item = tmpObj[i]; | |
| 1012 | + } | |
| 1013 | + } | |
| 1014 | + // 当前门店同类商品还没加入到购物车 但是有其他门店的同类商品 | |
| 1015 | + if (th.data.prom_type == 1 && !th.data.is_normal && !item) { | |
| 1016 | + | |
| 1017 | + // 秒杀购物车购买 修正数量 | |
| 1018 | + var snum = limitNum - boughtNum; | |
| 1019 | + if (snum <= 0) { | |
| 1020 | + wx.showModal({ | |
| 1021 | + title: '超出限购数量', | |
| 1022 | + }); | |
| 1023 | + return false; | |
| 1024 | + } | |
| 1025 | + | |
| 1026 | + var cSnum = snum- cartGoodsNum <= 0 ? 0 : snum- cartGoodsNum; | |
| 1027 | + var cRedisNums = redisNums- cartGoodsNum <= 0 ? 0 : redisNums- cartGoodsNum; | |
| 1028 | + | |
| 1029 | + if (newd['goods_num'] >= redisNums){ | |
| 1030 | + if (redisNums > snum) { | |
| 1031 | + newd['goods_num'] = cSnum; | |
| 1032 | + } else { | |
| 1033 | + newd['goods_num'] = cRedisNums; | |
| 1034 | + } | |
| 1035 | + } else { | |
| 1036 | + if (newd['goods_num'] > snum) newd['goods_num'] = cSnum; | |
| 1037 | + } | |
| 1038 | + | |
| 1039 | + if (newd['goods_num'] <= 0) { | |
| 1040 | + getApp().my_warnning('加入购物车成功', 1, th, 450); | |
| 1041 | + th.closeSpecModal(); | |
| 1042 | + return false; | |
| 1043 | + } | |
| 1044 | + getApp().request.post("/api/weshop/cartService/save", { | |
| 1045 | + data: newd, | |
| 1046 | + success: function(t) { | |
| 1047 | + getApp().my_warnning('加入购物车成功', 1, th, 450); | |
| 1048 | + var c_num = th.data.cartGoodsNum + th.data.goodsInputNum; | |
| 1049 | + th.setData({ | |
| 1050 | + cartGoodsNum: c_num | |
| 1051 | + }); | |
| 1052 | + th.closeSpecModal(); | |
| 1053 | + } | |
| 1054 | + }); | |
| 1055 | + return false; | |
| 1056 | + } | |
| 1057 | + | |
| 1058 | + // 以下为当前门店同类商品已经加入到购物车 | |
| 1059 | + var totalNum = th.data.goodsInputNum + item.goods_num; | |
| 1060 | + | |
| 1061 | + // 秒杀购物车购买 修正数量 | |
| 1062 | + if (th.data.prom_type == 1 && !th.data.is_normal) { | |
| 1063 | + var snum = limitNum - boughtNum; | |
| 1064 | + if (snum <= 0) { | |
| 1065 | + wx.showModal({ | |
| 1066 | + title: '超出限购数量', | |
| 1067 | + }); | |
| 1068 | + return false; | |
| 1069 | + } | |
| 1070 | + if (totalNum >= redisNums){ | |
| 1071 | + if (redisNums > snum) { | |
| 1072 | + totalNum = snum- cartGoodsNum; | |
| 1073 | + } else { | |
| 1074 | + totalNum = redisNums- cartGoodsNum; | |
| 1075 | + } | |
| 1076 | + } else { | |
| 1077 | + if (totalNum > snum) | |
| 1078 | + totalNum = snum- cartGoodsNum; | |
| 1079 | + } | |
| 1080 | + } | |
| 1081 | + | |
| 1092 | 1082 | var updata = { |
| 1093 | 1083 | id: item.id, |
| 1094 | - goods_num: th.data.goodsInputNum + item.goods_num, | |
| 1084 | + goods_num: totalNum, | |
| 1095 | 1085 | money: th.data.data.shop_price, |
| 1096 | 1086 | store_id: os.stoid, |
| 1097 | 1087 | }; |
| ... | ... | @@ -1124,7 +1114,6 @@ Page({ |
| 1124 | 1114 | } |
| 1125 | 1115 | }); |
| 1126 | 1116 | } else { |
| 1127 | - | |
| 1128 | 1117 | getApp().request.post("/api/weshop/cartService/save", { |
| 1129 | 1118 | data: newd, |
| 1130 | 1119 | success: function(t) { |
| ... | ... | @@ -1171,142 +1160,121 @@ Page({ |
| 1171 | 1160 | }, |
| 1172 | 1161 | |
| 1173 | 1162 | //------检查数量是不是超出限购------ |
| 1174 | - checkCartNum: function(t) { | |
| 1163 | + checkCartNum: async function(t) { | |
| 1164 | + var th = this; | |
| 1175 | 1165 | |
| 1176 | - if(this.data.prom_type != 1) { | |
| 1177 | - this.setData({goodsInputNum: t}); | |
| 1178 | - return false; | |
| 1166 | + if(!th.data.def_pick_store) { | |
| 1167 | + wx.showModal({title: '请选择门店',}); | |
| 1168 | + return false; | |
| 1179 | 1169 | }; |
| 1180 | 1170 | |
| 1181 | - var th = this; | |
| 1182 | - | |
| 1183 | - // if(this.data.prom_act.is_shop_buy && this.data.options.prom_type != 1) { | |
| 1184 | - | |
| 1185 | - if(t == 0) return false; | |
| 1186 | - // th.setData({goodsInputNum:t}); | |
| 1171 | + // 非秒杀活动 | |
| 1172 | + if(this.data.prom_type != 1) { | |
| 1173 | + this.setData({ | |
| 1174 | + goodsInputNum: t, | |
| 1175 | + }); | |
| 1176 | + }; | |
| 1187 | 1177 | |
| 1188 | - // if(this.data.options.prom_type == 1 && !this.data.openSpecModal_flash_normal) { | |
| 1189 | - | |
| 1190 | - this.get_buy_num(this.data.sele_g, async function () { | |
| 1191 | - th.data.sele_g.viplimited = th.data.sele_g.buy_limit; | |
| 1192 | - | |
| 1193 | - //--判断商品是否超出限购-- | |
| 1194 | - // if (th.data.g_buy_num != null && th.data.sele_g.viplimited > 0) { | |
| 1195 | - // if(!th.data.prom_act.is_shop_buy) { | |
| 1196 | - | |
| 1197 | - // if (th.data.sele_g.viplimited > 0) { | |
| 1198 | - // var gd_buy_num = th.data.sele_g.buy_num; | |
| 1199 | - | |
| 1200 | - // if (t + gd_buy_num> th.data.sele_g.viplimited) { | |
| 1201 | - // wx.showModal({ | |
| 1202 | - // title: '超出商品限购', | |
| 1203 | - // }); | |
| 1204 | - | |
| 1205 | - // var num = th.data.sele_g.viplimited - gd_buy_num; | |
| 1206 | - // if (num <= 0) num = 1; | |
| 1207 | - // th.setData({goodsInputNum: num}) | |
| 1208 | - // return false; | |
| 1209 | - // } | |
| 1210 | - // }; | |
| 1211 | - | |
| 1212 | - | |
| 1213 | - // 单独购买 | |
| 1214 | - if(th.data.openSpecModal_flash_normal) th.data.is_normal = 1; | |
| 1215 | - | |
| 1216 | - // 秒杀:判断活动是否抢光 | |
| 1217 | - if (th.data.sele_g.prom_type == 1 && !th.data.is_normal) { | |
| 1218 | - var redis_num = 0; | |
| 1219 | - //------判断活动是否抢光----- | |
| 1220 | - await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + | |
| 1221 | - os.stoid + "/" + th.data.sele_g.prom_type + "/" + th.data.sele_g.prom_id, { | |
| 1222 | - 1: 1 | |
| 1223 | - }).then(res => { | |
| 1224 | - redis_num = res.data.data; | |
| 1178 | + // 秒杀活动 | |
| 1179 | + if(this.data.prom_type == 1) { | |
| 1180 | + // 如果是秒杀活动下的单独购买,is_normal为1 | |
| 1181 | + if(this.data.openSpecModal_flash_normal) this.data.is_normal = 1; | |
| 1182 | + | |
| 1183 | + if(this.data.is_normal) {// 单独购买 | |
| 1184 | + this.setData({ | |
| 1185 | + goodsInputNum: t, | |
| 1186 | + }); | |
| 1187 | + } else {// 秒杀购买 | |
| 1188 | + | |
| 1189 | + // 获取redis当前可以购买的数量 | |
| 1190 | + // 如果数量为0,设置和显示已抢光 | |
| 1191 | + // 否则,进一步判断是否超出限购或超出库存 | |
| 1192 | + await this.getactLen().then(async function(res) { | |
| 1193 | + // res: redis可购买数量 | |
| 1194 | + console.log('当前可以购买的数量:', res); | |
| 1195 | + if(res <= 0) { | |
| 1196 | + // 可购买数量<=0, 设置和显示已抢光 | |
| 1197 | + th.setData({ | |
| 1198 | + prom_r_null: 1, | |
| 1199 | + }); | |
| 1200 | + } else { | |
| 1201 | + // 可购买数量>0 | |
| 1202 | + // 计算自己还可以购买的数量 | |
| 1203 | + // 自己还可购买的数量c = 每人活动限购数量a - 自己已经购买的数量b | |
| 1204 | + // 如果限购数量a>redis可购买数量d,当增加数量t>d, 提示超出库存 | |
| 1205 | + // 如果限购数量a<=redis可购买数量d, 当增加数量t>a,提示超出限购 | |
| 1206 | + let actInfo = th.data.sele_g; | |
| 1207 | + await th.get_buy_num2().then(function (data) { | |
| 1208 | + let limited = actInfo.buy_limit; // 限购数量a | |
| 1209 | + let promcardbuynum = data.data.data.promcardbuynum; | |
| 1210 | + let buyedNum = promcardbuynum; // 自己已经购买的数量b | |
| 1211 | + let canBuyNum = limited - buyedNum; // 自己还可购买的数量c | |
| 1212 | + | |
| 1213 | + if(canBuyNum <= 0) { | |
| 1214 | + canBuyNum = 0; | |
| 1215 | + }; | |
| 1216 | + | |
| 1217 | + if(limited > res) { | |
| 1218 | + if(t > res) { // t当前增减的数量 | |
| 1219 | + wx.showModal({ | |
| 1220 | + title: '超出活动库存', | |
| 1225 | 1221 | }); |
| 1226 | - | |
| 1227 | - if (t > redis_num) { | |
| 1228 | - wx.showToast({ | |
| 1229 | - // title: '超出商品活动库存', | |
| 1230 | - title: '超出活动库存', | |
| 1231 | - icon: 'none', | |
| 1232 | - }); | |
| 1233 | - th.setData({goodsInputNum: redis_num}) | |
| 1234 | - return false; | |
| 1235 | - } | |
| 1222 | + th.setData({ | |
| 1223 | + goodsInputNum: res, | |
| 1224 | + }); | |
| 1225 | + return false; | |
| 1236 | 1226 | }; |
| 1237 | - | |
| 1238 | - //--秒杀:判断商品是否超出活动限购-- | |
| 1239 | - if (th.data.sele_g.viplimited > 0 && !th.data.is_normal && th.data.prom_type == 1) { | |
| 1240 | - var gd_buy_num = th.data.promcardbuynum; | |
| 1241 | - | |
| 1242 | - // 如果限购数量>活动库存数量,增加数量时会先超过库存数量,此时应该提示“超出活动库存”; | |
| 1243 | - // 如果限购数量<=活动库存数量,增加数量时会先超过限购数量,此时应提示“超出活动限购数量” | |
| 1244 | - if(th.data.sele_g.viplimited > th.data.sele_g.goods_num) { | |
| 1245 | - | |
| 1246 | - // 计算还可以购买的数量:库存量 - 已购数 | |
| 1247 | - var num = th.data.sele_g.goods_num - gd_buy_num; | |
| 1248 | - if(num < 0) num = 0; | |
| 1249 | - if(t > num) { | |
| 1250 | - wx.showToast({ | |
| 1251 | - title: '超出活动库存', | |
| 1252 | - icon: 'none', | |
| 1253 | - }); | |
| 1254 | - | |
| 1255 | - th.setData({goodsInputNum: num}) | |
| 1256 | - return false; | |
| 1257 | - | |
| 1258 | - }; | |
| 1259 | - | |
| 1260 | - } else { | |
| 1261 | - if ((t + gd_buy_num> th.data.sele_g.viplimited) && (t<=th.data.sele_g.goods_num)) { | |
| 1262 | - wx.showToast({ | |
| 1263 | - title: '超出活动限购数量', | |
| 1264 | - icon: 'none', | |
| 1265 | - }); | |
| 1266 | - | |
| 1267 | - var num = th.data.sele_g.viplimited - gd_buy_num; | |
| 1268 | - if (num <= 0) num = 1; | |
| 1269 | - th.setData({goodsInputNum: num}) | |
| 1270 | - return false; | |
| 1271 | - }; | |
| 1272 | - }; | |
| 1273 | - | |
| 1274 | - | |
| 1275 | - | |
| 1227 | + }; | |
| 1228 | + | |
| 1229 | + if(limited <= res) { | |
| 1230 | + if(t>canBuyNum) { | |
| 1231 | + wx.showModal({ | |
| 1232 | + title: '超出限购数量', | |
| 1233 | + }); | |
| 1234 | + th.setData({ | |
| 1235 | + goodsInputNum: canBuyNum, | |
| 1236 | + }); | |
| 1237 | + return false; | |
| 1276 | 1238 | }; |
| 1277 | - | |
| 1278 | - //--秒杀:判断商品是否超出活动限购-- | |
| 1279 | - // if (th.data.prom_buy_num != -1 && th.data.prom_buy_limit > 0 && !th.data.is_normal) { | |
| 1280 | - // if (t + th.data.prom_buy_num > th.data.prom_buy_limit) { | |
| 1281 | - // wx.showModal({ | |
| 1282 | - // title: '超出商品活动限购', | |
| 1283 | - // }); | |
| 1239 | + }; | |
| 1240 | + | |
| 1241 | + th.setData({ | |
| 1242 | + goodsInputNum: t, | |
| 1243 | + }); | |
| 1244 | + }); | |
| 1245 | + }; | |
| 1246 | + }); | |
| 1284 | 1247 | |
| 1285 | - // var num = th.data.prom_buy_limit - th.data.prom_buy_num; | |
| 1286 | - // if (num < 0) num = 0; | |
| 1287 | - // th.setData({goodsInputNum: num}) | |
| 1288 | - // return false; | |
| 1289 | - // }; | |
| 1290 | - // }; | |
| 1248 | + } | |
| 1249 | + | |
| 1250 | + | |
| 1251 | + }; | |
| 1252 | + | |
| 1253 | + | |
| 1254 | + | |
| 1255 | + | |
| 1256 | + | |
| 1257 | + | |
| 1291 | 1258 | |
| 1292 | 1259 | |
| 1293 | 1260 | |
| 1294 | 1261 | |
| 1295 | 1262 | |
| 1296 | 1263 | // var e = th.data.sele_g.goods_num; |
| 1297 | - var p_type = th.data.prom_type; //&& p_type!=1 && p_type!=4 | |
| 1298 | - if (th.data.sales_rules == 2 && (p_type != 1 && p_type != 4 && p_type != 6 || th.data.openSpecModal_inte_normal == 1 || th.data.is_normal == 1)) { | |
| 1299 | - if (!th.data.def_pick_store) { | |
| 1300 | - wx.showModal({title: '请选择门店',}); | |
| 1301 | - return false; | |
| 1302 | - } else { | |
| 1303 | - // e = th.data.def_pick_store.CanOutQty; | |
| 1304 | - } | |
| 1305 | - } | |
| 1306 | - | |
| 1307 | - th.setData({goodsInputNum: t}); | |
| 1264 | + // var p_type = th.data.prom_type; //&& p_type!=1 && p_type!=4 | |
| 1265 | + // if (th.data.sales_rules == 2 && (p_type != 1 && p_type != 4 && p_type != 6 || th.data.openSpecModal_inte_normal == 1 || th.data.is_normal == 1)) { | |
| 1266 | + // if (!th.data.def_pick_store) { | |
| 1267 | + // wx.showModal({title: '请选择门店',}); | |
| 1268 | + // return false; | |
| 1269 | + // } else { | |
| 1270 | + // e = th.data.def_pick_store.CanOutQty; | |
| 1271 | + // } | |
| 1272 | + // } | |
| 1273 | + | |
| 1274 | + | |
| 1275 | + // th.setData({goodsInputNum: t}); | |
| 1308 | 1276 | |
| 1309 | - }); | |
| 1277 | + // }); | |
| 1310 | 1278 | |
| 1311 | 1279 | |
| 1312 | 1280 | }, |
| ... | ... | @@ -1338,12 +1306,10 @@ Page({ |
| 1338 | 1306 | return false; |
| 1339 | 1307 | } |
| 1340 | 1308 | |
| 1341 | - var ind = t.currentTarget.dataset.ind; | |
| 1342 | - | |
| 1309 | + var ind = t.currentTarget.dataset.ind; | |
| 1343 | 1310 | this.setData({ |
| 1344 | 1311 | openSpecModal: !0, |
| 1345 | - openSpecModal_ind: ind, | |
| 1346 | - goodsInputNum: 1, | |
| 1312 | + openSpecModal_ind: ind, | |
| 1347 | 1313 | }); |
| 1348 | 1314 | |
| 1349 | 1315 | }, |
| ... | ... | @@ -3300,19 +3266,18 @@ Page({ |
| 3300 | 3266 | |
| 3301 | 3267 | |
| 3302 | 3268 | //获取redis中的数量 |
| 3303 | - async getactLen(func) { | |
| 3304 | - var r_num = 0, | |
| 3305 | - prom_type = this.data.prom_type, | |
| 3306 | - prom_id = this.data.prom_id; | |
| 3307 | - await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + os.stoid + "/" + prom_type + "/" + prom_id, { | |
| 3269 | + async getactLen() { | |
| 3270 | + let prom_type = this.data.options.prom_type; | |
| 3271 | + let prom_id = this.data.options.prom_id; | |
| 3272 | + return await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + os.stoid + "/" + prom_type + "/" + prom_id, { | |
| 3308 | 3273 | 1: 1 |
| 3309 | 3274 | }).then(res => { |
| 3310 | - var em = res; | |
| 3311 | - if (em.data.code == 0) { | |
| 3312 | - r_num = em.data.data; | |
| 3313 | - } | |
| 3275 | + if (res.data.code == 0) { | |
| 3276 | + // 当前可以购买的数量 | |
| 3277 | + let r_num = res.data.data; | |
| 3278 | + return r_num; | |
| 3279 | + }; | |
| 3314 | 3280 | }) |
| 3315 | - func(r_num); | |
| 3316 | 3281 | }, |
| 3317 | 3282 | |
| 3318 | 3283 | |
| ... | ... | @@ -3551,7 +3516,7 @@ Page({ |
| 3551 | 3516 | //----获取商品购买数---- |
| 3552 | 3517 | if (th.data.prom_type == 1) { |
| 3553 | 3518 | //----获取活动购买数---- |
| 3554 | - getApp().request.get("/api/weshop/rechargeServicelist/getUserBuyGoodsNum", { | |
| 3519 | + getApp().request.promiseGet("/api/weshop/rechargeServicelist/getUserBuyGoodsNum", { | |
| 3555 | 3520 | data: { |
| 3556 | 3521 | store_id: os.stoid, |
| 3557 | 3522 | user_id: user_id, |
| ... | ... | @@ -3579,6 +3544,49 @@ Page({ |
| 3579 | 3544 | }, |
| 3580 | 3545 | |
| 3581 | 3546 | |
| 3547 | + get_buy_num2: async function () { | |
| 3548 | + // var map = this.data.g_buy_num, | |
| 3549 | + var th = this, | |
| 3550 | + user_id = getApp().globalData.user_id; | |
| 3551 | + // if (user_id == null) { | |
| 3552 | + // // map.set(gd.goods_id, 0); | |
| 3553 | + // th.setData({ | |
| 3554 | + // // g_buy_num: map, | |
| 3555 | + // prom_buy_num: 0, | |
| 3556 | + // }); | |
| 3557 | + // "function" == typeof func && func(); | |
| 3558 | + // return false; | |
| 3559 | + // } | |
| 3560 | + | |
| 3561 | + | |
| 3562 | + //----获取商品购买数---- | |
| 3563 | + | |
| 3564 | + //----获取活动购买数---- | |
| 3565 | + return await getApp().request.promiseGet("/api/weshop/rechargeServicelist/getUserBuyGoodsNum", { | |
| 3566 | + data: { | |
| 3567 | + store_id: os.stoid, | |
| 3568 | + user_id: user_id, | |
| 3569 | + card_id: th.data.options.goods_id, | |
| 3570 | + prom_type: th.data.options.prom_type, | |
| 3571 | + prom_id: th.data.options.prom_id | |
| 3572 | + }, | |
| 3573 | + //-----获取----- | |
| 3574 | + success: function (tt) { | |
| 3575 | + if (tt.data.code == 0) { | |
| 3576 | + // map.set(gd.goods_id, g_buy_num); | |
| 3577 | + th.setData({ | |
| 3578 | + // g_buy_num: map, | |
| 3579 | + promcardbuynum: tt.data.data.promcardbuynum, | |
| 3580 | + cardbuynum: tt.data.data.cardbuynum, | |
| 3581 | + }); | |
| 3582 | + } | |
| 3583 | + } | |
| 3584 | + }); | |
| 3585 | + | |
| 3586 | + | |
| 3587 | + }, | |
| 3588 | + | |
| 3589 | + | |
| 3582 | 3590 | |
| 3583 | 3591 | |
| 3584 | 3592 | |
| ... | ... | @@ -3619,6 +3627,17 @@ Page({ |
| 3619 | 3627 | |
| 3620 | 3628 | //-- 秒杀的普通购买 -- |
| 3621 | 3629 | openSpecModel_Nor: function () { |
| 3630 | + | |
| 3631 | + // 是否授权登陆 | |
| 3632 | + var user_info = getApp().globalData.userInfo; | |
| 3633 | + if (user_info == null || user_info.mobile == undefined || user_info.mobile == "" || user_info.mobile == null) { | |
| 3634 | + wx.navigateTo({ | |
| 3635 | + url: '/pages/togoin/togoin', | |
| 3636 | + }) | |
| 3637 | + return false; | |
| 3638 | + } | |
| 3639 | + | |
| 3640 | + | |
| 3622 | 3641 | this.data.g_buy_num = new Map(); |
| 3623 | 3642 | var th = this; |
| 3624 | 3643 | this.setData({open_ind_store: 5, goodsInputNum: 1});//拼团直接给4 | ... | ... |
pages/cart/cart/cart.js
| ... | ... | @@ -1079,9 +1079,10 @@ Page({ |
| 1079 | 1079 | if (a = isNaN(t.detail.value) || t.detail.value < 1 ? 1 : parseInt(t.detail.value)) { |
| 1080 | 1080 | var s = { |
| 1081 | 1081 | goods_num: a, |
| 1082 | - goods_id: e.goods_id, | |
| 1082 | + goods_id: e.service_id, | |
| 1083 | 1083 | id: e.id, |
| 1084 | 1084 | store_id: oo.stoid, |
| 1085 | + is_pd_normal: e.is_pd_normal | |
| 1085 | 1086 | }; |
| 1086 | 1087 | if(e.prom_type) { |
| 1087 | 1088 | s.prom_type = e.prom_type; |
| ... | ... | @@ -1102,7 +1103,7 @@ Page({ |
| 1102 | 1103 | addNum_ser: function (t) { |
| 1103 | 1104 | if (!this.data.is_load) return false; |
| 1104 | 1105 | if (this.data.up_dating == 1) return false; |
| 1105 | - this.data.up_dating = 1; | |
| 1106 | + // this.data.up_dating = 1; | |
| 1106 | 1107 | |
| 1107 | 1108 | var a = t.currentTarget.dataset.item; |
| 1108 | 1109 | var b = t.currentTarget.dataset.pitems; |
| ... | ... | @@ -1113,6 +1114,7 @@ Page({ |
| 1113 | 1114 | id: a.id, |
| 1114 | 1115 | goods_id: a.service_id, |
| 1115 | 1116 | store_id: oo.stoid, |
| 1117 | + is_pd_normal: a.is_pd_normal | |
| 1116 | 1118 | }; |
| 1117 | 1119 | if(a.prom_type) { |
| 1118 | 1120 | e.prom_type = a.prom_type; |
| ... | ... | @@ -1134,7 +1136,7 @@ Page({ |
| 1134 | 1136 | |
| 1135 | 1137 | if (!this.data.is_load) return false; |
| 1136 | 1138 | if (this.data.up_dating == 1) return false; |
| 1137 | - this.data.up_dating = 1; | |
| 1139 | + // this.data.up_dating = 1; | |
| 1138 | 1140 | |
| 1139 | 1141 | var a = t.currentTarget.dataset.item; |
| 1140 | 1142 | var b = t.currentTarget.dataset.pitems; |
| ... | ... | @@ -1150,9 +1152,11 @@ Page({ |
| 1150 | 1152 | var e = { |
| 1151 | 1153 | goods_num: a.goods_num - 1, |
| 1152 | 1154 | id: a.id, |
| 1153 | - goods_id: a.goods_id, | |
| 1154 | - store_id: oo.stoid | |
| 1155 | + goods_id: a.service_id, | |
| 1156 | + store_id: oo.stoid, | |
| 1157 | + is_pd_normal: a.is_pd_normal | |
| 1155 | 1158 | }; |
| 1159 | + | |
| 1156 | 1160 | this.postCardList_ser(e, t.currentTarget.dataset.item, t.currentTarget.dataset.pitems); |
| 1157 | 1161 | } |
| 1158 | 1162 | }, |
| ... | ... | @@ -2025,104 +2029,139 @@ Page({ |
| 2025 | 2029 | e.setData({ |
| 2026 | 2030 | [txt]: t.goods_num |
| 2027 | 2031 | }); |
| 2028 | - | |
| 2029 | - | |
| 2030 | - if(t.prom_type == 1) { | |
| 2031 | - var txt = "service_data[" + pitem + "].goods[" + item + "].goods_num"; | |
| 2032 | - var redis_num = 0; | |
| 2033 | - | |
| 2034 | - //------判断活动是否抢光----- | |
| 2035 | - await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + | |
| 2036 | - t.store_id + "/" + t.prom_type + "/" + t.prom_id, { | |
| 2037 | - 1: 1 | |
| 2038 | - }).then(res => { | |
| 2039 | - redis_num = res.data.data; | |
| 2040 | - }); | |
| 2041 | - | |
| 2042 | - // 检测库存 | |
| 2043 | - if(redis_num == 0) { | |
| 2044 | - wx.showToast({ | |
| 2045 | - title: '超出活动库存', | |
| 2046 | - icon: 'none', | |
| 2047 | - }); | |
| 2048 | - th.setData({[txt]: redis_num}); | |
| 2049 | - await e.doCheckAll(); | |
| 2050 | - return false; | |
| 2051 | - }; | |
| 2052 | 2032 | |
| 2053 | - var buylimit = 0 | |
| 2054 | - await getApp().request.promiseGet("/api/ms/flash_sale/getNew/" + t.store_id + "/" + getApp().globalData.user_id + "/" + t.prom_id, { | |
| 2033 | + // 1.秒杀活动 | |
| 2034 | + // 2.活动开始 | |
| 2035 | + if(t.prom_type == 1 && t.is_pd_normal == 0) { | |
| 2036 | + var txt = "service_data[" + pitem + "].goods[" + item + "].goods_num"; | |
| 2037 | + var redis_num = 0; | |
| 2038 | + | |
| 2039 | + // 获取其他门店,同类商品的数量 | |
| 2040 | + var cartGoodsNum = 0; | |
| 2041 | + await getApp().request.promiseGet("/api/weshop/cartService/page?store_id="+t.store_id+"&user_id="+getApp().globalData.user_id+"&service_id="+t.goods_id, | |
| 2042 | + { }).then(res => { | |
| 2043 | + if (res.data.data.pageData.length > 0) { | |
| 2044 | + const tmpObj = res.data.data.pageData; | |
| 2045 | + tmpObj.forEach(v => { | |
| 2046 | + if (t.id != v.id) { | |
| 2047 | + cartGoodsNum += parseInt(v.goods_num); | |
| 2048 | + } | |
| 2055 | 2049 | |
| 2056 | - }).then(res => { | |
| 2057 | - if(res.data.code == 0) { | |
| 2058 | - | |
| 2059 | - th.data.sele_g = res.data.data; | |
| 2060 | - th.data.sele_g.viplimited = res.data.data.buy_limit; | |
| 2061 | - buylimit = !res.data.data.buy_limit ? 0 : res.data.data.buy_limit; | |
| 2062 | - }; | |
| 2063 | 2050 | }); |
| 2051 | + } | |
| 2052 | + }); | |
| 2053 | + // 当前商品数量包括其他门店 | |
| 2054 | + var totalNum = 0 | |
| 2055 | + if (cartGoodsNum > 0) { | |
| 2056 | + totalNum = t.goods_num + cartGoodsNum; | |
| 2057 | + } else { | |
| 2058 | + totalNum = t.goods_num; | |
| 2059 | + } | |
| 2064 | 2060 | |
| 2065 | - //----获取用户活动购买数---- | |
| 2066 | - var gd_buy_num = 0; | |
| 2067 | - await getApp().request.promiseGet("/api/weshop/rechargeServicelist/getUserBuyGoodsNum?store_id="+t.store_id+"&user_id="+getApp().globalData.user_id+"&card_id="+t.goods_id+"&prom_type="+t.prom_type+"&prom_id="+t.prom_id, { | |
| 2068 | - }).then(tt => { | |
| 2069 | - if (tt.data.code == 0) { | |
| 2070 | - gd_buy_num = !tt.data.promcardbuynum ? 0 : tt.data.promcardbuynum; | |
| 2071 | - th.setData({ | |
| 2072 | - promcardbuynum: !tt.data.promcardbuynum ? 0 : tt.data.promcardbuynum, | |
| 2073 | - cardbuynum: tt.data.data.cardbuynum, | |
| 2074 | - }); | |
| 2075 | - }; | |
| 2061 | + //获取当前商品活动库存 | |
| 2062 | + await getApp().request.promiseGet("/api/weshop/activitylist/getActLen/" + | |
| 2063 | + t.store_id + "/" + t.prom_type + "/" + t.prom_id, { | |
| 2064 | + 1: 1 | |
| 2065 | + }).then(res => { | |
| 2066 | + redis_num = res.data.data; | |
| 2067 | + }); | |
| 2068 | + | |
| 2069 | + // 检测库存 | |
| 2070 | + if(redis_num == 0) { | |
| 2071 | + wx.showToast({ | |
| 2072 | + title: '超出活动库存', | |
| 2073 | + icon: 'none', | |
| 2074 | + }); | |
| 2075 | + th.setData({[txt]: redis_num}); | |
| 2076 | + t.goods_num = redis_num; | |
| 2077 | + await th.doCheckAll(); | |
| 2078 | + await th.update_cart_ser(t, pitem, item); | |
| 2079 | + return false; | |
| 2080 | + }; | |
| 2081 | + | |
| 2082 | + // 限购数量 | |
| 2083 | + var buylimit = 0 | |
| 2084 | + await getApp().request.promiseGet("/api/ms/flash_sale/getNew/" + t.store_id + "/" + getApp().globalData.user_id + "/" + t.prom_id, { | |
| 2085 | + | |
| 2086 | + }).then(res => { | |
| 2087 | + if(res.data.code == 0) { | |
| 2088 | + th.data.sele_g = res.data.data; | |
| 2089 | + th.data.sele_g.viplimited = res.data.data.buy_limit; | |
| 2090 | + buylimit = !res.data.data.buy_limit ? 0 : res.data.data.buy_limit; | |
| 2091 | + }; | |
| 2092 | + }); | |
| 2093 | + | |
| 2094 | + //用户已经成功付款购买的数量 | |
| 2095 | + var gd_buy_num = 0; | |
| 2096 | + await getApp().request.promiseGet("/api/weshop/rechargeServicelist/getUserBuyGoodsNum?store_id="+t.store_id+"&user_id="+getApp().globalData.user_id+"&card_id="+t.card_id+"&prom_type="+t.prom_type+"&prom_id="+t.prom_id, { | |
| 2097 | + }).then(tt => { | |
| 2098 | + if (tt.data.code == 0) { | |
| 2099 | + gd_buy_num = !tt.data.data.promcardbuynum ? 0 : tt.data.data.promcardbuynum; | |
| 2100 | + th.setData({ | |
| 2101 | + promcardbuynum: !tt.data.data.promcardbuynum ? 0 : tt.data.data.promcardbuynum, | |
| 2102 | + cardbuynum: tt.data.data.cardbuynum, | |
| 2076 | 2103 | }); |
| 2104 | + }; | |
| 2105 | + }); | |
| 2077 | 2106 | |
| 2078 | - | |
| 2079 | - | |
| 2107 | + // 剩余购买数 | |
| 2108 | + let num = buylimit - gd_buy_num; | |
| 2080 | 2109 | |
| 2081 | - if(t.goods_num > redis_num) { | |
| 2082 | - wx.showToast({ | |
| 2083 | - title: '超出活动库存', | |
| 2084 | - icon: 'none', | |
| 2085 | - }); | |
| 2086 | - // 开启限购 | |
| 2087 | - if (buylimit > 0) { | |
| 2088 | - let num = buylimit - gd_buy_num; | |
| 2089 | - if (num > redis_num) { | |
| 2090 | - th.setData({[txt]: redis_num}); | |
| 2091 | - } else { | |
| 2092 | - th.setData({[txt]: num}); | |
| 2093 | - } | |
| 2094 | - } else { | |
| 2095 | - th.setData({[txt]: redis_num}); | |
| 2096 | - } | |
| 2110 | + if(totalNum > redis_num) { | |
| 2111 | + wx.showToast({ | |
| 2112 | + title: '超出活动库存', | |
| 2113 | + icon: 'none', | |
| 2114 | + }); | |
| 2115 | + // 开启限购 | |
| 2116 | + if (buylimit > 0) { | |
| 2117 | + if (num > redis_num) { | |
| 2118 | + th.setData({[txt]: redis_num-cartGoodsNum}); | |
| 2119 | + t.goods_num = redis_num-cartGoodsNum; | |
| 2120 | + await th.doCheckAll(); | |
| 2121 | + await th.update_cart_ser(t, pitem, item); | |
| 2122 | + } else { | |
| 2123 | + th.setData({[txt]: num - cartGoodsNum}); | |
| 2124 | + t.goods_num = num - cartGoodsNum; | |
| 2125 | + await th.doCheckAll(); | |
| 2126 | + await th.update_cart_ser(t, pitem, item); | |
| 2127 | + } | |
| 2128 | + } else { | |
| 2129 | + th.setData({[txt]: redis_num - cartGoodsNum}); | |
| 2130 | + t.goods_num = redis_num - cartGoodsNum; | |
| 2131 | + await th.doCheckAll(); | |
| 2132 | + await th.update_cart_ser(t, pitem, item); | |
| 2133 | + } | |
| 2097 | 2134 | |
| 2098 | - await e.doCheckAll(); | |
| 2099 | - return false; | |
| 2100 | - }; | |
| 2135 | + return false; | |
| 2136 | + }; | |
| 2101 | 2137 | |
| 2138 | + | |
| 2139 | + //--秒杀:判断商品是否超出活动限购-- | |
| 2140 | + if (buylimit > 0) { | |
| 2141 | + | |
| 2142 | + // 如果限购数量<=活动库存数量,增加数量时会先超过限购数量,此时应提示“超出活动限购数量” | |
| 2143 | + if(totalNum > num) { | |
| 2144 | + // 计算还可以购买的数量:库存量 - 已购数 | |
| 2145 | + wx.showToast({ | |
| 2146 | + title: '超出活动限购', | |
| 2147 | + icon: 'none', | |
| 2148 | + }); | |
| 2149 | + if (num <= 0) num = 1; | |
| 2150 | + th.setData({[txt]: num - cartGoodsNum}); | |
| 2151 | + t.goods_num = num - cartGoodsNum; | |
| 2152 | + await th.doCheckAll(); | |
| 2153 | + await th.update_cart_ser(t, pitem, item); | |
| 2154 | + return false; | |
| 2155 | + }; | |
| 2102 | 2156 | |
| 2103 | - //--秒杀:判断商品是否超出活动限购-- | |
| 2104 | - if (buylimit > 0) { | |
| 2105 | - | |
| 2106 | - // 如果限购数量<=活动库存数量,增加数量时会先超过限购数量,此时应提示“超出活动限购数量” | |
| 2107 | - if(t.goods_num + gd_buy_num > buylimit) { | |
| 2108 | - // 计算还可以购买的数量:库存量 - 已购数 | |
| 2109 | - wx.showToast({ | |
| 2110 | - title: '超出活动限购', | |
| 2111 | - icon: 'none', | |
| 2112 | - }); | |
| 2113 | - let num = buylimit - gd_buy_num; | |
| 2114 | - if (num <= 0) num = 1; | |
| 2115 | - th.setData({[txt]: num}); | |
| 2116 | - await e.doCheckAll(); | |
| 2117 | - return false; | |
| 2118 | - }; | |
| 2119 | - | |
| 2120 | - } | |
| 2121 | - | |
| 2122 | - | |
| 2123 | - } | |
| 2124 | - await e.doCheckAll(); | |
| 2125 | - await e.update_cart_ser(t, pitem, item); | |
| 2157 | + } | |
| 2158 | + | |
| 2159 | + | |
| 2160 | + } | |
| 2161 | + | |
| 2162 | + | |
| 2163 | + await e.doCheckAll(); | |
| 2164 | + await e.update_cart_ser(t, pitem, item); | |
| 2126 | 2165 | |
| 2127 | 2166 | |
| 2128 | 2167 | }, |
| ... | ... | @@ -2336,7 +2375,6 @@ Page({ |
| 2336 | 2375 | update_cart_ser: function (t, pitem, item) { |
| 2337 | 2376 | var e = this; |
| 2338 | 2377 | |
| 2339 | - console.log('t===>', t); | |
| 2340 | 2378 | getApp().request.put("/api/weshop/cartService/update", { |
| 2341 | 2379 | data: t, |
| 2342 | 2380 | success: async function (ee) { | ... | ... |
pages/cart/cart2/cart2.js
| ... | ... | @@ -3855,15 +3855,20 @@ Page({ |
| 3855 | 3855 | if (prom_pt_json) { |
| 3856 | 3856 | for (let oj in prom_pt_json) { |
| 3857 | 3857 | let item_j = prom_pt_json[oj]; |
| 3858 | - | |
| 3859 | 3858 | //要对一下阶梯优惠促销的功能 |
| 3860 | 3859 | if (item_j.ladder_prom_id) { |
| 3861 | - | |
| 3862 | 3860 | //看一下要不要限制使用优惠券 |
| 3863 | 3861 | if (th.data.ladder_map[item_j.ladder_prom_id] && th.data.ladder_map[item_j.ladder_prom_id].is_usecoupon) { |
| 3864 | 3862 | continue; |
| 3865 | 3863 | } |
| 3866 | - | |
| 3864 | + cut_price += parseFloat(item_j.dis); | |
| 3865 | + } | |
| 3866 | + //要对一下组合购促销的功能 | |
| 3867 | + if (item_j.zhprom_id) { | |
| 3868 | + //看一下要不要限制使用优惠券 | |
| 3869 | + if (th.data.zhhe_act_map[item_j.zhprom_id] && th.data.zhhe_act_map[item_j.zhprom_id].is_xz_yh) { | |
| 3870 | + continue; | |
| 3871 | + } | |
| 3867 | 3872 | cut_price += parseFloat(item_j.dis); |
| 3868 | 3873 | } |
| 3869 | 3874 | } | ... | ... |
pages/goods/goodsInfo/goodsInfo.wxml
| ... | ... | @@ -490,61 +490,8 @@ |
| 490 | 490 | </view> |
| 491 | 491 | </view> |
| 492 | 492 | </block> |
| 493 | - <!-- 门店收货地址 --> | |
| 494 | - <view class="xc-address_frame bdt16 flex-vertical xc-ash {{def_pick_store!=null?'sn_height':'on_height'}}"> | |
| 495 | - <view class="address_frame" bindtap="choice_store" data-ind="0"> | |
| 496 | - <view class="flex-vertical-between "> | |
| 497 | - <view class="flex-vertical select_store_height"> | |
| 498 | - <image class="stores-img" src="{{iurl}}/miniapp/images/stores.png"></image> | |
| 499 | - <view class="fs30" style="color:black;">选择门店</view> | |
| 500 | - </view> | |
| 501 | - <view class="red_bb fs26">更多门店<text class="bg_jj"></text></view> | |
| 502 | - </view> | |
| 503 | - <view wx:if="{{def_pick_store && def_pick_store.pickup_name}}"> | |
| 504 | - <view class="flex-space-between address ai_end pdv10"> | |
| 505 | - <view> | |
| 506 | - <text class="fs30 xc-black3 shop_name bold">{{def_pick_store.pickup_name}}</text> | |
| 507 | - </view> | |
| 508 | - <view class="distance fs24" wx:if="{{def_pick_store.distance!=null}}"> | |
| 509 | - 距离:{{def_pick_store.distance>1000?filters.toFix(def_pick_store.distance/1000,2)+"km":filters.toFix(def_pick_store.distance,0)+"m"}} | |
| 510 | - </view> | |
| 511 | - </view> | |
| 512 | - <view class="no_store" wx:if="{{only_pk && !only_pk.length}}">(库存不足)</view> | |
| 513 | - <block wx:else> | |
| 514 | - <view class="no_store" wx:if="{{def_pickpu_list && !def_pickpu_list.length}}"> | |
| 515 | - (库存不足) | |
| 516 | - </view> | |
| 517 | - <block wx:else> | |
| 518 | - <view class="no_store" wx:if="{{def_pick_store && def_pick_store.is_no_dis}}"> | |
| 519 | - (配送不匹配) | |
| 520 | - </view> | |
| 521 | - <view class="no_store" wx:elif="{{def_pick_store && !def_pick_store.CanOutQty && sales_rules==2 && prom_type==0}}"> | |
| 522 | - (库存不足) | |
| 523 | - </view> | |
| 524 | - </block> | |
| 525 | - </block> | |
| 526 | - <view class="fs24 xc-ash-9f">地址:{{def_pick_store.fulladdress}}</view> | |
| 527 | - </view> | |
| 528 | - </view> | |
| 529 | - </view> | |
| 530 | - <!-- 许程 7.24暂时注释 --> | |
| 531 | - <view class="bdt16" wx:if="{{prom_type!=1&& prom_type!=1 && prom_act.kttype!=3&&prom_act.kttype!=2&&prom_act.kttype!=1 && is_closecoupon!=1}}"> | |
| 532 | - <view class="cx-frame flex" style="position: relative" wx:if="{{fir_quan.length>0}}"> | |
| 533 | - <view class="cx-sizs fs30">领券</view> | |
| 534 | - <view class="flex ai_c f1 pdh20"> | |
| 535 | - <view class="xc-coupon-fram" wx:for="{{fir_quan}}" wx:key="id"> | |
| 536 | - <view class="circle xc-circular xc-one"></view> | |
| 537 | - <view class="xc-coupon t-c four-level-word"> | |
| 538 | - 满{{item.condition}}减{{item.money}} | |
| 539 | - </view> | |
| 540 | - <view class="circle xc-circular xc-two"></view> | |
| 541 | - </view> | |
| 542 | - </view> | |
| 543 | - <view data-coupon="1" bindtap="switchCoupon" class="cx-obtain-coupon wsize"> | |
| 544 | - <text class="bg_jj"></text> | |
| 545 | - </view> | |
| 546 | - </view> | |
| 547 | - </view> | |
| 493 | + | |
| 494 | + | |
| 548 | 495 | <!-- 要判断是不是有促销活动 --> |
| 549 | 496 | <block wx:if="{{prom_goods}}"> |
| 550 | 497 | <view class="cx-frame flex" style="position: relative; height: auto" hidden="{{prom_type==4 || prom_type==6}}"> |
| ... | ... | @@ -601,7 +548,6 @@ |
| 601 | 548 | </view> |
| 602 | 549 | </block> |
| 603 | 550 | |
| 604 | - | |
| 605 | 551 | <!-- 要判断是不是有订单优惠 --> |
| 606 | 552 | <block wx:if="{{order_prom}}"> |
| 607 | 553 | <view class="cx-frame flex" style="position: relative; height: auto"> |
| ... | ... | @@ -664,7 +610,61 @@ |
| 664 | 610 | </view> |
| 665 | 611 | </block> |
| 666 | 612 | </block> |
| 667 | - | |
| 613 | + <!-- 许程 7.24暂时注释 --> | |
| 614 | + <view class="bdt16" wx:if="{{prom_type!=1&& prom_type!=1 && prom_act.kttype!=3&&prom_act.kttype!=2&&prom_act.kttype!=1 && is_closecoupon!=1}}"> | |
| 615 | + <view class="cx-frame flex" style="position: relative" wx:if="{{fir_quan.length>0}}"> | |
| 616 | + <view class="cx-sizs fs30">领券</view> | |
| 617 | + <view class="flex ai_c f1 pdh20"> | |
| 618 | + <view class="xc-coupon-fram" wx:for="{{fir_quan}}" wx:key="id"> | |
| 619 | + <view class="circle xc-circular xc-one"></view> | |
| 620 | + <view class="xc-coupon t-c four-level-word"> | |
| 621 | + 满{{item.condition}}减{{item.money}} | |
| 622 | + </view> | |
| 623 | + <view class="circle xc-circular xc-two"></view> | |
| 624 | + </view> | |
| 625 | + </view> | |
| 626 | + <view data-coupon="1" bindtap="switchCoupon" class="cx-obtain-coupon wsize"> | |
| 627 | + <text class="bg_jj"></text> | |
| 628 | + </view> | |
| 629 | + </view> | |
| 630 | + </view> | |
| 631 | + <!-- 门店收货地址 --> | |
| 632 | + <view class="xc-address_frame bdt16 flex-vertical xc-ash {{def_pick_store!=null?'sn_height':'on_height'}}"> | |
| 633 | + <view class="address_frame" bindtap="choice_store" data-ind="0"> | |
| 634 | + <view class="flex-vertical-between "> | |
| 635 | + <view class="flex-vertical select_store_height"> | |
| 636 | + <image class="stores-img" src="{{iurl}}/miniapp/images/stores.png"></image> | |
| 637 | + <view class="fs30" style="color:black;">选择门店</view> | |
| 638 | + </view> | |
| 639 | + <view class="red_bb fs26">更多门店<text class="bg_jj"></text></view> | |
| 640 | + </view> | |
| 641 | + <view wx:if="{{def_pick_store && def_pick_store.pickup_name}}"> | |
| 642 | + <view class="flex-space-between address ai_end pdv10"> | |
| 643 | + <view> | |
| 644 | + <text class="fs30 xc-black3 shop_name bold">{{def_pick_store.pickup_name}}</text> | |
| 645 | + </view> | |
| 646 | + <view class="distance fs24" wx:if="{{def_pick_store.distance!=null}}"> | |
| 647 | + 距离:{{def_pick_store.distance>1000?filters.toFix(def_pick_store.distance/1000,2)+"km":filters.toFix(def_pick_store.distance,0)+"m"}} | |
| 648 | + </view> | |
| 649 | + </view> | |
| 650 | + <view class="no_store" wx:if="{{only_pk && !only_pk.length}}">(库存不足)</view> | |
| 651 | + <block wx:else> | |
| 652 | + <view class="no_store" wx:if="{{def_pickpu_list && !def_pickpu_list.length}}"> | |
| 653 | + (库存不足) | |
| 654 | + </view> | |
| 655 | + <block wx:else> | |
| 656 | + <view class="no_store" wx:if="{{def_pick_store && def_pick_store.is_no_dis}}"> | |
| 657 | + (配送不匹配) | |
| 658 | + </view> | |
| 659 | + <view class="no_store" wx:elif="{{def_pick_store && !def_pick_store.CanOutQty && sales_rules==2 && prom_type==0}}"> | |
| 660 | + (库存不足) | |
| 661 | + </view> | |
| 662 | + </block> | |
| 663 | + </block> | |
| 664 | + <view class="fs24 xc-ash-9f">地址:{{def_pick_store.fulladdress}}</view> | |
| 665 | + </view> | |
| 666 | + </view> | |
| 667 | + </view> | |
| 668 | 668 | <!-- 保障服务 --> |
| 669 | 669 | <view class="bz_view flex bdt16 ai_c" wx:if="{{bconfig.service_bz}}"> |
| 670 | 670 | <image class="bzfu_img" src="{{iurl}}/miniapp/images/bzfu_w.png"></image> |
| ... | ... | @@ -676,7 +676,6 @@ |
| 676 | 676 | </view> |
| 677 | 677 | </view> |
| 678 | 678 | </view> |
| 679 | - | |
| 680 | 679 | <!-- - 搭配促销 -- --> |
| 681 | 680 | <view class="dp_cx_view" wx:if="{{collocationGoods}}"> |
| 682 | 681 | <view class="bb_view"> | ... | ... |
pages/goods/search/g_filter.wxs
| 1 | 1 | var g_filters = { |
| 2 | - //-- 判断是不是有等级价 -- | |
| 3 | - is_has_rank:function(rank_switch,item){ | |
| 4 | - if(!rank_switch) return false; | |
| 5 | - if(item.cardprice1 || item.cardprice2 || item.cardprice3) {return true} | |
| 6 | - return false; | |
| 7 | - }, | |
| 8 | - | |
| 9 | - //-- 判断,不是等级会员时候,要显示的最低等级价和名称 -- | |
| 10 | - get_card_price:function(goods,all_card,type){ | |
| 11 | - var price1=parseFloat(goods['cardprice1']); | |
| 12 | - var price2=parseFloat(goods['cardprice2']); | |
| 13 | - var price3=parseFloat(goods['cardprice3']); | |
| 14 | - if(!all_card){ | |
| 15 | - if(type==0) return 0; | |
| 16 | - return ""; | |
| 17 | - } | |
| 18 | - | |
| 19 | - var arr=[]; | |
| 20 | - var min_price= 0; | |
| 21 | - var min_name=""; | |
| 22 | - | |
| 23 | - var min_price=null; | |
| 24 | - var min_name=null; | |
| 25 | - //---设置对应的价格名字---- | |
| 26 | - for(var i=0;i<3;i++) { | |
| 27 | - var vl=all_card[i]; | |
| 28 | - if(!vl) continue; | |
| 29 | - if(vl['CorrPrice']=="Price1" && price1>0) | |
| 30 | - { | |
| 31 | - if(min_price==null) { | |
| 32 | - min_price=price1;min_name=vl['CardName']; | |
| 33 | - } | |
| 34 | - else if(price1<min_price) { | |
| 35 | - min_price=price1;min_name=vl['CardName']; | |
| 36 | - } | |
| 37 | - } | |
| 38 | - if(vl['CorrPrice']=="Price2" && price2>0) | |
| 39 | - { | |
| 40 | - if(min_price==null) { | |
| 41 | - min_price=price2;min_name=vl['CardName']; | |
| 42 | - } | |
| 43 | - else if(price2<min_price) { | |
| 44 | - min_price=price2;min_name=vl['CardName']; | |
| 45 | - } | |
| 46 | - } | |
| 47 | - | |
| 48 | - if(vl['CorrPrice']=="Price3" && price3>0) | |
| 49 | - { | |
| 50 | - if(min_price==null) { | |
| 51 | - min_price=price3;min_name=vl['CardName']; | |
| 52 | - } | |
| 53 | - else if(price3<min_price) { | |
| 54 | - min_price=price3;min_name=vl['CardName']; | |
| 55 | - } | |
| 56 | - } | |
| 57 | - | |
| 58 | - } | |
| 59 | - if(min_price==null){ | |
| 60 | - if(type==0) return 0; | |
| 61 | - return ""; | |
| 62 | - } | |
| 63 | - | |
| 64 | - //if(type==0) return arr.length; | |
| 65 | - //--进行排序,升序--- | |
| 66 | - /*--- | |
| 67 | - arr.sort(function(a,b){ | |
| 68 | - if (a.price < b.price) { | |
| 69 | - return -1; | |
| 70 | - } else if (a.fee == b.fee) { | |
| 71 | - return 0; | |
| 72 | - } else { | |
| 73 | - return 1; | |
| 74 | - } | |
| 75 | - })--*/ | |
| 76 | - //-- 获取最下价钱,和相应的卡的名称 -- | |
| 77 | - //min_price=min.price; | |
| 78 | - //min_name=min.name; | |
| 79 | - if(type==0) return min_price.toFixed(2); | |
| 80 | - if(min_name.length>7 ) min_name=min_name.substring(0, 8); | |
| 81 | - return min_name; | |
| 82 | - }, | |
| 2 | + //-- 判断是不是有等级价 -- | |
| 3 | + is_has_rank: function (rank_switch, item) { | |
| 4 | + if (!rank_switch) return false; | |
| 5 | + if (item.cardprice1 || item.cardprice2 || item.cardprice3) { return true } | |
| 6 | + return false; | |
| 7 | + }, | |
| 83 | 8 | |
| 9 | + //-- 判断,不是等级会员时候,要显示的最低等级价和名称 -- | |
| 10 | + get_card_price: function (goods, all_card, type) { | |
| 11 | + var price1 = parseFloat(goods['cardprice1']); | |
| 12 | + var price2 = parseFloat(goods['cardprice2']); | |
| 13 | + var price3 = parseFloat(goods['cardprice3']); | |
| 14 | + if (!all_card) { | |
| 15 | + if (type == 0) return 0; | |
| 16 | + return ""; | |
| 17 | + } | |
| 84 | 18 | |
| 85 | - get_goods_url:function(item){ | |
| 19 | + var arr = []; | |
| 20 | + var min_price = 0; | |
| 21 | + var min_name = ""; | |
| 86 | 22 | |
| 87 | - var url1="/pages/goods/goodsInfo/goodsInfo?goods_id="+item.goods_id | |
| 88 | - // 预售活动 | |
| 89 | - if(item.prom_type==8){ | |
| 90 | - url1="/packageC/pages/presell/goodsInfo/goodsInfo?goods_id="+item.goods_id+"&prom_id="+item.prom_id | |
| 91 | - } | |
| 92 | - // 如果是幸运购活动商品 | |
| 93 | - if(item.prom_type == 9){ | |
| 94 | - url1 = "/packageC/pages/luckyGo/luckyGo_goodsInfo/luckyGo_goodsInfo?goods_id=" + item.goods_id + "&group_id=" + item.prom_id | |
| 95 | - } | |
| 96 | - | |
| 97 | - if(item.prom_type==1 && item.prom_id>0){ | |
| 98 | - url1="/pages/goods/goodsInfo/goodsInfo?goods_id="+item.goods_id+"&prom_id="+item.prom_id+"&prom_type=1"; | |
| 99 | - } | |
| 100 | - return url1; | |
| 101 | - } | |
| 23 | + var min_price = null; | |
| 24 | + var min_name = null; | |
| 25 | + //---设置对应的价格名字---- | |
| 26 | + for (var i = 0; i < 3; i++) { | |
| 27 | + var vl = all_card[i]; | |
| 28 | + if (!vl) continue; | |
| 29 | + if (vl['CorrPrice'] == "Price1" && price1 > 0) { | |
| 30 | + if (min_price == null) { | |
| 31 | + min_price = price1; min_name = vl['CardName']; | |
| 32 | + } | |
| 33 | + else if (price1 < min_price) { | |
| 34 | + min_price = price1; min_name = vl['CardName']; | |
| 35 | + } | |
| 36 | + } | |
| 37 | + if (vl['CorrPrice'] == "Price2" && price2 > 0) { | |
| 38 | + if (min_price == null) { | |
| 39 | + min_price = price2; min_name = vl['CardName']; | |
| 40 | + } | |
| 41 | + else if (price2 < min_price) { | |
| 42 | + min_price = price2; min_name = vl['CardName']; | |
| 43 | + } | |
| 44 | + } | |
| 45 | + | |
| 46 | + if (vl['CorrPrice'] == "Price3" && price3 > 0) { | |
| 47 | + if (min_price == null) { | |
| 48 | + min_price = price3; min_name = vl['CardName']; | |
| 49 | + } | |
| 50 | + else if (price3 < min_price) { | |
| 51 | + min_price = price3; min_name = vl['CardName']; | |
| 52 | + } | |
| 53 | + } | |
| 54 | + | |
| 55 | + } | |
| 56 | + if (min_price == null) { | |
| 57 | + if (type == 0) return 0; | |
| 58 | + return ""; | |
| 59 | + } | |
| 60 | + | |
| 61 | + //if(type==0) return arr.length; | |
| 62 | + //--进行排序,升序--- | |
| 63 | + /*--- | |
| 64 | + arr.sort(function(a,b){ | |
| 65 | + if (a.price < b.price) { | |
| 66 | + return -1; | |
| 67 | + } else if (a.fee == b.fee) { | |
| 68 | + return 0; | |
| 69 | + } else { | |
| 70 | + return 1; | |
| 71 | + } | |
| 72 | + })--*/ | |
| 73 | + //-- 获取最下价钱,和相应的卡的名称 -- | |
| 74 | + //min_price=min.price; | |
| 75 | + //min_name=min.name; | |
| 76 | + if (type == 0) return min_price.toFixed(2); | |
| 77 | + if (min_name.length > 7) min_name = min_name.substring(0, 8); | |
| 78 | + return min_name; | |
| 79 | + }, | |
| 80 | + | |
| 81 | + | |
| 82 | + get_goods_url: function (item) { | |
| 83 | + | |
| 84 | + var url1 = "/pages/goods/goodsInfo/goodsInfo?goods_id=" + item.goods_id | |
| 85 | + // 预售活动 | |
| 86 | + if (item.prom_type == 8) { | |
| 87 | + url1 = "/packageC/pages/presell/goodsInfo/goodsInfo?goods_id=" + item.goods_id + "&prom_id=" + item.prom_id | |
| 88 | + } | |
| 89 | + // 如果是幸运购活动商品 | |
| 90 | + if (item.prom_type == 9) { | |
| 91 | + url1 = "/packageC/pages/luckyGo/luckyGo_goodsInfo/luckyGo_goodsInfo?goods_id=" + item.goods_id + "&group_id=" + item.prom_id | |
| 92 | + } | |
| 93 | + | |
| 94 | + if (item.prom_type == 1 && item.prom_id > 0) { | |
| 95 | + url1 = "/pages/goods/goodsInfo/goodsInfo?goods_id=" + item.goods_id + "&prom_id=" + item.prom_id + "&prom_type=1"; | |
| 96 | + } | |
| 97 | + return url1; | |
| 98 | + } | |
| 102 | 99 | } |
| 103 | 100 | |
| 104 | 101 | module.exports = { |
| 105 | - is_has_rank:g_filters.is_has_rank, | |
| 106 | - get_card_price:g_filters.get_card_price, | |
| 107 | - get_goods_url:g_filters.get_goods_url | |
| 102 | + is_has_rank: g_filters.is_has_rank, | |
| 103 | + get_card_price: g_filters.get_card_price, | |
| 104 | + get_goods_url: g_filters.get_goods_url | |
| 108 | 105 | } |
| 109 | 106 | \ No newline at end of file | ... | ... |
pages/index/index/index.js
pages/user/address_list/address_list.js
| ... | ... | @@ -56,10 +56,8 @@ Page({ |
| 56 | 56 | var arr1 = e.data.addresses; |
| 57 | 57 | var arr2 = t.data.data.pageData; |
| 58 | 58 | var arr3 = [...arr1, ...arr2]; |
| 59 | - | |
| 60 | 59 | var ismore = 0; |
| 61 | 60 | if (arr3.length == t.data.data.total) ismore = 1 |
| 62 | - | |
| 63 | 61 | e.setData({ |
| 64 | 62 | addresses: arr3, total: t.data.data.total, ismore: ismore, |
| 65 | 63 | is_address_read:1 | ... | ... |
pages/user/address_list/address_list.wxml
| ... | ... | @@ -32,7 +32,7 @@ |
| 32 | 32 | <view class="address-box"> |
| 33 | 33 | |
| 34 | 34 | <!-- 单个收货地址框架 --> |
| 35 | - <view class="address-user" wx:for="{{addresses}}" wx:key="{{index}}"> | |
| 35 | + <view class="address-user" wx:for="{{addresses}}" wx:key="index"> | |
| 36 | 36 | <!-- 选择icon |
| 37 | 37 | <view class="icon"> |
| 38 | 38 | <icon type="success" color="red" size="33rpx" wx:if="{{item.is_pickup==1}}" bindtap="add_is_pickup" data-icon="{{index}}"></icon> | ... | ... |
pages/user/order_list/order_list.js
| ... | ... | @@ -2224,35 +2224,176 @@ Page({ |
| 2224 | 2224 | }, |
| 2225 | 2225 | |
| 2226 | 2226 | // 卡项订单 - 立即支付 |
| 2227 | - pay(e) { | |
| 2227 | + pay: async function(e) { | |
| 2228 | 2228 | let index = e.currentTarget.dataset.index; |
| 2229 | 2229 | let item = this.data.cardList[index]; |
| 2230 | 2230 | let order_sn = item.order_sn; |
| 2231 | 2231 | let order_id = item.order_id; |
| 2232 | 2232 | let store_id = app.globalData.setting.stoid; |
| 2233 | - // console.log('go1!!!!!!!!!!!!!!!!!!!!!!!!!',index,item,order_sn,store_id); | |
| 2233 | + let user_id = oo.user_id; | |
| 2234 | + let flag = true; | |
| 2235 | + | |
| 2236 | + | |
| 2237 | + // 如果是普通购买或单独购买,不用判断 | |
| 2238 | + // 如果是秒杀购买:1、判断活动是否变化;2、是否超出限购 | |
| 2239 | + | |
| 2240 | + let list = item.list; | |
| 2241 | + for(const it of list) { | |
| 2242 | + if(it.prom_type == 1) { | |
| 2243 | + let act_details = null; | |
| 2244 | + let redis_num = 0; | |
| 2245 | + let promcardbuynum = 0; | |
| 2246 | + let qty = it.qty; | |
| 2247 | + | |
| 2248 | + | |
| 2249 | + await getApp().request.promiseGet('/api/ms/flash_sale/getNew/' + store_id + '/' + user_id + '/' + it.prom_id, {}).then(res => { | |
| 2250 | + console.log('11111111====>>>'); | |
| 2251 | + if(res.data.code == 0) { | |
| 2252 | + console.log('当前的秒杀活动信息:', res.data.data); | |
| 2253 | + act_details = res.data.data; | |
| 2254 | + if(act_details.is_end == 1) { | |
| 2255 | + wx.showModal({ | |
| 2256 | + title: '提示', | |
| 2257 | + content: '活动已结束,无法支付,请取消订单!', | |
| 2258 | + showCancel: false, | |
| 2259 | + }); | |
| 2260 | + flag = false; | |
| 2261 | + return false; | |
| 2262 | + }; | |
| 2263 | + if(act_details.id != it.prom_id) { | |
| 2264 | + wx.showModal({ | |
| 2265 | + title: '提示', | |
| 2266 | + content: '活动发生了变化,无法支付,请取消订单,重新购买!', | |
| 2267 | + showCancel: false, | |
| 2268 | + }); | |
| 2269 | + flag = false; | |
| 2270 | + return false; | |
| 2271 | + }; | |
| 2272 | + }; | |
| 2273 | + }); | |
| 2274 | + | |
| 2275 | + await getApp().request.promiseGet('/api/weshop/activitylist/getActLen/' + store_id + '/' + it.prom_type + '/' + it.prom_id, { | |
| 2276 | + 1: 1 | |
| 2277 | + }).then(res => { | |
| 2278 | + console.log('222222222====>>>'); | |
| 2279 | + if (res.data.code == 0) { | |
| 2280 | + // 当前可以购买的数量 | |
| 2281 | + console.log('redis当前可以购买的数量:', res.data.data); | |
| 2282 | + redis_num = res.data.data; | |
| 2283 | + // if(redis_num <=0) { | |
| 2284 | + // wx.showModal({ | |
| 2285 | + // title: '提示', | |
| 2286 | + // content: '活动库存不足,无法支付,请取消订单!', | |
| 2287 | + // showCancel: false, | |
| 2288 | + // }); | |
| 2289 | + // // flag = false; | |
| 2290 | + // return true; | |
| 2291 | + // }; | |
| 2292 | + }; | |
| 2293 | + }); | |
| 2294 | + | |
| 2295 | + await getApp().request.promiseGet("/api/weshop/rechargeServicelist/getUserBuyGoodsNum", { | |
| 2296 | + data: { | |
| 2297 | + store_id: store_id, | |
| 2298 | + user_id: user_id, | |
| 2299 | + card_id: it.card_id, | |
| 2300 | + prom_type: it.prom_type, | |
| 2301 | + prom_id: it.prom_id, | |
| 2302 | + } | |
| 2303 | + }).then(res => { | |
| 2304 | + console.log('333333333====>>>'); | |
| 2305 | + if (res.data.code == 0) { | |
| 2306 | + console.log('已经购买的数量:', res.data.data); | |
| 2307 | + promcardbuynum = res.data.data.promcardbuynum; | |
| 2308 | + | |
| 2309 | + | |
| 2310 | + let limited = act_details.buy_limit; // 限购数量a | |
| 2311 | + let buyedNum = promcardbuynum; // 自己已经购买的数量b | |
| 2312 | + let canBuyNum = limited - buyedNum; // 自己还可购买的数量c | |
| 2313 | + | |
| 2314 | + | |
| 2315 | + if(canBuyNum <= 0) { | |
| 2316 | + wx.showModal({ | |
| 2317 | + title: '提示', | |
| 2318 | + content: '您已超出活动限购数量,无法支付,请取消订单!', | |
| 2319 | + showCancel: false, | |
| 2320 | + }); | |
| 2321 | + flag = false; | |
| 2322 | + return false; | |
| 2323 | + }; | |
| 2324 | + | |
| 2325 | + if(limited > redis_num) { | |
| 2326 | + if(canBuyNum <= redis_num) { | |
| 2327 | + if(qty > canBuyNum) { | |
| 2328 | + wx.showModal({ | |
| 2329 | + title: '提示', | |
| 2330 | + content: '您已超出活动限购数量,无法支付,请取消订单!', | |
| 2331 | + showCancel: false, | |
| 2332 | + }); | |
| 2333 | + flag = false; | |
| 2334 | + return false; | |
| 2335 | + }; | |
| 2336 | + | |
| 2337 | + }; | |
| 2338 | + | |
| 2339 | + if(canBuyNum > redis_num) { | |
| 2340 | + if(qty > redis_num) { | |
| 2341 | + wx.showModal({ | |
| 2342 | + title: '提示', | |
| 2343 | + content: '活动库存不足,无法支付,请取消订单!', | |
| 2344 | + showCancel: false, | |
| 2345 | + }); | |
| 2346 | + flag = false; | |
| 2347 | + return false; | |
| 2348 | + }; | |
| 2349 | + | |
| 2350 | + }; | |
| 2351 | + }; | |
| 2352 | + | |
| 2353 | + if(limited <= redis_num) { | |
| 2354 | + if(qty > canBuyNum) { | |
| 2355 | + wx.showModal({ | |
| 2356 | + title: '提示', | |
| 2357 | + content: '您已超出活动限购数量,无法支付,请取消订单!', | |
| 2358 | + showCancel: false, | |
| 2359 | + }); | |
| 2360 | + flag = false; | |
| 2361 | + return false; | |
| 2362 | + }; | |
| 2363 | + }; | |
| 2364 | + }; | |
| 2365 | + }); | |
| 2366 | + | |
| 2367 | + }; | |
| 2368 | + | |
| 2369 | + }; | |
| 2370 | + | |
| 2234 | 2371 | |
| 2235 | - app.request.post('/api/weshop/order/pay/createRechargeOrder', { | |
| 2236 | - data: { | |
| 2237 | - parentSn: order_sn, | |
| 2238 | - store_id: store_id, | |
| 2239 | - }, | |
| 2372 | + if(flag) { | |
| 2373 | + await app.request.promisePost('/api/weshop/order/pay/createRechargeOrder', { | |
| 2374 | + data: { | |
| 2375 | + parentSn: order_sn, | |
| 2376 | + store_id: store_id, | |
| 2377 | + }, | |
| 2378 | + }).then(res => { | |
| 2379 | + // success: function(res) { | |
| 2380 | + var n = res.data.data; | |
| 2381 | + self.weixinPay(n, function() { | |
| 2382 | + app.showWarning('支付成功'); | |
| 2383 | + | |
| 2384 | + }, function() { | |
| 2385 | + app.showWarning('支付失败'); | |
| 2386 | + // setTimeout(function() { | |
| 2387 | + // wx.reLaunch({ | |
| 2388 | + // url: '/packageA/pages/cardList/cardList', | |
| 2389 | + // }) | |
| 2390 | + // }, 1000) | |
| 2391 | + }); | |
| 2392 | + // } | |
| 2393 | + }); | |
| 2394 | + }; | |
| 2395 | + | |
| 2240 | 2396 | |
| 2241 | - success: function(res) { | |
| 2242 | - var n = res.data.data; | |
| 2243 | - self.weixinPay(n, function() { | |
| 2244 | - app.showWarning('支付成功'); | |
| 2245 | - | |
| 2246 | - }, function() { | |
| 2247 | - app.showWarning('支付失败'); | |
| 2248 | - // setTimeout(function() { | |
| 2249 | - // wx.reLaunch({ | |
| 2250 | - // url: '/packageA/pages/cardList/cardList', | |
| 2251 | - // }) | |
| 2252 | - // }, 1000) | |
| 2253 | - }); | |
| 2254 | - } | |
| 2255 | - }) | |
| 2256 | 2397 | }, |
| 2257 | 2398 | |
| 2258 | 2399 | //------调起支付框-------- | ... | ... |