Commit 1b940ef9282ff8d14c511c4f06e6cd9219d86d5e
1 parent
aed8e658
购物车和确认订单页面的优化
Showing
5 changed files
with
1115 additions
and
820 deletions
app.js
@@ -51,7 +51,7 @@ App({ | @@ -51,7 +51,7 @@ App({ | ||
51 | config: null, //门店参数 | 51 | config: null, //门店参数 |
52 | config2: null, //门店配置 | 52 | config2: null, //门店配置 |
53 | code: null, | 53 | code: null, |
54 | - user_id:null,//6520491,// 6519913,//6520352 | 54 | + user_id:null, //6520509,//6520491,// 6519913,//6520352 |
55 | // user_id:6520314,// qa-6519858,// | 55 | // user_id:6520314,// qa-6519858,// |
56 | // user_id:14148118,// qa-6519858,// | 56 | // user_id:14148118,// qa-6519858,// |
57 | buy_now: null, | 57 | buy_now: null, |
@@ -1584,6 +1584,15 @@ App({ | @@ -1584,6 +1584,15 @@ App({ | ||
1584 | return cx_arr; | 1584 | return cx_arr; |
1585 | }, | 1585 | }, |
1586 | 1586 | ||
1587 | + get_has_cx_act2(act_arr){ | ||
1588 | + var cx_arr=[]; | ||
1589 | + if(act_arr && act_arr.length) | ||
1590 | + cx_arr=act_arr.filter(function (e) { | ||
1591 | + return e.s_time < ut.gettimestamp() && [3,5,7,10].indexOf(e.prom_type)>-1; | ||
1592 | + }) | ||
1593 | + return cx_arr; | ||
1594 | + }, | ||
1595 | + | ||
1587 | //-- 获取判断注册成功后,是跳转等级卡,还是新人有礼 -- | 1596 | //-- 获取判断注册成功后,是跳转等级卡,还是新人有礼 -- |
1588 | async go_to_page(is_reg,func){ | 1597 | async go_to_page(is_reg,func){ |
1589 | if(!is_reg) { | 1598 | if(!is_reg) { |
packageE/pages/cart/cart2/cart2.js
@@ -170,7 +170,12 @@ Page({ | @@ -170,7 +170,12 @@ Page({ | ||
170 | showFold:true, | 170 | showFold:true, |
171 | 171 | ||
172 | ly_map:{}, | 172 | ly_map:{}, |
173 | - template_id:[] | 173 | + template_id:[], |
174 | + | ||
175 | + //用于后台计算的多促销集合 | ||
176 | + show_can_cx_map:{}, | ||
177 | + //优惠促销活动的集合 | ||
178 | + yhcx_act_map: {}, | ||
174 | }, | 179 | }, |
175 | 180 | ||
176 | 181 | ||
@@ -909,7 +914,7 @@ Page({ | @@ -909,7 +914,7 @@ Page({ | ||
909 | var th = this, app = getApp(); | 914 | var th = this, app = getApp(); |
910 | var state = 0; | 915 | var state = 0; |
911 | if (th.data.state) state = 1; | 916 | if (th.data.state) state = 1; |
912 | - a.get("/api/weshop/cart/list", { | 917 | + a.get("/api/weshop/cart/listNew1", { |
913 | data: { | 918 | data: { |
914 | user_id: to.globalData.user_id, selected: 1, state: state, | 919 | user_id: to.globalData.user_id, selected: 1, state: state, |
915 | store_id: oo.stoid, pageSize: 600, | 920 | store_id: oo.stoid, pageSize: 600, |
@@ -926,18 +931,18 @@ Page({ | @@ -926,18 +931,18 @@ Page({ | ||
926 | if (pick_id_arr.length == 0 || pick_id_arr.indexOf(carr[i].pick_id) == -1) | 931 | if (pick_id_arr.length == 0 || pick_id_arr.indexOf(carr[i].pick_id) == -1) |
927 | pick_id_arr.push(carr[i].pick_id); | 932 | pick_id_arr.push(carr[i].pick_id); |
928 | } | 933 | } |
929 | - var req_d = { | ||
930 | - store_id: os.stoid, ids: pick_id_arr.join(',') | ||
931 | - } | ||
932 | - //-- 获取门店的列表 -- | ||
933 | - await getApp().request.promiseGet("/api/weshop/pickup/list", { data: req_d }).then(res => { | ||
934 | - if (ut.ajax_ok(res)) { | ||
935 | - th.data.allsto = res.data.data.pageData; | ||
936 | - } | ||
937 | - }) | 934 | + //-- 门店不在获取2024-2-3 -- |
935 | + // var req_d = { | ||
936 | + // store_id: os.stoid, ids: pick_id_arr.join(',') | ||
937 | + // } | ||
938 | + // //-- 获取门店的列表 -- | ||
939 | + // await getApp().request.promiseGet("/api/weshop/pickup/list", { data: req_d }).then(res => { | ||
940 | + // if (ut.ajax_ok(res)) { | ||
941 | + // th.data.allsto = res.data.data.pageData; | ||
942 | + // } | ||
943 | + // }) | ||
938 | 944 | ||
939 | th.data.cartlist_y =JSON.parse(JSON.stringify(carr)); //存储原始购物车列表 | 945 | th.data.cartlist_y =JSON.parse(JSON.stringify(carr)); //存储原始购物车列表 |
940 | - | ||
941 | wx.showLoading(); | 946 | wx.showLoading(); |
942 | 947 | ||
943 | th.get_cart_next(carr); | 948 | th.get_cart_next(carr); |
@@ -950,7 +955,7 @@ Page({ | @@ -950,7 +955,7 @@ Page({ | ||
950 | is_last(gid,goods,map){ | 955 | is_last(gid,goods,map){ |
951 | let last_id=0; | 956 | let last_id=0; |
952 | for (let i = 0; i <goods.length ; i++) { | 957 | for (let i = 0; i <goods.length ; i++) { |
953 | - if(map.indexOf(goods[i].goods_id)>-1){ | 958 | + if(map && map.indexOf(goods[i].goods_id)>-1){ |
954 | last_id=goods[i].goods_id; | 959 | last_id=goods[i].goods_id; |
955 | } | 960 | } |
956 | } | 961 | } |
@@ -958,6 +963,7 @@ Page({ | @@ -958,6 +963,7 @@ Page({ | ||
958 | return false; | 963 | return false; |
959 | }, | 964 | }, |
960 | 965 | ||
966 | + | ||
961 | //-- is_change是有没有切换活动的意思 -- | 967 | //-- is_change是有没有切换活动的意思 -- |
962 | async get_cart_next(carr,is_change,old_prom){ | 968 | async get_cart_next(carr,is_change,old_prom){ |
963 | 969 | ||
@@ -973,7 +979,7 @@ Page({ | @@ -973,7 +979,7 @@ Page({ | ||
973 | 979 | ||
974 | var c_ok=1; | 980 | var c_ok=1; |
975 | if(old_prom && (carr[ir].prom_type!=old_prom.prom_type || carr[ir].prom_id!=old_prom.prom_id) ){ | 981 | if(old_prom && (carr[ir].prom_type!=old_prom.prom_type || carr[ir].prom_id!=old_prom.prom_id) ){ |
976 | - c_ok=0; | 982 | + c_ok=0; |
977 | } | 983 | } |
978 | 984 | ||
979 | if(carr[ir].is_gift && carr[ir].id && c_ok) { | 985 | if(carr[ir].is_gift && carr[ir].id && c_ok) { |
@@ -995,22 +1001,22 @@ Page({ | @@ -995,22 +1001,22 @@ Page({ | ||
995 | var map=this.data.prom_goods_map; | 1001 | var map=this.data.prom_goods_map; |
996 | if(map){ | 1002 | if(map){ |
997 | for (var ky in map) { | 1003 | for (var ky in map) { |
998 | - if(map[ky]){ | ||
999 | - var ob=map[ky]; | ||
1000 | - for (var ii in ob) { | ||
1001 | - var item_map = ob[ii]; | ||
1002 | - if (item_map.hasOwnProperty('cy_cx')) { | ||
1003 | - delete item_map.cy_cx; | ||
1004 | - } | ||
1005 | - } | 1004 | + if(map[ky]){ |
1005 | + var ob=map[ky]; | ||
1006 | + for (var ii in ob) { | ||
1007 | + var item_map = ob[ii]; | ||
1008 | + if (item_map.hasOwnProperty('cy_cx')) { | ||
1009 | + delete item_map.cy_cx; | ||
1010 | + } | ||
1006 | } | 1011 | } |
1012 | + } | ||
1007 | } | 1013 | } |
1008 | } | 1014 | } |
1009 | } | 1015 | } |
1010 | 1016 | ||
1011 | //按门店分类的数组 | 1017 | //按门店分类的数组 |
1012 | var arr = new Array(); | 1018 | var arr = new Array(); |
1013 | - | 1019 | + |
1014 | var th=this; | 1020 | var th=this; |
1015 | th.data.in_zhact_gdmap = {}; | 1021 | th.data.in_zhact_gdmap = {}; |
1016 | //---是不是购买等级卡成功的返回---等级卡显示的判断--- | 1022 | //---是不是购买等级卡成功的返回---等级卡显示的判断--- |
@@ -1018,40 +1024,40 @@ Page({ | @@ -1018,40 +1024,40 @@ Page({ | ||
1018 | 1024 | ||
1019 | //-- 判断组合购是总数量是不是存在 -- | 1025 | //-- 判断组合购是总数量是不是存在 -- |
1020 | var no_zh_num={}; | 1026 | var no_zh_num={}; |
1021 | - | 1027 | + //-- 多促销活动调用接口需要的参数,和商品的购买数量和活动的购买数量的请求参数 -- |
1028 | + var dug_cx_arr = []; | ||
1029 | + //获取 限购 和 多活动的促销---2024-2-1 | ||
1022 | for (var i = 0; i < carr.length; i++) { | 1030 | for (var i = 0; i < carr.length; i++) { |
1023 | 1031 | ||
1024 | - var item1 = carr[i]; | ||
1025 | - //-- 获取一下商品的所有活动 -- | ||
1026 | - await th.buy_pro_group(item1); | ||
1027 | - //把已经购买了多少见的内容填入 | ||
1028 | - var goodsbuynum = 0, promgoodsbuynum = 0; | ||
1029 | - //--要获得商品,该用户买了多少件,同步应用-- | ||
1030 | - await getApp().request.promiseGet("/api/weshop/ordergoods/getUserBuyGoodsNum", { | ||
1031 | - data: { | ||
1032 | - store_id: os.stoid, | ||
1033 | - user_id: getApp().globalData.user_id, | ||
1034 | - goods_id: item1.goods_id, | ||
1035 | - prom_type: item1.prom_type, | ||
1036 | - prom_id: item1.prom_id, | ||
1037 | - isnew:1 | ||
1038 | - }, | ||
1039 | - }).then(res => { | ||
1040 | - var buy_num_data = res.data.data; | ||
1041 | - if (buy_num_data.promgoodsbuynum) { | ||
1042 | - promgoodsbuynum = buy_num_data.promgoodsbuynum; | 1032 | + let item1 = carr[i]; |
1033 | + //如果不是活动的时候,不是代发商品的时候,不是赠品的时候,不是阶梯商品拆分的,不是组合购拆分的 | ||
1034 | + if([1, 2, 4, 6, 8, 9].indexOf(item1.prom_type)== -1 && !item1.whsle_id | ||
1035 | + && !item1.is_gift && !item1.is_ld_split && !item1.is_zh_split ){ | ||
1036 | + //-- 快速查找,组装查询多活动的列表 -- | ||
1037 | + let f_idx=dug_cx_arr.findIndex(function (ele) { | ||
1038 | + return ele.goods_id == item1.goods_id | ||
1039 | + }); | ||
1040 | + if(f_idx==-1) { | ||
1041 | + let gd_ite={ | ||
1042 | + goods_id:carr[i].goods_id, | ||
1043 | + goods_num:1, | ||
1044 | + is_limit_show:1, | ||
1045 | + is_state:0 | ||
1046 | + } | ||
1047 | + dug_cx_arr.push(gd_ite); | ||
1043 | } | 1048 | } |
1044 | - goodsbuynum = buy_num_data.goodsbuynum; | ||
1045 | - }) | ||
1046 | - //如果有购买活动 | ||
1047 | - item1.promgoodsbuynum = promgoodsbuynum; | 1049 | + |
1050 | + } | ||
1048 | 1051 | ||
1049 | if(is_change){ | 1052 | if(is_change){ |
1050 | carr[i].collocationList=null; | 1053 | carr[i].collocationList=null; |
1051 | } | 1054 | } |
1052 | - | ||
1053 | } | 1055 | } |
1054 | 1056 | ||
1057 | + //-- 对商品的多促销进行判断 ---2024-2-1-- | ||
1058 | + if(dug_cx_arr.length){ | ||
1059 | + await th.buy_pro_group(dug_cx_arr,carr); | ||
1060 | + } | ||
1055 | //在分组的时候,就不要再调用接口,await | 1061 | //在分组的时候,就不要再调用接口,await |
1056 | for (var i = 0; i < carr.length; i++) { | 1062 | for (var i = 0; i < carr.length; i++) { |
1057 | var item = carr[i]; | 1063 | var item = carr[i]; |
@@ -1079,10 +1085,9 @@ Page({ | @@ -1079,10 +1085,9 @@ Page({ | ||
1079 | 1085 | ||
1080 | } | 1086 | } |
1081 | 1087 | ||
1082 | - | ||
1083 | //商品的图片不能重复的赋值 | 1088 | //商品的图片不能重复的赋值 |
1084 | if(item.original_img.indexOf(oo.imghost)==-1) | 1089 | if(item.original_img.indexOf(oo.imghost)==-1) |
1085 | - item.original_img = oo.imghost + item.original_img; | 1090 | + item.original_img = oo.imghost + item.original_img; |
1086 | 1091 | ||
1087 | var car_item = item; | 1092 | var car_item = item; |
1088 | /*----接口要弄出来的,先顶着-----*/ | 1093 | /*----接口要弄出来的,先顶着-----*/ |
@@ -1095,10 +1100,10 @@ Page({ | @@ -1095,10 +1100,10 @@ Page({ | ||
1095 | 1100 | ||
1096 | if (arr[j].pickup_id == pcid) { | 1101 | if (arr[j].pickup_id == pcid) { |
1097 | if (item.is_gift != 1) { | 1102 | if (item.is_gift != 1) { |
1098 | - //确定配送方式 | ||
1099 | - if (arr[j].distr_t == 0) { | ||
1100 | - arr[j].distr_t = car_item.distr_type; | ||
1101 | - } | 1103 | + //确定配送方式 |
1104 | + if (arr[j].distr_t == 0) { | ||
1105 | + arr[j].distr_t = car_item.distr_type; | ||
1106 | + } | ||
1102 | }else{ | 1107 | }else{ |
1103 | item.distr_type=0; //赠品不控制物流的方式 | 1108 | item.distr_type=0; //赠品不控制物流的方式 |
1104 | } | 1109 | } |
@@ -1112,10 +1117,10 @@ Page({ | @@ -1112,10 +1117,10 @@ Page({ | ||
1112 | switch (dis_t) { | 1117 | switch (dis_t) { |
1113 | case 0: | 1118 | case 0: |
1114 | if(!arr[j].exp_sure){ | 1119 | if(!arr[j].exp_sure){ |
1115 | - e_t = 1; | ||
1116 | - //-- 系统后台有设置要默认的 -- | ||
1117 | - if (th.data.json_d.pickupway && th.data.json_d.pickupway == 1) e_t = 0; | ||
1118 | - arr[j].exp_type=e_t | 1120 | + e_t = 1; |
1121 | + //-- 系统后台有设置要默认的 -- | ||
1122 | + if (th.data.json_d.pickupway && th.data.json_d.pickupway == 1) e_t = 0; | ||
1123 | + arr[j].exp_type=e_t | ||
1119 | } | 1124 | } |
1120 | break; | 1125 | break; |
1121 | case 1: | 1126 | case 1: |
@@ -1147,8 +1152,8 @@ Page({ | @@ -1147,8 +1152,8 @@ Page({ | ||
1147 | 1152 | ||
1148 | } | 1153 | } |
1149 | if(car_item.is_gift != 1){ | 1154 | if(car_item.is_gift != 1){ |
1150 | - arr[j].exp_type = e_t; | ||
1151 | - if (e_t == 0) th.setData({ is_all_zt: 0 }); | 1155 | + arr[j].exp_type = e_t; |
1156 | + if (e_t == 0) th.setData({ is_all_zt: 0 }); | ||
1152 | } | 1157 | } |
1153 | 1158 | ||
1154 | //else if (e_t == 1) th.setData({ is_all_zt: 1 }); | 1159 | //else if (e_t == 1) th.setData({ is_all_zt: 1 }); |
@@ -1176,13 +1181,12 @@ Page({ | @@ -1176,13 +1181,12 @@ Page({ | ||
1176 | if (find == 0) { | 1181 | if (find == 0) { |
1177 | var pikname = '', sto = null; | 1182 | var pikname = '', sto = null; |
1178 | //----找到门店名称----- | 1183 | //----找到门店名称----- |
1179 | - for (var k = 0; k < th.data.allsto.length; k++) { | ||
1180 | - if (pcid == th.data.allsto[k].pickup_id) { | ||
1181 | - pikname = th.data.allsto[k].pickup_name; | ||
1182 | - sto = th.data.allsto[k]; | ||
1183 | - break; | ||
1184 | - } | ||
1185 | - } | 1184 | + pikname = item.pickup_name; |
1185 | + sto ={ | ||
1186 | + pickup_id:item.pick_id, | ||
1187 | + pickup_name:pikname, | ||
1188 | + distr_type:item.pickup_distr_type | ||
1189 | + }; | ||
1186 | var e_t = 0, dis_t = 0;//物流方式,配送方式 | 1190 | var e_t = 0, dis_t = 0;//物流方式,配送方式 |
1187 | if (item.distr_type == 0) { | 1191 | if (item.distr_type == 0) { |
1188 | dis_t = sto.distr_type; | 1192 | dis_t = sto.distr_type; |
@@ -1191,7 +1195,6 @@ Page({ | @@ -1191,7 +1195,6 @@ Page({ | ||
1191 | } | 1195 | } |
1192 | 1196 | ||
1193 | let exp_sure=0; | 1197 | let exp_sure=0; |
1194 | - | ||
1195 | switch (dis_t) { | 1198 | switch (dis_t) { |
1196 | case 0: | 1199 | case 0: |
1197 | e_t = 1; | 1200 | e_t = 1; |
@@ -1224,12 +1227,10 @@ Page({ | @@ -1224,12 +1227,10 @@ Page({ | ||
1224 | } | 1227 | } |
1225 | } | 1228 | } |
1226 | } | 1229 | } |
1227 | - | ||
1228 | - | ||
1229 | if (back_data && parseFloat(back_data)) { | 1230 | if (back_data && parseFloat(back_data)) { |
1230 | - c_item.can_usecommise = parseFloat(parseFloat(back_data).toFixed(2)); | ||
1231 | - cart_commission += c_item.can_usecommise; | ||
1232 | - } | 1231 | + c_item.can_usecommise = parseFloat(parseFloat(back_data).toFixed(2)); |
1232 | + cart_commission += c_item.can_usecommise; | ||
1233 | + } | ||
1233 | 1234 | ||
1234 | var ie = { | 1235 | var ie = { |
1235 | pickup_id: pcid, | 1236 | pickup_id: pcid, |
@@ -1285,6 +1286,8 @@ Page({ | @@ -1285,6 +1286,8 @@ Page({ | ||
1285 | 1286 | ||
1286 | } | 1287 | } |
1287 | 1288 | ||
1289 | + | ||
1290 | + | ||
1288 | var cart_commission = 0; | 1291 | var cart_commission = 0; |
1289 | //-- 循环计算一下线下取价 -- | 1292 | //-- 循环计算一下线下取价 -- |
1290 | for (var k = 0; k < arr.length; k++) { | 1293 | for (var k = 0; k < arr.length; k++) { |
@@ -1292,8 +1295,31 @@ Page({ | @@ -1292,8 +1295,31 @@ Page({ | ||
1292 | if (!is_change) { | 1295 | if (!is_change) { |
1293 | //-- 要进行归类一下活动 -- | 1296 | //-- 要进行归类一下活动 -- |
1294 | await m_cx.cart_cx_group(th, arr[k].goods, c_item, 0, 0, (show_can_cx) => { | 1297 | await m_cx.cart_cx_group(th, arr[k].goods, c_item, 0, 0, (show_can_cx) => { |
1295 | - | ||
1296 | - arr[k].show_can_cx = show_can_cx; | 1298 | + //后台计算使用 |
1299 | + th.data.show_can_cx_map[c_item.pickup_id]=show_can_cx; | ||
1300 | + //-- 把活动组装进去 --- | ||
1301 | + let show_can_cx1 = ut.deep_cp(show_can_cx); | ||
1302 | + //前端处理渲染的时,要处理一些不需要的字段属性 | ||
1303 | + if(show_can_cx1){ | ||
1304 | + for (const key in show_can_cx1) { | ||
1305 | + let element = show_can_cx1[key]; | ||
1306 | + if(element.cur_act){ | ||
1307 | + let c_act=element.cur_act; | ||
1308 | + delete c_act.goods; | ||
1309 | + } | ||
1310 | + if(element.ch_map){ | ||
1311 | + delete element.ch_map; | ||
1312 | + } | ||
1313 | + if(element.act_arr && element.act_arr.length>0){ | ||
1314 | + for (var ij = 0; ij < element.act_arr.length; ij++) { | ||
1315 | + var act_ite = element.act_arr[ij]; | ||
1316 | + delete act_ite.goods; | ||
1317 | + delete act_ite.key; | ||
1318 | + } | ||
1319 | + } | ||
1320 | + } | ||
1321 | + } | ||
1322 | + arr[k].show_can_cx = show_can_cx1; | ||
1297 | },2) | 1323 | },2) |
1298 | } else { | 1324 | } else { |
1299 | var show_can_cx = this.data.cartlist[k].show_can_cx; | 1325 | var show_can_cx = this.data.cartlist[k].show_can_cx; |
@@ -1314,13 +1340,13 @@ Page({ | @@ -1314,13 +1340,13 @@ Page({ | ||
1314 | //-- 如果初始活动在计算的时候,是不满足的时候,就要把活动清理掉 -- | 1340 | //-- 如果初始活动在计算的时候,是不满足的时候,就要把活动清理掉 -- |
1315 | var is_no_ok=arr[k].show_can_cx[key_o].cur_act.is_no_ok; | 1341 | var is_no_ok=arr[k].show_can_cx[key_o].cur_act.is_no_ok; |
1316 | if(is_no_ok==1){ | 1342 | if(is_no_ok==1){ |
1317 | - item1.prom_id = 0; | ||
1318 | - item1.prom_type = 0; | 1343 | + item1.prom_id = 0; |
1344 | + item1.prom_type = 0; | ||
1319 | 1345 | ||
1320 | - //这里要判断一下活动的最后一个商品,is_act_last | ||
1321 | - if(th.is_last(item1.goods_id,arr[k].goods,arr[k].show_can_cx[key_o].ch_map)){ | ||
1322 | - item1.is_act_last=1; //这个是要在前端显示按钮切换的 | ||
1323 | - } | 1346 | + //这里要判断一下活动的最后一个商品,is_act_last |
1347 | + if(th.is_last(item1.goods_id,arr[k].goods,arr[k].show_can_cx[key_o].ch_map)){ | ||
1348 | + item1.is_act_last=1; //这个是要在前端显示按钮切换的 | ||
1349 | + } | ||
1324 | 1350 | ||
1325 | } | 1351 | } |
1326 | } | 1352 | } |
@@ -1331,7 +1357,7 @@ Page({ | @@ -1331,7 +1357,7 @@ Page({ | ||
1331 | if (item1.prom_type == 3 && item1.is_gift != 1 && !item1.whsle_id) { | 1357 | if (item1.prom_type == 3 && item1.is_gift != 1 && !item1.whsle_id) { |
1332 | // th.check_is_youhui(item1.goods_id, item1.pick_id); | 1358 | // th.check_is_youhui(item1.goods_id, item1.pick_id); |
1333 | //增加优惠活动次数限制 | 1359 | //增加优惠活动次数限制 |
1334 | - let limit_num = await th.getprom(item1) //活动限制次数 | 1360 | + let limit_num = th.getprom(item1) //活动限制次数 |
1335 | 1361 | ||
1336 | if (!limit_num) { | 1362 | if (!limit_num) { |
1337 | await th.add_prom_goods_map(item1); | 1363 | await th.add_prom_goods_map(item1); |
@@ -1431,7 +1457,7 @@ Page({ | @@ -1431,7 +1457,7 @@ Page({ | ||
1431 | 1457 | ||
1432 | } else { | 1458 | } else { |
1433 | 1459 | ||
1434 | - | 1460 | + |
1435 | item1.act = th.data.zhhe_act_map[item1.prom_id]; | 1461 | item1.act = th.data.zhhe_act_map[item1.prom_id]; |
1436 | } | 1462 | } |
1437 | } | 1463 | } |
@@ -1511,29 +1537,48 @@ Page({ | @@ -1511,29 +1537,48 @@ Page({ | ||
1511 | //如果是秒杀,团购的时候,优惠促销和搭配购的时候 | 1537 | //如果是秒杀,团购的时候,优惠促销和搭配购的时候 |
1512 | if([1,2,3,5,6,7,10].indexOf(item1.prom_type)>-1){ | 1538 | if([1,2,3,5,6,7,10].indexOf(item1.prom_type)>-1){ |
1513 | 1539 | ||
1540 | + //由于是购物车购买,所以prom_type 基本不会员等于6 | ||
1514 | if(item1.prom_type==1 || item1.prom_type==6) { | 1541 | if(item1.prom_type==1 || item1.prom_type==6) { |
1515 | item1.is_quan=0; | 1542 | item1.is_quan=0; |
1516 | } | 1543 | } |
1517 | - | ||
1518 | - var url= "/api/weshop/activitylist/getSJGoodsPriceNew/" + os.stoid | ||
1519 | - + "/" + item1.goods_id + "/"+item1.prom_type+"/" + item1.prom_id + "/" + app.globalData.user_id; | ||
1520 | - await app.request.promiseGet(url,{}).then(res=>{ | ||
1521 | - if(res.data.code==0){ | ||
1522 | - console.log(res.data.data,"111"); | ||
1523 | - //组合促销有另外一个字段名is_orderyh,在控制订单促销的叠加 | ||
1524 | - | 1544 | + let t_goodsActinfo=item1.goodsActinfo; |
1545 | + if(t_goodsActinfo && t_goodsActinfo.length){ | ||
1546 | + let ff_prom=t_goodsActinfo.find(function (e){ | ||
1547 | + return e.prom_type==item1.prom_type; | ||
1548 | + }) | ||
1549 | + if(ff_prom){ | ||
1525 | if(item1.prom_type!=7 && item1.prom_type!=10) { | 1550 | if(item1.prom_type!=7 && item1.prom_type!=10) { |
1526 | - item1.is_order_yh=res.data.data.is_order_yh; | 1551 | + item1.is_order_yh=ff_prom.is_order_yh; |
1527 | }else item1.is_order_yh=0; | 1552 | }else item1.is_order_yh=0; |
1528 | 1553 | ||
1529 | - item1.is_post_temp=res.data.data.is_post_temp; | 1554 | + item1.is_post_temp=ff_prom.is_post_temp; |
1530 | 1555 | ||
1556 | + //由于是购物车购买,所以prom_type 基本不会员等于6 | ||
1531 | if(item1.prom_type==1 || item1.prom_type==6) { | 1557 | if(item1.prom_type==1 || item1.prom_type==6) { |
1532 | - item1.is_quan=res.data.data.is_quan; | 1558 | + item1.is_quan=item1.cartActinfo.is_quan; |
1533 | } | 1559 | } |
1534 | - | ||
1535 | } | 1560 | } |
1536 | - }) | 1561 | + } |
1562 | + | ||
1563 | + // var url= "/api/weshop/activitylist/getSJGoodsPriceNew/" + os.stoid | ||
1564 | + // + "/" + item1.goods_id + "/"+item1.prom_type+"/" + item1.prom_id + "/" + app.globalData.user_id; | ||
1565 | + // await app.request.promiseGet(url,{}).then(res=>{ | ||
1566 | + // if(res.data.code==0){ | ||
1567 | + // console.log(res.data.data,"111"); | ||
1568 | + // //组合促销有另外一个字段名is_orderyh,在控制订单促销的叠加 | ||
1569 | + // | ||
1570 | + // if(item1.prom_type!=7 && item1.prom_type!=10) { | ||
1571 | + // item1.is_order_yh=res.data.data.is_order_yh; | ||
1572 | + // }else item1.is_order_yh=0; | ||
1573 | + // | ||
1574 | + // item1.is_post_temp=res.data.data.is_post_temp; | ||
1575 | + // | ||
1576 | + // if(item1.prom_type==1 || item1.prom_type==6) { | ||
1577 | + // item1.is_quan=res.data.data.is_quan; | ||
1578 | + // } | ||
1579 | + // | ||
1580 | + // } | ||
1581 | + // }) | ||
1537 | } | 1582 | } |
1538 | 1583 | ||
1539 | } | 1584 | } |
@@ -1662,12 +1707,37 @@ Page({ | @@ -1662,12 +1707,37 @@ Page({ | ||
1662 | } | 1707 | } |
1663 | } | 1708 | } |
1664 | } | 1709 | } |
1665 | - | ||
1666 | //深拷贝 | 1710 | //深拷贝 |
1667 | th.data.old_cartlist = JSON.parse(JSON.stringify(arr)); | 1711 | th.data.old_cartlist = JSON.parse(JSON.stringify(arr)); |
1668 | - th.setData({ | ||
1669 | - cartlist: arr, | ||
1670 | - }); | 1712 | + |
1713 | + th.data.cartlist=arr; | ||
1714 | + | ||
1715 | + //-- 大于20使用逐步渲染 -- | ||
1716 | + if(arr.length>10){ | ||
1717 | + for (let ib = 0; ib <arr.length ; ib++) { | ||
1718 | + //-- 都用深拷贝 -- | ||
1719 | + var ite=ut.deep_cp(th.data.old_cartlist[ib]); | ||
1720 | + delete ite.goods; | ||
1721 | + var txt0="cartlist["+ib+"]"; | ||
1722 | + th.setData({ | ||
1723 | + [txt0]:ite | ||
1724 | + }) | ||
1725 | + //都用深拷贝 | ||
1726 | + var tt_goods=ut.deep_cp(th.data.old_cartlist[ib].goods); | ||
1727 | + for (let iz = 0; iz <tt_goods.length;iz++) { | ||
1728 | + var txt="cartlist["+ib+"].goods["+iz+"]"; | ||
1729 | + setTimeout(()=>{ | ||
1730 | + th.setData({ | ||
1731 | + [txt]:tt_goods[iz] | ||
1732 | + }) | ||
1733 | + },ib*200+iz*300+100) | ||
1734 | + } | ||
1735 | + } | ||
1736 | + }else{ | ||
1737 | + th.setData({ | ||
1738 | + cartlist: arr, | ||
1739 | + }); | ||
1740 | + } | ||
1671 | 1741 | ||
1672 | //--- 获取一下看有没有优惠券 ---- | 1742 | //--- 获取一下看有没有优惠券 ---- |
1673 | setTimeout(function () { | 1743 | setTimeout(function () { |
@@ -1684,6 +1754,7 @@ Page({ | @@ -1684,6 +1754,7 @@ Page({ | ||
1684 | }, 500) | 1754 | }, 500) |
1685 | }, | 1755 | }, |
1686 | 1756 | ||
1757 | + | ||
1687 | //-----单个商品购买的入口判断---- | 1758 | //-----单个商品购买的入口判断---- |
1688 | get_buy_goods: function (e) { | 1759 | get_buy_goods: function (e) { |
1689 | var th = this; | 1760 | var th = this; |
@@ -2202,60 +2273,68 @@ Page({ | @@ -2202,60 +2273,68 @@ Page({ | ||
2202 | } | 2273 | } |
2203 | }, | 2274 | }, |
2204 | 2275 | ||
2276 | + | ||
2205 | //-- 立即购买的时候,获取商品优惠活动,is_state判断是不是单个商品购买, | 2277 | //-- 立即购买的时候,获取商品优惠活动,is_state判断是不是单个商品购买, |
2206 | // 很多活动需要判断会员的plus等级, 权益登陆,user_id调用接口是必须的 -- | 2278 | // 很多活动需要判断会员的plus等级, 权益登陆,user_id调用接口是必须的 -- |
2207 | //先用着,后面会用接口来代替 | 2279 | //先用着,后面会用接口来代替 |
2208 | - async buy_pro_group(item1, is_state) { | ||
2209 | - //-- 代发商品不参与任何活动 -- | ||
2210 | - if (item1.whsle_id) return false; | ||
2211 | - if (item1.is_gift) return false; | ||
2212 | - if (item1.is_collocation) return false; | ||
2213 | - if (item1.is_ld_split) return false; //是阶梯 | ||
2214 | - if (item1.is_zh_split) return false; | ||
2215 | - | ||
2216 | - //-- 购物车的秒杀和团购不计算 -- | ||
2217 | - var p_type=parseInt(item1.prom_type); | ||
2218 | - if([1,2].indexOf(p_type)>-1) return false; | ||
2219 | - | 2280 | + async buy_pro_group(g_arr,carr) { |
2220 | var th=this; | 2281 | var th=this; |
2221 | - var req_d = { | ||
2222 | - store_id: os.stoid, | ||
2223 | - user_id: getApp().globalData.user_id, | ||
2224 | - goods_id: item1.goods_id, | ||
2225 | - goods_num: item1.goods_num, | ||
2226 | - goods_price: item1.goods_price, | ||
2227 | - } | ||
2228 | - //--- 调用接口获取活动 --- | ||
2229 | - await getApp().promiseGet('/api/weshop/goods/getGoodsPromInfo', {data:req_d}).then(res => { | ||
2230 | - if(res.data.code==0){ | ||
2231 | - var more_cx=res.data.data.more_cx; | ||
2232 | - for(var i=0;i<more_cx.length;i++){ | ||
2233 | - if(more_cx[i].prom_type==5){ | ||
2234 | - more_cx[i].main_gid= more_cx[i].collocation.main_goods_id; | ||
2235 | - var min=more_cx[i].collocation_main_price+more_cx[i].collocation_min_price; | ||
2236 | - var max=more_cx[i].collocation_main_price+more_cx[i].collocation_max_price; | ||
2237 | - more_cx[i].show_price="¥"+min+"-"+max; | ||
2238 | - } | ||
2239 | - } | ||
2240 | - item1.more_cx=more_cx; | ||
2241 | - | ||
2242 | - if(res.data.data.zh_pro){ | ||
2243 | - th.data.zhhe_act_map[res.data.data.zh_pro.id]=res.data.data.zh_pro; | ||
2244 | - } | ||
2245 | - if(res.data.data.ladder_pro){ | ||
2246 | - var ladder_pro=res.data.data.ladder_pro; | ||
2247 | - th.data.ladder_map[ladder_pro.id]=ladder_pro; | ||
2248 | - var fd=res.data.data.more_cx.find(function (e){ | ||
2249 | - return e.prom_type==10; | ||
2250 | - }) | ||
2251 | - if(fd){ | ||
2252 | - th.data.ladder_map[ladder_pro.id].ladder_list=fd.ladder_list; | ||
2253 | - } | 2282 | + //获取商品参与的促销活,优惠促,搭配促,组合促,阶梯促销 |
2283 | + let cx_rs= await getApp().request.promisePost("/api/weshop/cart/listGoodsPromInfo",{ | ||
2284 | + is_json:1, | ||
2285 | + data:{ | ||
2286 | + user_id:app.globalData.user_id, | ||
2287 | + store_id:oo.stoid, | ||
2288 | + goods:g_arr, | ||
2289 | + } | ||
2290 | + }); | ||
2291 | + //-- 判断返回结果有没有正确,有促销活动就要进行赋值 -- | ||
2292 | + if(cx_rs && cx_rs.data.code==0 && cx_rs.data.data && cx_rs.data.data.goods) { | ||
2293 | + let g_list=cx_rs.data.data.goods; | ||
2294 | + for (var ia = 0; ia < carr.length; ia++) { | ||
2295 | + if (carr[ia].whsle_id) continue; //代发商品不进行赋值 | ||
2296 | + if (carr[ia].is_gift) continue; //赠品不进行赋值 | ||
2297 | + //有参与秒,团购之类的活动不进行赋值 | ||
2298 | + if([1, 2, 4, 6, 8, 9].indexOf(carr[ia].prom_type)> -1 ) continue; | ||
2299 | + //再g_list中快速查找 | ||
2300 | + let i_fd=g_list.find(function (ele) { | ||
2301 | + return ele.goods_id == carr[ia].goods_id | ||
2302 | + }); | ||
2303 | + if(i_fd.goodsPromInfoRespDto){ | ||
2304 | + //-- 多促销活动的优化 -- | ||
2305 | + i_fd=i_fd.goodsPromInfoRespDto; | ||
2306 | + //-- 赋值多促销活动的优化-- | ||
2307 | + carr[ia].more_cx=i_fd.more_cx; | ||
2308 | + | ||
2309 | + //商品优惠促销的缓存 | ||
2310 | + if (i_fd.yhcx_pro) { | ||
2311 | + th.data.yhcx_act_map[i_fd.yhcx_pro.id] = i_fd.yhcx_pro; | ||
2312 | + } | ||
2313 | + //商品组合促销的缓存 | ||
2314 | + if (i_fd.zh_pro) { | ||
2315 | + th.data.zhhe_act_map[i_fd.zh_pro.id] = i_fd.zh_pro; | ||
2316 | + } | ||
2317 | + //商品阶梯促销的缓存 | ||
2318 | + if (i_fd.ladder_pro) { | ||
2319 | + var ladder_pro = i_fd.ladder_pro; | ||
2320 | + th.data.ladder_map[ladder_pro.id] = ladder_pro; | ||
2321 | + var fd_ite = i_fd.more_cx.find(function (e) { | ||
2322 | + return e.prom_type == 10; | ||
2323 | + }) | ||
2324 | + if (fd_ite) { | ||
2325 | + th.data.ladder_map[ladder_pro.id].ladder_list = fd_ite.ladder_list; | ||
2254 | } | 2326 | } |
2255 | - } | ||
2256 | - }) | 2327 | + } |
2328 | + | ||
2329 | + } | ||
2330 | + | ||
2331 | + } | ||
2332 | + } | ||
2257 | }, | 2333 | }, |
2258 | 2334 | ||
2335 | + | ||
2336 | + | ||
2337 | + | ||
2259 | //---------------检查是否有收货地址------------------- | 2338 | //---------------检查是否有收货地址------------------- |
2260 | checkAddressList: function () { | 2339 | checkAddressList: function () { |
2261 | var t = this; | 2340 | var t = this; |
@@ -2393,11 +2472,11 @@ Page({ | @@ -2393,11 +2472,11 @@ Page({ | ||
2393 | newd.is_past=1; | 2472 | newd.is_past=1; |
2394 | } | 2473 | } |
2395 | 2474 | ||
2396 | - ord_goods.splice(pos+1,0,newd); | 2475 | + //ord_goods.splice(pos+1,0,newd); |
2397 | th.data.old_cartlist[i].goods.splice(pos2+1,0,newd); | 2476 | th.data.old_cartlist[i].goods.splice(pos2+1,0,newd); |
2398 | 2477 | ||
2399 | - var txt9 = "cartlist[" + i + "].goods"; | ||
2400 | - th.setData({ [txt9]: ord_goods }) | 2478 | + var txt9 = "cartlist[" + i + "].goods["+(pos+1)+"]"; |
2479 | + th.setData({ [txt9]: newd }) | ||
2401 | 2480 | ||
2402 | } | 2481 | } |
2403 | 2482 | ||
@@ -6610,25 +6689,26 @@ Page({ | @@ -6610,25 +6689,26 @@ Page({ | ||
6610 | }).then(res => { | 6689 | }).then(res => { |
6611 | if (res.data.code == 0) { | 6690 | if (res.data.code == 0) { |
6612 | var quan_list = res.data.data.pageData; | 6691 | var quan_list = res.data.data.pageData; |
6613 | - arr[ind].quan_list = th.check_is_frozenQuan(quan_list, th.data.frozenQuan); | 6692 | + //arr[ind].quan_list = th.check_is_frozenQuan(quan_list, th.data.frozenQuan); |
6693 | + quan_list= th.check_is_frozenQuan(quan_list, th.data.frozenQuan); | ||
6694 | + var set_txt = "cartlist[" + ind + "].quan_list"; | ||
6695 | + th.setData({ | ||
6696 | + [set_txt]:quan_list | ||
6697 | + }) | ||
6614 | } | 6698 | } |
6615 | }) | 6699 | }) |
6616 | } | 6700 | } |
6617 | - | ||
6618 | - | ||
6619 | } | 6701 | } |
6620 | 6702 | ||
6621 | 6703 | ||
6622 | - | ||
6623 | - | ||
6624 | //如果是搭配购的立即购买的时候 | 6704 | //如果是搭配购的立即购买的时候 |
6625 | if (th.data.is_b_now) { | 6705 | if (th.data.is_b_now) { |
6626 | if (arr && arr.length > 0) { | 6706 | if (arr && arr.length > 0) { |
6627 | var quanlist = arr[0].quan_list; | 6707 | var quanlist = arr[0].quan_list; |
6628 | - th.setData({ selected_quan_list: quanlist, cartlist: arr }) | 6708 | + th.setData({ selected_quan_list: quanlist }) |
6629 | } | 6709 | } |
6630 | } else { | 6710 | } else { |
6631 | - th.setData({ cartlist: arr }) | 6711 | + //th.setData({ cartlist: arr }) |
6632 | th.set_can_num(); | 6712 | th.set_can_num(); |
6633 | } | 6713 | } |
6634 | 6714 | ||
@@ -6899,25 +6979,38 @@ Page({ | @@ -6899,25 +6979,38 @@ Page({ | ||
6899 | } | 6979 | } |
6900 | return user_pre_buynum | 6980 | return user_pre_buynum |
6901 | }, | 6981 | }, |
6982 | + | ||
6983 | + | ||
6902 | //获取优惠活动 | 6984 | //获取优惠活动 |
6903 | - async getprom(item){ | ||
6904 | - | 6985 | + getprom(item){ |
6986 | + | ||
6905 | let prom_id=item.prom_id | 6987 | let prom_id=item.prom_id |
6906 | let pickup_id=item.pick_id | 6988 | let pickup_id=item.pick_id |
6907 | let limit_num=0 | 6989 | let limit_num=0 |
6908 | - await getApp().request.promiseGet("/api/weshop/promgoods/get/" + oo.stoid + "/" + prom_id, {}).then(res => { | ||
6909 | - if (res.data.code == 0) { | ||
6910 | - let prom = res.data.data; | ||
6911 | - limit_num =prom.limit_num | ||
6912 | - let yh_is_xz_yh=this.data.yh_is_xz_yh | ||
6913 | - yh_is_xz_yh[pickup_id]=prom.is_xz_yh | ||
6914 | - this.setData({ | ||
6915 | - ['yh_is_xz_yh']:yh_is_xz_yh | ||
6916 | - }) | ||
6917 | - } | ||
6918 | - }) | 6990 | + //不再调用接口活动优惠促销活动的内容 |
6991 | + // await getApp().request.promiseGet("/api/weshop/promgoods/get/" + oo.stoid + "/" + prom_id, {}).then(res => { | ||
6992 | + // if (res.data.code == 0) { | ||
6993 | + // let prom = res.data.data; | ||
6994 | + // limit_num =prom.limit_num | ||
6995 | + // let yh_is_xz_yh=this.data.yh_is_xz_yh | ||
6996 | + // yh_is_xz_yh[pickup_id]=prom.is_xz_yh | ||
6997 | + // this.setData({ | ||
6998 | + // ['yh_is_xz_yh']:yh_is_xz_yh | ||
6999 | + // }) | ||
7000 | + // } | ||
7001 | + // }) | ||
7002 | + if(this.data.yhcx_act_map[prom_id]){ | ||
7003 | + let prom = this.data.yhcx_act_map[prom_id]; | ||
7004 | + limit_num =prom.limit_num | ||
7005 | + let yh_is_xz_yh=this.data.yh_is_xz_yh | ||
7006 | + yh_is_xz_yh[pickup_id]=prom.is_xz_yh | ||
7007 | + this.setData({ | ||
7008 | + ['yh_is_xz_yh']:yh_is_xz_yh | ||
7009 | + }) | ||
7010 | + } | ||
6919 | return limit_num | 7011 | return limit_num |
6920 | }, | 7012 | }, |
7013 | + | ||
6921 | //--检查订单优惠-- | 7014 | //--检查订单优惠-- |
6922 | check_is_order_prom: function (condition, func, pick) { | 7015 | check_is_order_prom: function (condition, func, pick) { |
6923 | var th = this; | 7016 | var th = this; |
@@ -6971,10 +7064,11 @@ Page({ | @@ -6971,10 +7064,11 @@ Page({ | ||
6971 | 7064 | ||
6972 | } else { | 7065 | } else { |
6973 | var prom = null; | 7066 | var prom = null; |
6974 | - | ||
6975 | - await getApp().request.promiseGet("/api/weshop/promgoods/get/" + os.stoid + "/" + item.prom_id, {}).then(res => { | ||
6976 | - if (res.data.code == 0) { | ||
6977 | - prom = res.data.data; | 7067 | + |
7068 | + | ||
7069 | + if(th.data.yhcx_act_map[item.prom_id]){ | ||
7070 | + | ||
7071 | + prom = th.data.yhcx_act_map[item.prom_id]; | ||
6978 | 7072 | ||
6979 | let min_value = 0 | 7073 | let min_value = 0 |
6980 | if (prom && prom.is_xz_yh) { | 7074 | if (prom && prom.is_xz_yh) { |
@@ -7001,7 +7095,8 @@ Page({ | @@ -7001,7 +7095,8 @@ Page({ | ||
7001 | } | 7095 | } |
7002 | } | 7096 | } |
7003 | } | 7097 | } |
7004 | - }) | 7098 | + |
7099 | + if(!prom) return false; | ||
7005 | var ob = {}; | 7100 | var ob = {}; |
7006 | ob.prom_id = item.prom_id; | 7101 | ob.prom_id = item.prom_id; |
7007 | ob.name = prom.name; | 7102 | ob.name = prom.name; |
@@ -7033,11 +7128,9 @@ Page({ | @@ -7033,11 +7128,9 @@ Page({ | ||
7033 | } else { | 7128 | } else { |
7034 | var ob = {}; | 7129 | var ob = {}; |
7035 | var prom = null; | 7130 | var prom = null; |
7036 | - | ||
7037 | - await getApp().request.promiseGet("/api/weshop/promgoods/get/" + os.stoid + "/" + item.prom_id, {}).then(res => { | ||
7038 | - if (res.data.code == 0) { | ||
7039 | - prom = res.data.data; | ||
7040 | 7131 | ||
7132 | + if(th.data.yhcx_act_map[item.prom_id]){ | ||
7133 | + prom = th.data.yhcx_act_map[item.prom_id]; | ||
7041 | let min_value = 0 | 7134 | let min_value = 0 |
7042 | if (prom && prom.is_xz_yh) { | 7135 | if (prom && prom.is_xz_yh) { |
7043 | let arr = prom.promGoodsList || [] | 7136 | let arr = prom.promGoodsList || [] |
@@ -7063,9 +7156,8 @@ Page({ | @@ -7063,9 +7156,8 @@ Page({ | ||
7063 | } | 7156 | } |
7064 | } | 7157 | } |
7065 | } | 7158 | } |
7066 | - }) | ||
7067 | - | ||
7068 | 7159 | ||
7160 | + if(!prom) return false; | ||
7069 | //优惠促销取价的优化 | 7161 | //优惠促销取价的优化 |
7070 | let f_price=item.goods_price; | 7162 | let f_price=item.goods_price; |
7071 | 7163 | ||
@@ -8283,6 +8375,7 @@ Page({ | @@ -8283,6 +8375,7 @@ Page({ | ||
8283 | pro_pop.set_init(1,cp_arr); | 8375 | pro_pop.set_init(1,cp_arr); |
8284 | }, | 8376 | }, |
8285 | 8377 | ||
8378 | + | ||
8286 | //--- 选择回来时候的选择 --- | 8379 | //--- 选择回来时候的选择 --- |
8287 | sure_cx_group:function(e){ | 8380 | sure_cx_group:function(e){ |
8288 | var th=this; | 8381 | var th=this; |
@@ -8291,8 +8384,12 @@ Page({ | @@ -8291,8 +8384,12 @@ Page({ | ||
8291 | //-- 获取到当前的show_can_cx-- | 8384 | //-- 获取到当前的show_can_cx-- |
8292 | var idx=this.data.sele_cx_group_cidx; | 8385 | var idx=this.data.sele_cx_group_cidx; |
8293 | var gd_key= this.data.cx_group_gd_key; | 8386 | var gd_key= this.data.cx_group_gd_key; |
8387 | + | ||
8388 | + | ||
8389 | + var pk_id=this.data.cartlist[idx].pickup_id; | ||
8390 | + var cx_prom_group2= th.data.show_can_cx_map[pk_id][gd_key].act_arr; | ||
8391 | + | ||
8294 | var cx_prom_group=this.data.cartlist[idx].show_can_cx[gd_key].act_arr; | 8392 | var cx_prom_group=this.data.cartlist[idx].show_can_cx[gd_key].act_arr; |
8295 | - var pk=this.data.cartlist[idx].pickup_id; | ||
8296 | 8393 | ||
8297 | th.setData({ | 8394 | th.setData({ |
8298 | send_lb:{}, | 8395 | send_lb:{}, |
@@ -8311,12 +8408,19 @@ Page({ | @@ -8311,12 +8408,19 @@ Page({ | ||
8311 | //如果活动不是选择的 | 8408 | //如果活动不是选择的 |
8312 | if(cx_prom_group[dx].prom_type!=sele_prom_type) cx_prom_group[dx].sele=0; | 8409 | if(cx_prom_group[dx].prom_type!=sele_prom_type) cx_prom_group[dx].sele=0; |
8313 | else cx_prom_group[dx].sele=1; | 8410 | else cx_prom_group[dx].sele=1; |
8411 | + | ||
8412 | + if(cx_prom_group2[dx].prom_type!=sele_prom_type) cx_prom_group2[dx].sele=0; | ||
8413 | + else cx_prom_group2[dx].sele=1; | ||
8314 | } | 8414 | } |
8315 | //选择后就要把活动确定下来 | 8415 | //选择后就要把活动确定下来 |
8316 | //确定一下活动,先看一下有没有选择的活动 | 8416 | //确定一下活动,先看一下有没有选择的活动 |
8317 | var ck_prom_type=cx_prom_group.find(function (el){ | 8417 | var ck_prom_type=cx_prom_group.find(function (el){ |
8318 | return el.sele; | 8418 | return el.sele; |
8319 | }) | 8419 | }) |
8420 | + var ck_prom_type2=cx_prom_group2.find(function (el){ | ||
8421 | + return el.sele; | ||
8422 | + }) | ||
8423 | + | ||
8320 | 8424 | ||
8321 | this.cx_check_ok2(function (ck_res){ | 8425 | this.cx_check_ok2(function (ck_res){ |
8322 | 8426 | ||
@@ -8328,16 +8432,16 @@ Page({ | @@ -8328,16 +8432,16 @@ Page({ | ||
8328 | var goods0= JSON.parse(JSON.stringify(th.data.cartlist_y)); | 8432 | var goods0= JSON.parse(JSON.stringify(th.data.cartlist_y)); |
8329 | var goods=[]; | 8433 | var goods=[]; |
8330 | for(var ik=0;ik<goods0.length;ik++){ | 8434 | for(var ik=0;ik<goods0.length;ik++){ |
8331 | - var item_c=goods0[ik]; | ||
8332 | - if(item_c.pick_id==pk && item_c.is_collocation) continue; | ||
8333 | - goods.push(item_c); | 8435 | + var item_c=goods0[ik]; |
8436 | + if(item_c.pick_id==pk && item_c.is_collocation) continue; | ||
8437 | + goods.push(item_c); | ||
8334 | } | 8438 | } |
8335 | 8439 | ||
8336 | //-- 此时要把购物车中的商品确定活动 -- | 8440 | //-- 此时要把购物车中的商品确定活动 -- |
8337 | - for (var b=0; b<ck_prom_type.goods.length;b++){ | 8441 | + for (var b=0; b<ck_prom_type2.goods.length;b++){ |
8338 | //-- 开始查找 -- | 8442 | //-- 开始查找 -- |
8339 | var fg=goods.findIndex(function (g_item){ | 8443 | var fg=goods.findIndex(function (g_item){ |
8340 | - return g_item.goods_id==ck_prom_type.goods[b].goods_id | 8444 | + return g_item.goods_id==ck_prom_type2.goods[b].goods_id |
8341 | && [0,3,5,7,10].indexOf(g_item.prom_type)>-1 | 8445 | && [0,3,5,7,10].indexOf(g_item.prom_type)>-1 |
8342 | && g_item.pick_id==pk && g_item.is_gift==0; | 8446 | && g_item.pick_id==pk && g_item.is_gift==0; |
8343 | }) | 8447 | }) |
@@ -8352,10 +8456,10 @@ Page({ | @@ -8352,10 +8456,10 @@ Page({ | ||
8352 | } | 8456 | } |
8353 | 8457 | ||
8354 | for(var ik=0;ik< th.data.cartlist[idx].goods.length;ik++){ | 8458 | for(var ik=0;ik< th.data.cartlist[idx].goods.length;ik++){ |
8355 | - if(th.data.cartlist[idx].goods[ik].id==goods[fg].id){ | ||
8356 | - th.data.cartlist[idx].goods[ik].prom_type= goods[fg].prom_type; | ||
8357 | - th.data.cartlist[idx].goods[ik].prom_id= goods[fg].prom_id; | ||
8358 | - } | 8459 | + if(th.data.cartlist[idx].goods[ik].id==goods[fg].id){ |
8460 | + th.data.cartlist[idx].goods[ik].prom_type= goods[fg].prom_type; | ||
8461 | + th.data.cartlist[idx].goods[ik].prom_id= goods[fg].prom_id; | ||
8462 | + } | ||
8359 | } | 8463 | } |
8360 | 8464 | ||
8361 | //原始数据要有深拷贝不能有地址的牵连 | 8465 | //原始数据要有深拷贝不能有地址的牵连 |
pages/cart/cart/cart.js
@@ -59,6 +59,9 @@ Page({ | @@ -59,6 +59,9 @@ Page({ | ||
59 | 59 | ||
60 | is_cart:1, //标记是购物车计算的时候 | 60 | is_cart:1, //标记是购物车计算的时候 |
61 | 61 | ||
62 | + //送赠品的优化 | ||
63 | + cart_zp:{} | ||
64 | + | ||
62 | }, | 65 | }, |
63 | 66 | ||
64 | //-- 立即购买的时候,获取商品优惠活动,is_state判断是不是单个商品购买, | 67 | //-- 立即购买的时候,获取商品优惠活动,is_state判断是不是单个商品购买, |
@@ -126,6 +129,9 @@ Page({ | @@ -126,6 +129,9 @@ Page({ | ||
126 | }, | 129 | }, |
127 | onShow: function () { | 130 | onShow: function () { |
128 | 131 | ||
132 | + //-- 清空 checkouting 结算的标记 -- | ||
133 | + this.data.checkouting=0; | ||
134 | + | ||
129 | if(getApp().globalData.from_act_link){ | 135 | if(getApp().globalData.from_act_link){ |
130 | this.data.from_act_link= ut.deep_cp(getApp().globalData.from_act_link); | 136 | this.data.from_act_link= ut.deep_cp(getApp().globalData.from_act_link); |
131 | getApp().globalData.from_act_link=null; | 137 | getApp().globalData.from_act_link=null; |
@@ -140,7 +146,8 @@ Page({ | @@ -140,7 +146,8 @@ Page({ | ||
140 | //每次显示都清空 | 146 | //每次显示都清空 |
141 | this.data.in_zhact_gdmap = {}; | 147 | this.data.in_zhact_gdmap = {}; |
142 | this.setData({ | 148 | this.setData({ |
143 | - invalidList: [] | 149 | + invalidList: [], |
150 | + cart_zp:{} //-- 赠品也要清理显示 -- | ||
144 | }); | 151 | }); |
145 | 152 | ||
146 | if (typeof this.getTabBar === 'function' && this.getTabBar()) { | 153 | if (typeof this.getTabBar === 'function' && this.getTabBar()) { |
@@ -290,7 +297,6 @@ Page({ | @@ -290,7 +297,6 @@ Page({ | ||
290 | var user = getApp().globalData.userInfo; | 297 | var user = getApp().globalData.userInfo; |
291 | //如果后台有开启等级价的功能 | 298 | //如果后台有开启等级价的功能 |
292 | if (user && parseInt(s_list.rank_switch) == 2 && user['card_expiredate']) { | 299 | if (user && parseInt(s_list.rank_switch) == 2 && user['card_expiredate']) { |
293 | - | ||
294 | var str = user['card_expiredate'].replace(/-/g, '/'); | 300 | var str = user['card_expiredate'].replace(/-/g, '/'); |
295 | var end = new Date(str); | 301 | var end = new Date(str); |
296 | end = Date.parse(end) / 1000; | 302 | end = Date.parse(end) / 1000; |
@@ -517,7 +523,18 @@ Page({ | @@ -517,7 +523,18 @@ Page({ | ||
517 | 523 | ||
518 | wx.showLoading(); | 524 | wx.showLoading(); |
519 | 525 | ||
520 | - getApp().request.get("/api/weshop/cart/list", { | 526 | + //一次性把购物车selected状态变成0 |
527 | + var url = '/api/weshop/cart/updateUserCart'; | ||
528 | + getApp().request.put(url, { | ||
529 | + data: { | ||
530 | + user_id: app.globalData.user_id, | ||
531 | + store_id: oo.stoid, | ||
532 | + selected: 0, | ||
533 | + state:0 | ||
534 | + } | ||
535 | + }); | ||
536 | + | ||
537 | + getApp().request.get("/api/weshop/cart/listNew1", { | ||
521 | data: { | 538 | data: { |
522 | user_id: app.globalData.user_id, | 539 | user_id: app.globalData.user_id, |
523 | rd: rd, | 540 | rd: rd, |
@@ -534,65 +551,81 @@ Page({ | @@ -534,65 +551,81 @@ Page({ | ||
534 | 551 | ||
535 | if (carr && carr.length > 0) { | 552 | if (carr && carr.length > 0) { |
536 | var g_arr = []; | 553 | var g_arr = []; |
554 | + var by_map = null; | ||
555 | + | ||
537 | for (var i = 0; i < carr.length; i++) { | 556 | for (var i = 0; i < carr.length; i++) { |
538 | - //-- 清理购物车的选中状态 -- | ||
539 | - var url = '/api/weshop/cart/update'; | ||
540 | - getApp().request.put(url, { | ||
541 | - data: { | ||
542 | - id: carr[i].id, | ||
543 | - store_id: oo.stoid, | ||
544 | - selected: 0, | ||
545 | - } | ||
546 | - }); | 557 | + //填充一下已经买了多少件,只有在商品是有限购条件的时候才进行计算good.viplimited>0 |
558 | + if(carr[i].viplimited>0){ | ||
559 | + if(!by_map) by_map={}; | ||
560 | + by_map[carr[i].goods_id] = carr[i].goodsbuynum?carr[i].goodsbuynum:0; | ||
561 | + } | ||
547 | 562 | ||
548 | - if (g_arr.length == 0) g_arr.push(carr[i].goods_id); | ||
549 | - else { | ||
550 | - var ind = g_arr.findIndex(function (ele) { | 563 | + //如果不是活动的时候,不是代发商品的时候,不是赠品的时候 |
564 | + if([1, 2, 4, 6, 8, 9].indexOf(carr[i].prom_type)== -1 && !carr[i].whsle_id && !carr[i].is_gift ){ | ||
565 | + | ||
566 | + //快速查找 | ||
567 | + let f_idx=g_arr.findIndex(function (ele) { | ||
551 | return ele.goods_id == carr[i].goods_id | 568 | return ele.goods_id == carr[i].goods_id |
552 | - }) | ||
553 | - if (ind > -1) continue; | ||
554 | - g_arr.push(carr[i].goods_id) | 569 | + }); |
570 | + if(f_idx>-1) continue; | ||
571 | + | ||
572 | + let gd_ite={ | ||
573 | + goods_id:carr[i].goods_id, | ||
574 | + goods_num:1, | ||
575 | + is_limit_show:1, | ||
576 | + is_state:0 | ||
577 | + } | ||
578 | + g_arr.push(gd_ite); | ||
555 | } | 579 | } |
556 | } | 580 | } |
557 | 581 | ||
558 | - var by_map = null; | ||
559 | - | ||
560 | - // //--要获得商品,该用户买了多少件,同步应用-- | ||
561 | - // await getApp().request.promiseGet("/api/weshop/ordergoods/listUserBuyGoodsNum", { | ||
562 | - // data: { | ||
563 | - // store_id: oo.stoid, | ||
564 | - // user_id: user_id, | ||
565 | - // goods_ids: g_arr.join(','), | ||
566 | - // | ||
567 | - // }, | ||
568 | - // }).then(res => { | ||
569 | - // if (ut.ajax_ok2(res)) { | ||
570 | - // by_map = {}; | ||
571 | - // for (let i in res.data.data) { | ||
572 | - // let item = res.data.data[i]; | ||
573 | - // by_map[item.goods_id] = item; | ||
574 | - // } | ||
575 | - // } | ||
576 | - // }) | ||
577 | - | ||
578 | - for (let ir = 0; ir < g_arr.length; ir++) { | ||
579 | - let gg_it=g_arr[ir]; | ||
580 | - await getApp().request.promiseGet("/api/weshop/ordergoods/getUserBuyGoodsNum", { | ||
581 | - data: { | ||
582 | - store_id: oo.stoid, | ||
583 | - user_id: user_id, | ||
584 | - goods_id: gg_it, | ||
585 | - isnew:1 | ||
586 | - }, | ||
587 | - }).then(tt => { | ||
588 | - if (tt.data.code == 0) { | ||
589 | - if(!by_map) by_map={}; | ||
590 | - by_map[gg_it] = tt.data.data; | 582 | + //获取商品参与的促销活,优惠促,搭配促,组合促,阶梯促销 |
583 | + let cx_rs= await getApp().request.promisePost("/api/weshop/cart/listGoodsPromInfo",{ | ||
584 | + is_json:1, | ||
585 | + data:{ | ||
586 | + user_id:app.globalData.user_id, | ||
587 | + store_id:oo.stoid, | ||
588 | + goods:g_arr, | ||
589 | + } | ||
590 | + }); | ||
591 | + //-- 判断返回结果有没有正确,有促销活动就要进行赋值 -- | ||
592 | + if(cx_rs && cx_rs.data.code==0 && cx_rs.data.data && cx_rs.data.data.goods) { | ||
593 | + let g_list=cx_rs.data.data.goods; | ||
594 | + for (var ia = 0; ia < carr.length; ia++) { | ||
595 | + if (carr[ia].whsle_id) continue; //代发商品不进行赋值 | ||
596 | + if (carr[ia].is_gift) continue; //赠品不进行赋值 | ||
597 | + //有参与秒,团购之类的活动不进行赋值 | ||
598 | + if([1, 2, 4, 6, 8, 9].indexOf(carr[ia].prom_type)> -1 ) continue; | ||
599 | + //再g_list中快速查找 | ||
600 | + let i_fd=g_list.find(function (ele) { | ||
601 | + return ele.goods_id == carr[ia].goods_id | ||
602 | + }); | ||
603 | + if(i_fd.goodsPromInfoRespDto){ | ||
604 | + //-- 多促销活动的优化 -- | ||
605 | + i_fd=i_fd.goodsPromInfoRespDto; | ||
606 | + //-- 赋值多促销活动的优化-- | ||
607 | + carr[ia].more_cx=i_fd.more_cx; | ||
608 | + if (i_fd.zh_pro) { | ||
609 | + th.data.zuhe_map[i_fd.zh_pro.id] = i_fd.zh_pro; | ||
610 | + } | ||
611 | + if (i_fd.ladder_pro) { | ||
612 | + var ladder_pro = i_fd.ladder_pro; | ||
613 | + th.data.ladder_map[ladder_pro.id] = ladder_pro; | ||
614 | + var fd_ite = i_fd.more_cx.find(function (e) { | ||
615 | + return e.prom_type == 10; | ||
616 | + }) | ||
617 | + if (fd_ite) { | ||
618 | + th.data.ladder_map[ladder_pro.id].ladder_list = fd_ite.ladder_list; | ||
591 | } | 619 | } |
592 | - }) | 620 | + } |
621 | + } | ||
622 | + | ||
623 | + } | ||
593 | } | 624 | } |
594 | 625 | ||
595 | 626 | ||
627 | + | ||
628 | + let cart_up_data=[]; | ||
596 | for (var i = 0; i < carr.length; i++) { | 629 | for (var i = 0; i < carr.length; i++) { |
597 | var item = carr[i]; | 630 | var item = carr[i]; |
598 | var good = item; | 631 | var good = item; |
@@ -622,7 +655,7 @@ Page({ | @@ -622,7 +655,7 @@ Page({ | ||
622 | promgoodsbuynum = 0, | 655 | promgoodsbuynum = 0, |
623 | limit = 0; | 656 | limit = 0; |
624 | if (by_map && by_map[good.goods_id]) { | 657 | if (by_map && by_map[good.goods_id]) { |
625 | - goodsbuynum = by_map[good.goods_id].goodsbuynum; | 658 | + goodsbuynum = by_map[good.goods_id]; |
626 | //promgoodsbuynum = by_map[good.goods_id].promgoodsbuynum; | 659 | //promgoodsbuynum = by_map[good.goods_id].promgoodsbuynum; |
627 | } | 660 | } |
628 | 661 | ||
@@ -662,19 +695,19 @@ Page({ | @@ -662,19 +695,19 @@ Page({ | ||
662 | } else { | 695 | } else { |
663 | item.goods_price = good.shop_price; | 696 | item.goods_price = good.shop_price; |
664 | } | 697 | } |
665 | - | ||
666 | //-- 购物车更新 -- | 698 | //-- 购物车更新 -- |
667 | var updata1 = { | 699 | var updata1 = { |
668 | - id: item.id, | ||
669 | - prom_type: c_prom_type, | ||
670 | - prom_id: c_prom_id, | ||
671 | - store_id: os.stoid, | ||
672 | - user_id: getApp().globalData.userInfo.user_id | 700 | + id: item.id, |
701 | + prom_type: c_prom_type, | ||
702 | + prom_id: c_prom_id, | ||
703 | + store_id: os.stoid, | ||
704 | + user_id: getApp().globalData.userInfo.user_id, | ||
705 | + goods_price:item.goods_price | ||
673 | }; | 706 | }; |
674 | - getApp().request.put("/api/weshop/cart/update", { | ||
675 | - data: updata1, | ||
676 | - }) | ||
677 | - | 707 | + // getApp().request.put("/api/weshop/cart/update", { |
708 | + // data: updata1, | ||
709 | + // }) | ||
710 | + cart_up_data.push(updata1); | ||
678 | } | 711 | } |
679 | 712 | ||
680 | //判断如果是普通商品,后面参加活动了,变成失效商品 | 713 | //判断如果是普通商品,后面参加活动了,变成失效商品 |
@@ -682,24 +715,16 @@ Page({ | @@ -682,24 +715,16 @@ Page({ | ||
682 | 715 | ||
683 | var prom = null; | 716 | var prom = null; |
684 | var now = ut.gettimestamp(); | 717 | var now = ut.gettimestamp(); |
685 | - await getApp().request.promiseGet(`/api/weshop/activitylist/listGoodActInfo2New`, { | ||
686 | - data: { | ||
687 | - "store_id": oo.stoid, | ||
688 | - "goods_id": item.goods_id, | ||
689 | - "user_id": user_id, | ||
690 | - } | ||
691 | - }).then(res => { | ||
692 | - if (res.data.code == 0) { | ||
693 | - //开始时间已经开始的情况 | ||
694 | - for (var i = 0; i < res.data.data.length; i++) { | ||
695 | - var a_item = res.data.data[i]; | ||
696 | - if (a_item.s_time < now) { | ||
697 | - if (!prom) prom = []; | ||
698 | - prom.push(a_item); | ||
699 | - } | 718 | + let prom_arr = item.goodsActinfo; |
719 | + if(prom_arr && prom_arr.length){ | ||
720 | + for (var im = 0; im <prom_arr.length; im++) { | ||
721 | + var a_item = prom_arr[im]; | ||
722 | + if (a_item.s_time < now) { | ||
723 | + if (!prom) prom = []; | ||
724 | + prom.push(a_item); | ||
700 | } | 725 | } |
701 | } | 726 | } |
702 | - }) | 727 | + } |
703 | 728 | ||
704 | //只有一种活动,但是又是秒杀之类是互动,就要失效。不能是普通购买 | 729 | //只有一种活动,但是又是秒杀之类是互动,就要失效。不能是普通购买 |
705 | if (prom && prom.length == 1 && [1, 2, 4, 6, 8, 9].indexOf(prom[0].prom_type) > -1 && !item.is_integral_normal && !item.is_pd_normal) { | 730 | if (prom && prom.length == 1 && [1, 2, 4, 6, 8, 9].indexOf(prom[0].prom_type) > -1 && !item.is_integral_normal && !item.is_pd_normal) { |
@@ -725,36 +750,19 @@ Page({ | @@ -725,36 +750,19 @@ Page({ | ||
725 | 750 | ||
726 | } | 751 | } |
727 | 752 | ||
728 | - | ||
729 | //优化获取商品的活动购买了几件 | 753 | //优化获取商品的活动购买了几件 |
730 | if (item.prom_type == 1 || item.prom_type == 2) { | 754 | if (item.prom_type == 1 || item.prom_type == 2) { |
731 | - await getApp().request.promiseGet("/api/weshop/ordergoods/getUserBuyPromNum", { | ||
732 | - data: { | ||
733 | - store_id: oo.stoid, | ||
734 | - user_id: user_id, | ||
735 | - goods_id: item.goods_id, | ||
736 | - prom_type: item.prom_type, | ||
737 | - prom_id: item.prom_id | ||
738 | - }, | ||
739 | - }).then(res => { | ||
740 | - if (res.data.code == 0) { | ||
741 | - promgoodsbuynum = res.data.data.userbuynum; | ||
742 | - } | ||
743 | - }) | 755 | + if(item.promgoodsbuynum){ |
756 | + promgoodsbuynum=item.promgoodsbuynum; | ||
757 | + } | ||
744 | } | 758 | } |
745 | - | ||
746 | //如果秒杀活动都去掉了,或者结束了,那么这个商品也没有必要留着 | 759 | //如果秒杀活动都去掉了,或者结束了,那么这个商品也没有必要留着 |
747 | if (item.prom_type == 1) { | 760 | if (item.prom_type == 1) { |
748 | - var prom = null; | 761 | + var prom = item.cartActinfo; |
749 | var now = ut.gettimestamp(); | 762 | var now = ut.gettimestamp(); |
750 | - await getApp().request.promiseGet("/api/ms/flash_sale/getNew/" + os.stoid + '/' + user_id + "/" + item.prom_id, {}).then(res => { | ||
751 | - console.log('活动情况----------------') | ||
752 | - console.log(res) | ||
753 | - if (res.data.code == 0 && res.data.data) { | ||
754 | - prom = res.data.data; | ||
755 | - prom.price = prom.user_price; | ||
756 | - } | ||
757 | - }) | 763 | + if(prom){ |
764 | + prom.price = prom.user_price; | ||
765 | + } | ||
758 | //---如果互动都已经过期,或者还未开始,或者无活动 | 766 | //---如果互动都已经过期,或者还未开始,或者无活动 |
759 | if (!prom || prom.is_end == 1 || prom.end_time < now || prom.start_time > now) { | 767 | if (!prom || prom.is_end == 1 || prom.end_time < now || prom.start_time > now) { |
760 | // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; | 768 | // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; |
@@ -807,14 +815,12 @@ Page({ | @@ -807,14 +815,12 @@ Page({ | ||
807 | } | 815 | } |
808 | // 判断团购活动都去掉了,或者结束了,那么这个商品也没有必要留着 | 816 | // 判断团购活动都去掉了,或者结束了,那么这个商品也没有必要留着 |
809 | else if (item.prom_type == 2) { | 817 | else if (item.prom_type == 2) { |
810 | - var prom = null; | 818 | + var prom = item.cartActinfo; |
811 | var now = ut.gettimestamp(); | 819 | var now = ut.gettimestamp(); |
812 | - await getApp().request.promiseGet('/api/weshop/goods/groupBuy/getActInfo/' + oo.stoid + '/' + item.goods_id + '/' + item.prom_id, {}).then(res => { | ||
813 | - if (res.data.code == 0) { | ||
814 | - prom = res.data.data; | ||
815 | - prom.price = prom.user_price; | ||
816 | - } | ||
817 | - }); | 820 | + if(prom){ |
821 | + prom.price = prom.user_price; | ||
822 | + } | ||
823 | + | ||
818 | //---如果互动都已经过期,或者还未开始,或者无活动 | 824 | //---如果互动都已经过期,或者还未开始,或者无活动 |
819 | if (!prom || prom.is_end == 1 || prom.end_time < now || prom.start_time > now) { | 825 | if (!prom || prom.is_end == 1 || prom.end_time < now || prom.start_time > now) { |
820 | // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; | 826 | // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; |
@@ -863,8 +869,7 @@ Page({ | @@ -863,8 +869,7 @@ Page({ | ||
863 | item.init_goods_price=good.goods_price; | 869 | item.init_goods_price=good.goods_price; |
864 | 870 | ||
865 | //-- 读出每一种商品的所有的活动,方便后面的活动切换使用 -- | 871 | //-- 读出每一种商品的所有的活动,方便后面的活动切换使用 -- |
866 | - if (item.prom_type == 0) | ||
867 | - th.buy_pro_group(item, 0); | 872 | + //if (item.prom_type == 0) th.buy_pro_group(item, 0); |
868 | 873 | ||
869 | var pcid = item.pick_id; | 874 | var pcid = item.pick_id; |
870 | var find = 0; | 875 | var find = 0; |
@@ -900,8 +905,15 @@ Page({ | @@ -900,8 +905,15 @@ Page({ | ||
900 | arr.push(ie); | 905 | arr.push(ie); |
901 | } | 906 | } |
902 | } | 907 | } |
903 | - } | ||
904 | 908 | ||
909 | + //更新一下购物车商品的活动信息 | ||
910 | + if(cart_up_data.length>0){ | ||
911 | + getApp().request.promisePost('/api/weshop/cart/updateCartPromInfo',{ | ||
912 | + is_json:1, | ||
913 | + data:cart_up_data | ||
914 | + }) | ||
915 | + } | ||
916 | + } | ||
905 | if (th.data.is_open_offline && th.data.is_open_offline > 0 && th.data.sales_rules == 2) { | 917 | if (th.data.is_open_offline && th.data.is_open_offline > 0 && th.data.sales_rules == 2) { |
906 | //-- 此时要实时更新线下取价价格 -- | 918 | //-- 此时要实时更新线下取价价格 -- |
907 | for (var i = 0; i < arr.length; i++) { | 919 | for (var i = 0; i < arr.length; i++) { |
@@ -1224,7 +1236,6 @@ Page({ | @@ -1224,7 +1236,6 @@ Page({ | ||
1224 | 1236 | ||
1225 | if (a = isNaN(t.detail.value) || t.detail.value < 1 ? 1 : parseInt(t.detail.value)) { | 1237 | if (a = isNaN(t.detail.value) || t.detail.value < 1 ? 1 : parseInt(t.detail.value)) { |
1226 | //this.clear_req(); | 1238 | //this.clear_req(); |
1227 | - | ||
1228 | var s = { | 1239 | var s = { |
1229 | goods_num: a, | 1240 | goods_num: a, |
1230 | goods_id: e.goods_id, | 1241 | goods_id: e.goods_id, |
@@ -1237,14 +1248,14 @@ Page({ | @@ -1237,14 +1248,14 @@ Page({ | ||
1237 | 1248 | ||
1238 | //-------------加减数量的时候,要把show_can_cx清理掉, | 1249 | //-------------加减数量的时候,要把show_can_cx清理掉, |
1239 | // 同时应该记录一下当前是什么活动那个,如果切换后的活动有跟切换前的活动一样是,就要让切换后的活动的值匹配选中------------- | 1250 | // 同时应该记录一下当前是什么活动那个,如果切换后的活动有跟切换前的活动一样是,就要让切换后的活动的值匹配选中------------- |
1240 | - | ||
1241 | clear_req: function () { | 1251 | clear_req: function () { |
1242 | var carr = this.data.requestData; | 1252 | var carr = this.data.requestData; |
1243 | for (var i = 0; i < carr.length; i++) { | 1253 | for (var i = 0; i < carr.length; i++) { |
1244 | - var txt = 'requestData[' + i + '].show_can_cx' | ||
1245 | - this.setData({ | ||
1246 | - [txt]: null | ||
1247 | - }); | 1254 | + var txt = 'requestData[' + i + '].show_can_cx1' |
1255 | + this.setData({ | ||
1256 | + [txt]: null | ||
1257 | + }); | ||
1258 | + this.data.requestData[i].show_can_cx=null; | ||
1248 | } | 1259 | } |
1249 | }, | 1260 | }, |
1250 | 1261 | ||
@@ -1282,7 +1293,7 @@ Page({ | @@ -1282,7 +1293,7 @@ Page({ | ||
1282 | var add_num = 1; | 1293 | var add_num = 1; |
1283 | //调用接口判断是不是促销活动的商品 | 1294 | //调用接口判断是不是促销活动的商品 |
1284 | if ([0, 3, 5, 7, 10].indexOf(a.prom_type) > -1) { | 1295 | if ([0, 3, 5, 7, 10].indexOf(a.prom_type) > -1) { |
1285 | - var cx_arr = await getApp().get_has_cx_act(a.goods_id); | 1296 | + var cx_arr = getApp().get_has_cx_act2(a.goodsActinfo); |
1286 | var steep = getApp().get_limit_qty(a, cx_arr.length, 1); | 1297 | var steep = getApp().get_limit_qty(a, cx_arr.length, 1); |
1287 | if (steep > 1) { | 1298 | if (steep > 1) { |
1288 | add_num = steep; | 1299 | add_num = steep; |
@@ -1321,7 +1332,7 @@ Page({ | @@ -1321,7 +1332,7 @@ Page({ | ||
1321 | //this.clear_req(); | 1332 | //this.clear_req(); |
1322 | var add_num = 1; | 1333 | var add_num = 1; |
1323 | if ([0, 3, 5, 7, 10].indexOf(a.prom_type) > -1) { | 1334 | if ([0, 3, 5, 7, 10].indexOf(a.prom_type) > -1) { |
1324 | - var cx_arr = await getApp().get_has_cx_act(a.goods_id); | 1335 | + var cx_arr = getApp().get_has_cx_act2(a.goodsActinfo); |
1325 | var steep = getApp().get_limit_qty(a, cx_arr.length, 1); | 1336 | var steep = getApp().get_limit_qty(a, cx_arr.length, 1); |
1326 | if (steep > 1) { | 1337 | if (steep > 1) { |
1327 | add_num = steep; | 1338 | add_num = steep; |
@@ -1477,36 +1488,44 @@ Page({ | @@ -1477,36 +1488,44 @@ Page({ | ||
1477 | } | 1488 | } |
1478 | }, | 1489 | }, |
1479 | 1490 | ||
1480 | - | ||
1481 | //---------------全选,全选的时候要判断是否门店的匹配方式一致-------------- | 1491 | //---------------全选,全选的时候要判断是否门店的匹配方式一致-------------- |
1482 | checkAll: async function () { | 1492 | checkAll: async function () { |
1493 | + | ||
1494 | + console.log('1111'); | ||
1495 | + console.log(this.data.clicking); | ||
1496 | + | ||
1497 | + //防止重复点击,弹出加载动画,转圈圈 | ||
1498 | + if(this.data.clicking) return false; | ||
1499 | + this.data.clicking=1; | ||
1500 | + this.set_clicking(); | ||
1501 | + | ||
1483 | var e = this, | 1502 | var e = this, |
1484 | - th = this, | ||
1485 | - dda = e.data.requestData, | ||
1486 | - sdda = e.data.service_data, | ||
1487 | - tfeel = 0, | ||
1488 | - t_num = 0, | ||
1489 | - text_arr = ""; | 1503 | + th = this, |
1504 | + dda = e.data.requestData, | ||
1505 | + sdda = e.data.service_data, | ||
1506 | + tfeel = 0, | ||
1507 | + t_num = 0, | ||
1508 | + text_arr = ""; | ||
1490 | 1509 | ||
1491 | 1510 | ||
1492 | if(this.data.is_edit){ | 1511 | if(this.data.is_edit){ |
1493 | let val=!e.data.checkAllToggle; | 1512 | let val=!e.data.checkAllToggle; |
1494 | if (dda && dda.length > 0) { | 1513 | if (dda && dda.length > 0) { |
1495 | - for (var i = 0; i < dda.length; i++) { | ||
1496 | - var item = dda[i].goods; | 1514 | + for (var i = 0; i < dda.length; i++) { |
1515 | + var item = dda[i].goods; | ||
1497 | 1516 | ||
1498 | - var txt0 = "requestData[" + i + "].selected"; | ||
1499 | - this.setData({ | ||
1500 | - [txt0]: val, | ||
1501 | - }); | 1517 | + var txt0 = "requestData[" + i + "].selected"; |
1518 | + this.setData({ | ||
1519 | + [txt0]: val, | ||
1520 | + }); | ||
1502 | 1521 | ||
1503 | - for (var j = 0; j < item.length; j++) { | ||
1504 | - let txt = "requestData[" + i + "].goods[" + j + "].selected"; | ||
1505 | - e.setData({ | ||
1506 | - [txt]: val, | ||
1507 | - }); | ||
1508 | - } | 1522 | + for (var j = 0; j < item.length; j++) { |
1523 | + let txt = "requestData[" + i + "].goods[" + j + "].selected"; | ||
1524 | + e.setData({ | ||
1525 | + [txt]: val, | ||
1526 | + }); | ||
1509 | } | 1527 | } |
1528 | + } | ||
1510 | } | 1529 | } |
1511 | if (sdda && sdda.length > 0) { | 1530 | if (sdda && sdda.length > 0) { |
1512 | for (i = 0; i < sdda.length; i++) { | 1531 | for (i = 0; i < sdda.length; i++) { |
@@ -1529,15 +1548,18 @@ Page({ | @@ -1529,15 +1548,18 @@ Page({ | ||
1529 | e.setData({ | 1548 | e.setData({ |
1530 | checkAllToggle: val, | 1549 | checkAllToggle: val, |
1531 | }) | 1550 | }) |
1551 | + | ||
1552 | + th.clear_clicking(); | ||
1532 | return false; | 1553 | return false; |
1533 | } | 1554 | } |
1534 | 1555 | ||
1535 | if (e.data.requestData && e.data.requestData.length > 0 && | 1556 | if (e.data.requestData && e.data.requestData.length > 0 && |
1536 | - e.data.service_data && e.data.service_data.length > 0) { | 1557 | + e.data.service_data && e.data.service_data.length > 0) { |
1537 | wx.showModal({ | 1558 | wx.showModal({ |
1538 | title: '提示', | 1559 | title: '提示', |
1539 | content: '服务卡项目不能和商品一起选择' | 1560 | content: '服务卡项目不能和商品一起选择' |
1540 | }); | 1561 | }); |
1562 | + th.clear_clicking(); | ||
1541 | return false; | 1563 | return false; |
1542 | } | 1564 | } |
1543 | 1565 | ||
@@ -1550,10 +1572,11 @@ Page({ | @@ -1550,10 +1572,11 @@ Page({ | ||
1550 | if (dda && dda.length > 0) { | 1572 | if (dda && dda.length > 0) { |
1551 | for (var i = 0; i < dda.length; i++) { | 1573 | for (var i = 0; i < dda.length; i++) { |
1552 | var item = dda[i].goods; | 1574 | var item = dda[i].goods; |
1553 | - var txt0 = "requestData[" + i + "].show_can_cx"; | 1575 | + var txt0 = "requestData[" + i + "].show_can_cx1"; |
1554 | e.setData({ | 1576 | e.setData({ |
1555 | [txt0]: {}, | 1577 | [txt0]: {}, |
1556 | }); | 1578 | }); |
1579 | + th.data.requestData[i].show_can_cx=null; //清空需要的 | ||
1557 | 1580 | ||
1558 | if (e.data.checkAllToggle) { | 1581 | if (e.data.checkAllToggle) { |
1559 | var txt = "requestData[" + i + "].selected"; | 1582 | var txt = "requestData[" + i + "].selected"; |
@@ -1579,35 +1602,37 @@ Page({ | @@ -1579,35 +1602,37 @@ Page({ | ||
1579 | }); | 1602 | }); |
1580 | 1603 | ||
1581 | if (ob.code == -1) { | 1604 | if (ob.code == -1) { |
1582 | - | ||
1583 | wx.showToast({ | 1605 | wx.showToast({ |
1584 | title: gd_info.goods_name+'购买数量超出商品库存', | 1606 | title: gd_info.goods_name+'购买数量超出商品库存', |
1585 | icon: 'none', | 1607 | icon: 'none', |
1586 | }); | 1608 | }); |
1587 | 1609 | ||
1610 | + th.clear_clicking(); | ||
1588 | return false; | 1611 | return false; |
1589 | - } else { | ||
1590 | - if (th.data.sales_rules == 3) { | ||
1591 | - var goods_id = gd_info.goods_id; | ||
1592 | - var num = 0; | ||
1593 | - | ||
1594 | - for (let ii = 0; ii< th.data.requestData.length; ii++) { | ||
1595 | - if (i == ii) continue; | ||
1596 | - var it = th.data.requestData[ii].goods.find((e) => { | ||
1597 | - return e.goods_id == goods_id; | ||
1598 | - }) | ||
1599 | - if (it && it.selected) num += it.goods_num | ||
1600 | - } | 1612 | + } |
1601 | 1613 | ||
1602 | - if (num > ob.CanOutQty) { | ||
1603 | - wx.showToast({ | ||
1604 | - title: gd_info.goods_name+'购买数量超出商品库存', | ||
1605 | - icon: 'none', | ||
1606 | - }); | ||
1607 | - return false; | ||
1608 | - } | 1614 | + if (th.data.sales_rules == 3) { |
1615 | + var goods_id = gd_info.goods_id; | ||
1616 | + var num = 0; | ||
1617 | + | ||
1618 | + for (let ii = 0; ii< th.data.requestData.length; ii++) { | ||
1619 | + if (i == ii) continue; | ||
1620 | + var it = th.data.requestData[ii].goods.find((e) => { | ||
1621 | + return e.goods_id == goods_id; | ||
1622 | + }) | ||
1623 | + if (it && it.selected) num += it.goods_num | ||
1624 | + } | ||
1625 | + | ||
1626 | + if (num > ob.CanOutQty) { | ||
1627 | + wx.showToast({ | ||
1628 | + title: gd_info.goods_name+'购买数量超出商品库存', | ||
1629 | + icon: 'none', | ||
1630 | + }); | ||
1631 | + th.clear_clicking(); | ||
1632 | + return false; | ||
1609 | } | 1633 | } |
1610 | } | 1634 | } |
1635 | + | ||
1611 | } | 1636 | } |
1612 | 1637 | ||
1613 | 1638 | ||
@@ -1615,7 +1640,7 @@ Page({ | @@ -1615,7 +1640,7 @@ Page({ | ||
1615 | //-- 判断起购数量 -- | 1640 | //-- 判断起购数量 -- |
1616 | if (!e.data.checkAllToggle) { | 1641 | if (!e.data.checkAllToggle) { |
1617 | //判断是不是有促销活动 | 1642 | //判断是不是有促销活动 |
1618 | - var act = await getApp().get_has_cx_act(obj.goods_id); | 1643 | + var act = getApp().get_has_cx_act2(obj.goodsActinfo); |
1619 | th.click_set_limit(obj, i, j, act); | 1644 | th.click_set_limit(obj, i, j, act); |
1620 | } | 1645 | } |
1621 | 1646 | ||
@@ -1677,9 +1702,6 @@ Page({ | @@ -1677,9 +1702,6 @@ Page({ | ||
1677 | }); | 1702 | }); |
1678 | 1703 | ||
1679 | } else { | 1704 | } else { |
1680 | - e.setData({ | ||
1681 | - [txt]: !e.data.checkAllToggle, | ||
1682 | - }) | ||
1683 | 1705 | ||
1684 | if (!e.data.checkAllToggle) { | 1706 | if (!e.data.checkAllToggle) { |
1685 | //组合购的金额要另外算 | 1707 | //组合购的金额要另外算 |
@@ -1694,6 +1716,7 @@ Page({ | @@ -1694,6 +1716,7 @@ Page({ | ||
1694 | offline_num += item[j].goods_num; | 1716 | offline_num += item[j].goods_num; |
1695 | } | 1717 | } |
1696 | } | 1718 | } |
1719 | + | ||
1697 | e.setData({ | 1720 | e.setData({ |
1698 | [txt]: !e.data.checkAllToggle, | 1721 | [txt]: !e.data.checkAllToggle, |
1699 | }) | 1722 | }) |
@@ -1720,79 +1743,79 @@ Page({ | @@ -1720,79 +1743,79 @@ Page({ | ||
1720 | title: '提示', | 1743 | title: '提示', |
1721 | content: text_arr + '不能与门店中其他商品一起结算,配送方式不一致' | 1744 | content: text_arr + '不能与门店中其他商品一起结算,配送方式不一致' |
1722 | }); | 1745 | }); |
1746 | + th.clear_clicking(); | ||
1723 | return false; | 1747 | return false; |
1724 | - } else { | 1748 | + } |
1725 | 1749 | ||
1726 | - for (var i = 0; i < dda.length; i++) { | ||
1727 | 1750 | ||
1728 | - // if (!e.data.checkAllToggle) { | ||
1729 | - //多门店优惠促销次数控制 | ||
1730 | - if (dda[i].pro_off || e.data.checkAllToggle) { | ||
1731 | - var txt = "requestData[" + i + "].selected"; | ||
1732 | - e.setData({ | ||
1733 | - [txt]: 0, | ||
1734 | - }); | ||
1735 | - } else { | ||
1736 | - var txt = "requestData[" + i + "].selected"; | ||
1737 | - e.setData({ | ||
1738 | - [txt]: 1, | ||
1739 | - }); | ||
1740 | - } | ||
1741 | - // } | 1751 | + for (var i = 0; i < dda.length; i++) { |
1742 | 1752 | ||
1743 | - //总的价格,把组合商品的价格拿出来 | ||
1744 | - // var zh_calc_res = zh_calc.calculate_zh(dda, i, this); | ||
1745 | - // tfeel += zh_calc_res.tfeel; | ||
1746 | - // offline_price += zh_calc_res.offline_price; | ||
1747 | - // offline_num += zh_calc_res.offline_num; | ||
1748 | - // | ||
1749 | - // //总的价格,把阶梯促销的商品的价格拿出来 | ||
1750 | - // var ladder_calc_res = ladder_calc.calculate_ladder(dda, i, this); | ||
1751 | - // tfeel += ladder_calc_res.tfeel; | ||
1752 | - // offline_price += ladder_calc_res.offline_price; | ||
1753 | - // offline_num += ladder_calc_res.offline_num; | ||
1754 | - // | ||
1755 | - // //当有线下取价的时候 | ||
1756 | - // if (offline_price) { | ||
1757 | - // var txt1 = "requestData[" + i + "].offline_price"; | ||
1758 | - // var txt2 = "requestData[" + i + "].offline_num"; | ||
1759 | - // th.setData({ | ||
1760 | - // [txt1]: offline_price.toFixed(2), | ||
1761 | - // [txt2]: offline_num, | ||
1762 | - // }); | ||
1763 | - // } else { | ||
1764 | - // if (dda[i].offline_price > 0) { | ||
1765 | - // var txt1 = "requestData[" + i + "].offline_price"; | ||
1766 | - // var txt2 = "requestData[" + i + "].offline_num"; | ||
1767 | - // th.setData({ | ||
1768 | - // [txt1]: 0, | ||
1769 | - // [txt2]: 0 | ||
1770 | - // }); | ||
1771 | - // } | ||
1772 | - // } | ||
1773 | - } | ||
1774 | - //多门店优惠次数控制 | ||
1775 | - if (pro_off) { | 1753 | + // if (!e.data.checkAllToggle) { |
1754 | + //多门店优惠促销次数控制 | ||
1755 | + if (dda[i].pro_off || e.data.checkAllToggle) { | ||
1756 | + var txt = "requestData[" + i + "].selected"; | ||
1776 | e.setData({ | 1757 | e.setData({ |
1777 | - checkAllToggle: false, | 1758 | + [txt]: 0, |
1778 | }); | 1759 | }); |
1779 | } else { | 1760 | } else { |
1761 | + var txt = "requestData[" + i + "].selected"; | ||
1780 | e.setData({ | 1762 | e.setData({ |
1781 | - checkAllToggle: !e.data.checkAllToggle, | 1763 | + [txt]: 1, |
1782 | }); | 1764 | }); |
1783 | } | 1765 | } |
1784 | - e.setData({ | ||
1785 | - checkAllToggle: !e.data.checkAllToggle, | ||
1786 | - // total_fee: tfeel.toFixed(2), | ||
1787 | - // total_num: t_num, | 1766 | + // } |
1788 | 1767 | ||
1789 | - }); | 1768 | + //总的价格,把组合商品的价格拿出来 |
1769 | + // var zh_calc_res = zh_calc.calculate_zh(dda, i, this); | ||
1770 | + // tfeel += zh_calc_res.tfeel; | ||
1771 | + // offline_price += zh_calc_res.offline_price; | ||
1772 | + // offline_num += zh_calc_res.offline_num; | ||
1773 | + // | ||
1774 | + // //总的价格,把阶梯促销的商品的价格拿出来 | ||
1775 | + // var ladder_calc_res = ladder_calc.calculate_ladder(dda, i, this); | ||
1776 | + // tfeel += ladder_calc_res.tfeel; | ||
1777 | + // offline_price += ladder_calc_res.offline_price; | ||
1778 | + // offline_num += ladder_calc_res.offline_num; | ||
1779 | + // | ||
1780 | + // //当有线下取价的时候 | ||
1781 | + // if (offline_price) { | ||
1782 | + // var txt1 = "requestData[" + i + "].offline_price"; | ||
1783 | + // var txt2 = "requestData[" + i + "].offline_num"; | ||
1784 | + // th.setData({ | ||
1785 | + // [txt1]: offline_price.toFixed(2), | ||
1786 | + // [txt2]: offline_num, | ||
1787 | + // }); | ||
1788 | + // } else { | ||
1789 | + // if (dda[i].offline_price > 0) { | ||
1790 | + // var txt1 = "requestData[" + i + "].offline_price"; | ||
1791 | + // var txt2 = "requestData[" + i + "].offline_num"; | ||
1792 | + // th.setData({ | ||
1793 | + // [txt1]: 0, | ||
1794 | + // [txt2]: 0 | ||
1795 | + // }); | ||
1796 | + // } | ||
1797 | + // } | ||
1798 | + } | ||
1790 | 1799 | ||
1791 | - this.doCheckAll(function () { | ||
1792 | - e.all_check_prom_activity(); | ||
1793 | - }); | 1800 | + //e.setData({ |
1801 | + //checkAllToggle: !e.data.checkAllToggle, | ||
1802 | + // total_fee: tfeel.toFixed(2), | ||
1803 | + // total_num: t_num, | ||
1804 | + //}); | ||
1805 | + | ||
1806 | + this.doCheckAll(async function () { | ||
1807 | + await e.all_check_prom_activity(); | ||
1808 | + | ||
1809 | + //多门店优惠次数控制 | ||
1810 | + if (pro_off) { | ||
1811 | + e.setData({ | ||
1812 | + checkAllToggle: false, | ||
1813 | + }); | ||
1814 | + } | ||
1815 | + th.clear_clicking(); | ||
1816 | + | ||
1817 | + }); | ||
1794 | 1818 | ||
1795 | - } | ||
1796 | } | 1819 | } |
1797 | 1820 | ||
1798 | if (sdda && sdda.length > 0) { | 1821 | if (sdda && sdda.length > 0) { |
@@ -1822,28 +1845,40 @@ Page({ | @@ -1822,28 +1845,40 @@ Page({ | ||
1822 | total_fee: tfeel.toFixed(2), | 1845 | total_fee: tfeel.toFixed(2), |
1823 | total_num: t_num, | 1846 | total_num: t_num, |
1824 | }); | 1847 | }); |
1825 | - } | ||
1826 | 1848 | ||
1849 | + th.clear_clicking(); | ||
1850 | + | ||
1851 | + } | ||
1827 | }, | 1852 | }, |
1853 | + | ||
1854 | + | ||
1828 | //------门店全选按钮,要判断是否门店的匹配方式一致--------- | 1855 | //------门店全选按钮,要判断是否门店的匹配方式一致--------- |
1829 | check_th_all_item: async function (ele) { | 1856 | check_th_all_item: async function (ele) { |
1857 | + | ||
1858 | + //防止重复点击 | ||
1859 | + if(this.data.clicking) return false; | ||
1860 | + this.data.clicking=1; | ||
1861 | + //加载动画 | ||
1862 | + this.set_clicking(); | ||
1863 | + | ||
1830 | var e = this, | 1864 | var e = this, |
1831 | - th = this, | ||
1832 | - pitems = ele.currentTarget.dataset.pitems, | ||
1833 | - item = this.data.requestData[pitems].goods, | ||
1834 | - sele = this.data.requestData[pitems].selected; | 1865 | + th = this, |
1866 | + pitems = ele.currentTarget.dataset.pitems, | ||
1867 | + item = this.data.requestData[pitems].goods, | ||
1868 | + sele = this.data.requestData[pitems].selected; | ||
1835 | this.data.btn_click = 1; | 1869 | this.data.btn_click = 1; |
1836 | var garr = e.data.service_data; | 1870 | var garr = e.data.service_data; |
1837 | 1871 | ||
1838 | var isok = 1, | 1872 | var isok = 1, |
1839 | - fir = 0, | ||
1840 | - iarr = item; | 1873 | + fir = 0, |
1874 | + iarr = item; | ||
1841 | 1875 | ||
1842 | //清空-- 多个促销的切换 -- | 1876 | //清空-- 多个促销的切换 -- |
1843 | - var txt0 = "requestData[" + pitems + "].show_can_cx"; | 1877 | + var txt0 = "requestData[" + pitems + "].show_can_cx1"; |
1844 | e.setData({ | 1878 | e.setData({ |
1845 | [txt0]: {}, | 1879 | [txt0]: {}, |
1846 | }); | 1880 | }); |
1881 | + th.data.requestData[pitems].show_can_cx=null; //清空需要的 | ||
1847 | 1882 | ||
1848 | if (!sele) { | 1883 | if (!sele) { |
1849 | 1884 | ||
@@ -1857,6 +1892,8 @@ Page({ | @@ -1857,6 +1892,8 @@ Page({ | ||
1857 | 1892 | ||
1858 | var txt0 = "requestData[" + pitems + "].selected"; | 1893 | var txt0 = "requestData[" + pitems + "].selected"; |
1859 | this.setData({[txt0]:1}) | 1894 | this.setData({[txt0]:1}) |
1895 | + | ||
1896 | + th.clear_clicking(); | ||
1860 | return false; | 1897 | return false; |
1861 | } | 1898 | } |
1862 | 1899 | ||
@@ -1875,6 +1912,7 @@ Page({ | @@ -1875,6 +1912,7 @@ Page({ | ||
1875 | title: '提示', | 1912 | title: '提示', |
1876 | content: '服务卡项目不能和商品一起选择' | 1913 | content: '服务卡项目不能和商品一起选择' |
1877 | }); | 1914 | }); |
1915 | + th.clear_clicking(); | ||
1878 | return false; | 1916 | return false; |
1879 | } | 1917 | } |
1880 | } | 1918 | } |
@@ -1900,6 +1938,7 @@ Page({ | @@ -1900,6 +1938,7 @@ Page({ | ||
1900 | title: '提示', | 1938 | title: '提示', |
1901 | content: '同一门店自提和物流的商品不能同时结算' | 1939 | content: '同一门店自提和物流的商品不能同时结算' |
1902 | }); | 1940 | }); |
1941 | + th.clear_clicking(); | ||
1903 | return false; | 1942 | return false; |
1904 | } | 1943 | } |
1905 | 1944 | ||
@@ -1910,7 +1949,7 @@ Page({ | @@ -1910,7 +1949,7 @@ Page({ | ||
1910 | var gd_info = item[i]; | 1949 | var gd_info = item[i]; |
1911 | 1950 | ||
1912 | if (!sele) { | 1951 | if (!sele) { |
1913 | - var act = await getApp().get_has_cx_act(gd_info.goods_id); | 1952 | + var act =getApp().get_has_cx_act2(gd_info.goodsActinfo); |
1914 | th.click_set_limit(gd_info, pitems, i, act) | 1953 | th.click_set_limit(gd_info, pitems, i, act) |
1915 | } | 1954 | } |
1916 | 1955 | ||
@@ -1927,29 +1966,32 @@ Page({ | @@ -1927,29 +1966,32 @@ Page({ | ||
1927 | icon: 'none', | 1966 | icon: 'none', |
1928 | }); | 1967 | }); |
1929 | 1968 | ||
1969 | + th.clear_clicking(); | ||
1930 | return false; | 1970 | return false; |
1931 | - } else { | ||
1932 | - if (th.data.sales_rules == 3) { | ||
1933 | - var goods_id = gd_info.goods_id; | ||
1934 | - var num = 0; | ||
1935 | - | ||
1936 | - for (let i = 0; i < th.data.requestData.length; i++) { | ||
1937 | - if (pitems == i) continue; | ||
1938 | - var it = th.data.requestData[i].goods.find((e) => { | ||
1939 | - return e.goods_id == goods_id; | ||
1940 | - }) | ||
1941 | - if (it && it.selected) num += it.goods_num | ||
1942 | - } | 1971 | + } |
1943 | 1972 | ||
1944 | - if (num > ob.CanOutQty) { | ||
1945 | - wx.showToast({ | ||
1946 | - title: gd_info.goods_name+'购买数量超出商品库存', | ||
1947 | - icon: 'none', | ||
1948 | - }); | ||
1949 | - return false; | ||
1950 | - } | 1973 | + if (th.data.sales_rules == 3) { |
1974 | + var goods_id = gd_info.goods_id; | ||
1975 | + var num = 0; | ||
1976 | + | ||
1977 | + for (let i = 0; i < th.data.requestData.length; i++) { | ||
1978 | + if (pitems == i) continue; | ||
1979 | + var it = th.data.requestData[i].goods.find((e) => { | ||
1980 | + return e.goods_id == goods_id; | ||
1981 | + }) | ||
1982 | + if (it && it.selected) num += it.goods_num | ||
1983 | + } | ||
1984 | + | ||
1985 | + if (num > ob.CanOutQty) { | ||
1986 | + wx.showToast({ | ||
1987 | + title: gd_info.goods_name+'购买数量超出商品库存', | ||
1988 | + icon: 'none', | ||
1989 | + }); | ||
1990 | + th.clear_clicking(); | ||
1991 | + return false; | ||
1951 | } | 1992 | } |
1952 | } | 1993 | } |
1994 | + | ||
1953 | } | 1995 | } |
1954 | 1996 | ||
1955 | //判断多店优惠促销次数控制 | 1997 | //判断多店优惠促销次数控制 |
@@ -2023,12 +2065,17 @@ Page({ | @@ -2023,12 +2065,17 @@ Page({ | ||
2023 | if (sele && i == pitems) continue; | 2065 | if (sele && i == pitems) continue; |
2024 | await e.check_prom_activity(i); | 2066 | await e.check_prom_activity(i); |
2025 | } | 2067 | } |
2068 | + | ||
2069 | + th.clear_clicking(); | ||
2070 | + | ||
2026 | }); | 2071 | }); |
2027 | } else { | 2072 | } else { |
2073 | + th.clear_clicking(); | ||
2028 | wx.showToast({ | 2074 | wx.showToast({ |
2029 | title: the_res.msg, | 2075 | title: the_res.msg, |
2030 | icon: 'none', | 2076 | icon: 'none', |
2031 | }); | 2077 | }); |
2078 | + | ||
2032 | } | 2079 | } |
2033 | }) | 2080 | }) |
2034 | 2081 | ||
@@ -2074,16 +2121,35 @@ Page({ | @@ -2074,16 +2121,35 @@ Page({ | ||
2074 | }, | 2121 | }, |
2075 | 2122 | ||
2076 | 2123 | ||
2077 | - | 2124 | + //清理防止重复点击的状态函数---2024-2-1 |
2125 | + set_clicking(){ | ||
2126 | + wx.showLoading({ | ||
2127 | + mark:true | ||
2128 | + }); | ||
2129 | + }, | ||
2130 | + //清理防止重复点击的状态函数---2024-2-1 | ||
2131 | + clear_clicking(){ | ||
2132 | + var th=this; | ||
2133 | + wx.hideLoading({ | ||
2134 | + complete:function (){ | ||
2135 | + th.data.clicking=0; | ||
2136 | + } | ||
2137 | + }); | ||
2138 | + }, | ||
2078 | //---------------单选,也要判断门店的配送方式是否一致-------------- | 2139 | //---------------单选,也要判断门店的配送方式是否一致-------------- |
2079 | check_th_item: async function (t) { | 2140 | check_th_item: async function (t) { |
2141 | + | ||
2142 | + //防止重复点击 | ||
2143 | + if(this.data.clicking) return false; | ||
2144 | + this.data.clicking=1; | ||
2145 | + | ||
2080 | var e = this, | 2146 | var e = this, |
2081 | - th = this, | ||
2082 | - item = t.currentTarget.dataset.item, | ||
2083 | - pitems = t.currentTarget.dataset.pitems; | 2147 | + th = this, |
2148 | + item = t.currentTarget.dataset.item, | ||
2149 | + pitems = t.currentTarget.dataset.pitems; | ||
2084 | a = this.data.requestData[pitems].goods[item]; | 2150 | a = this.data.requestData[pitems].goods[item]; |
2085 | var isok = 1, | 2151 | var isok = 1, |
2086 | - fir = 0; | 2152 | + fir = 0; |
2087 | var iarr = e.data.requestData[pitems].goods; | 2153 | var iarr = e.data.requestData[pitems].goods; |
2088 | this.data.btn_click = 1; | 2154 | this.data.btn_click = 1; |
2089 | var garr = e.data.service_data; | 2155 | var garr = e.data.service_data; |
@@ -2093,9 +2159,10 @@ Page({ | @@ -2093,9 +2159,10 @@ Page({ | ||
2093 | 2159 | ||
2094 | //如果是标记的时候 | 2160 | //如果是标记的时候 |
2095 | if(this.data.is_edit){ | 2161 | if(this.data.is_edit){ |
2096 | - var txt = "requestData[" + pitems + "].goods[" + item + "].selected"; | ||
2097 | - this.setData({[txt]:1}) | ||
2098 | - return false; | 2162 | + var txt = "requestData[" + pitems + "].goods[" + item + "].selected"; |
2163 | + this.setData({[txt]:1}); | ||
2164 | + th.clear_clicking(); | ||
2165 | + return false; | ||
2099 | } | 2166 | } |
2100 | 2167 | ||
2101 | 2168 | ||
@@ -2113,6 +2180,7 @@ Page({ | @@ -2113,6 +2180,7 @@ Page({ | ||
2113 | title: '提示', | 2180 | title: '提示', |
2114 | content: '服务卡项目不能和商品一起选择' | 2181 | content: '服务卡项目不能和商品一起选择' |
2115 | }); | 2182 | }); |
2183 | + th.clear_clicking(); | ||
2116 | return false; | 2184 | return false; |
2117 | } | 2185 | } |
2118 | } | 2186 | } |
@@ -2142,112 +2210,120 @@ Page({ | @@ -2142,112 +2210,120 @@ Page({ | ||
2142 | title: '提示', | 2210 | title: '提示', |
2143 | content: '同一门店自提和物流的商品不能同时结算' | 2211 | content: '同一门店自提和物流的商品不能同时结算' |
2144 | }); | 2212 | }); |
2145 | - } else { | ||
2146 | - var txt = "requestData[" + pitems + "].goods[" + item + "].selected"; | ||
2147 | - var gd_info = a; | 2213 | + th.clear_clicking(); |
2214 | + return false; | ||
2215 | + } | ||
2148 | 2216 | ||
2149 | - var erpwareid = gd_info.erpwareid; | ||
2150 | 2217 | ||
2151 | - //-- 如果是选中的时候 -- | ||
2152 | - if (!a.selected) { | 2218 | + var txt = "requestData[" + pitems + "].goods[" + item + "].selected"; |
2219 | + var gd_info = a; | ||
2153 | 2220 | ||
2154 | - th.data.pitems=pitems; | 2221 | + var erpwareid = gd_info.erpwareid; |
2155 | 2222 | ||
2156 | - //判断是不是有促销活动 | ||
2157 | - var act = await getApp().get_has_cx_act(gd_info.goods_id); | ||
2158 | - //-- 专门来设置商品订购数量 -- | ||
2159 | - th.click_set_limit(gd_info, pitems, item, act) | ||
2160 | - if (th.data.sales_rules >= 2 && !gd_info.whsle_id && [1, 2, 4, 6, 8, 9].indexOf(gd_info.prom_type) == -1) { | 2223 | + //-- 如果是选中的时候 -- |
2224 | + if (!a.selected) { | ||
2161 | 2225 | ||
2162 | - var ob = {}; | ||
2163 | - await th.check_down_line_next(gd_info, pitems, item, erpwareid, function (res) { | ||
2164 | - ob = res; | 2226 | + th.data.pitems=pitems; |
2227 | + | ||
2228 | + //判断是不是有促销活动 | ||
2229 | + var act = getApp().get_has_cx_act2(gd_info.goodsActinfo); | ||
2230 | + //-- 专门来设置商品订购数量 -- | ||
2231 | + th.click_set_limit(gd_info, pitems, item, act) | ||
2232 | + if (th.data.sales_rules >= 2 && !gd_info.whsle_id && [1, 2, 4, 6, 8, 9].indexOf(gd_info.prom_type) == -1) { | ||
2233 | + | ||
2234 | + var ob = {}; | ||
2235 | + await th.check_down_line_next(gd_info, pitems, item, erpwareid, function (res) { | ||
2236 | + ob = res; | ||
2237 | + }); | ||
2238 | + if (ob.code == -1) { | ||
2239 | + wx.showToast({ | ||
2240 | + title: '购买数量超出商品库存', | ||
2241 | + icon: 'none', | ||
2165 | }); | 2242 | }); |
2166 | - if (ob.code == -1) { | 2243 | + th.clear_clicking(); |
2244 | + return false; | ||
2245 | + } | ||
2167 | 2246 | ||
2247 | + if (th.data.sales_rules == 3) { | ||
2248 | + var goods_id = gd_info.goods_id; | ||
2249 | + var num = 0; | ||
2250 | + | ||
2251 | + for (let i = 0; i < th.data.requestData.length; i++) { | ||
2252 | + if (pitems == i) continue; | ||
2253 | + var it = th.data.requestData[i].goods.find((e) => { | ||
2254 | + return e.goods_id == goods_id; | ||
2255 | + }) | ||
2256 | + if (it && it.selected) num += it.goods_num | ||
2257 | + } | ||
2258 | + | ||
2259 | + if (num > ob.CanOutQty) { | ||
2168 | wx.showToast({ | 2260 | wx.showToast({ |
2169 | title: '购买数量超出商品库存', | 2261 | title: '购买数量超出商品库存', |
2170 | icon: 'none', | 2262 | icon: 'none', |
2171 | }); | 2263 | }); |
2172 | - | 2264 | + th.clear_clicking(); |
2173 | return false; | 2265 | return false; |
2174 | - } else { | ||
2175 | - if (th.data.sales_rules == 3) { | ||
2176 | - var goods_id = gd_info.goods_id; | ||
2177 | - var num = 0; | ||
2178 | - | ||
2179 | - for (let i = 0; i < th.data.requestData.length; i++) { | ||
2180 | - if (pitems == i) continue; | ||
2181 | - var it = th.data.requestData[i].goods.find((e) => { | ||
2182 | - return e.goods_id == goods_id; | ||
2183 | - }) | ||
2184 | - if (it && it.selected) num += it.goods_num | ||
2185 | - } | ||
2186 | - | ||
2187 | - if (num > ob.CanOutQty) { | ||
2188 | - wx.showToast({ | ||
2189 | - title: '购买数量超出商品库存', | ||
2190 | - icon: 'none', | ||
2191 | - }); | ||
2192 | - | ||
2193 | - return false; | ||
2194 | - } | ||
2195 | - } | ||
2196 | } | 2266 | } |
2197 | - | ||
2198 | } | 2267 | } |
2268 | + | ||
2199 | } | 2269 | } |
2270 | + } | ||
2200 | 2271 | ||
2201 | 2272 | ||
2202 | - let pro_off = false | ||
2203 | - //判断多店优惠促销次数控制 | ||
2204 | - if (th.data.requestData.length > 1) { | ||
2205 | - if (a.prom_type == 3 && !a.selected) { | ||
2206 | - //pro_off = await th.multiple_stores_pro(pitems, item) | ||
2207 | - } | 2273 | + let pro_off = false |
2274 | + //判断多店优惠促销次数控制 | ||
2275 | + if (th.data.requestData.length > 1) { | ||
2276 | + if (a.prom_type == 3 && !a.selected) { | ||
2277 | + //pro_off = await th.multiple_stores_pro(pitems, item) | ||
2208 | } | 2278 | } |
2279 | + } | ||
2280 | + | ||
2281 | + if (pro_off) { | ||
2282 | + wx.showToast({ | ||
2283 | + title: '已超出优惠促销次数', | ||
2284 | + icon: 'none', | ||
2285 | + }); | ||
2286 | + th.clear_clicking(); | ||
2287 | + return false; | ||
2288 | + } | ||
2289 | + | ||
2290 | + var txt0 = "requestData[" + pitems + "].show_can_cx"; | ||
2291 | + e.setData({ | ||
2292 | + [txt0]: {}, | ||
2293 | + }); | ||
2294 | + th.data.requestData[pitems].show_can_cx=null; | ||
2209 | 2295 | ||
2210 | - if (pro_off) { | 2296 | + //-- 选择了什么商品,就用什么商品来判断 -- |
2297 | + var sele_arr = {}; | ||
2298 | + sele_arr[item] = !a.selected; | ||
2299 | + //回调判断活动有没有冲突 | ||
2300 | + this.cx_check_ok(pitems, sele_arr, function (the_res) { | ||
2301 | + if (the_res.code == 0) { | ||
2302 | + th.setData({ | ||
2303 | + [txt]: Number(!a.selected), | ||
2304 | + }); | ||
2305 | + //要先处理了,再来判断要不要显示凑单 | ||
2306 | + th.doCheckAll(async function () { | ||
2307 | + th.data.duo_zp_num_arr={}; | ||
2308 | + //判断商品是不是优惠活动 | ||
2309 | + for (var i in e.data.requestData) { | ||
2310 | + await e.check_prom_activity(i); | ||
2311 | + } | ||
2312 | + //清理一下点击防止重复点击 | ||
2313 | + th.clear_clicking(); | ||
2314 | + | ||
2315 | + }); | ||
2316 | + } else { | ||
2211 | wx.showToast({ | 2317 | wx.showToast({ |
2212 | - title: '已超出优惠促销次数', | 2318 | + title: the_res.msg, |
2213 | icon: 'none', | 2319 | icon: 'none', |
2214 | }); | 2320 | }); |
2215 | - return false; | ||
2216 | } | 2321 | } |
2322 | + }) | ||
2217 | 2323 | ||
2218 | - var txt0 = "requestData[" + pitems + "].show_can_cx"; | ||
2219 | - e.setData({ | ||
2220 | - [txt0]: {}, | ||
2221 | - }); | ||
2222 | - | ||
2223 | - //-- 选择了什么商品,就用什么商品来判断 -- | ||
2224 | - var sele_arr = {}; | ||
2225 | - sele_arr[item] = !a.selected; | ||
2226 | - //回调判断活动有没有冲突 | ||
2227 | - this.cx_check_ok(pitems, sele_arr, function (the_res) { | ||
2228 | - if (the_res.code == 0) { | ||
2229 | - th.setData({ | ||
2230 | - [txt]: Number(!a.selected), | ||
2231 | - }); | ||
2232 | - //要先处理了,再来判断要不要显示凑单 | ||
2233 | - th.doCheckAll(async function () { | ||
2234 | - th.data.duo_zp_num_arr={}; | ||
2235 | - //判断商品是不是优惠活动 | ||
2236 | - for (var i in e.data.requestData) { | ||
2237 | - await e.check_prom_activity(i); | ||
2238 | - } | 2324 | + }, |
2239 | 2325 | ||
2240 | - }); | ||
2241 | - } else { | ||
2242 | - wx.showToast({ | ||
2243 | - title: the_res.msg, | ||
2244 | - icon: 'none', | ||
2245 | - }); | ||
2246 | - } | ||
2247 | - }) | ||
2248 | 2326 | ||
2249 | - } | ||
2250 | - }, | ||
2251 | 2327 | ||
2252 | //------门店全选按钮,要判断是否门店的匹配方式一致--------- | 2328 | //------门店全选按钮,要判断是否门店的匹配方式一致--------- |
2253 | check_th_all_item_ser: async function (ele) { | 2329 | check_th_all_item_ser: async function (ele) { |
@@ -2410,6 +2486,29 @@ Page({ | @@ -2410,6 +2486,29 @@ Page({ | ||
2410 | for (var a = 0; a < car.length; a++) { | 2486 | for (var a = 0; a < car.length; a++) { |
2411 | //-- 把活动组装进去 --- | 2487 | //-- 把活动组装进去 --- |
2412 | var show_can_cx = rd_arr[a]; | 2488 | var show_can_cx = rd_arr[a]; |
2489 | + //-- 把活动组装进去 --- | ||
2490 | + let show_can_cx1 = ut.deep_cp(rd_arr[a]); | ||
2491 | + //前端处理渲染的时,要处理一些不需要的字段属性 | ||
2492 | + if(show_can_cx1){ | ||
2493 | + for (const key in show_can_cx1) { | ||
2494 | + let element = show_can_cx1[key]; | ||
2495 | + if(element.cur_act ){ | ||
2496 | + delete element.cur_act; | ||
2497 | + } | ||
2498 | + if(element.ch_map){ | ||
2499 | + delete element.ch_map; | ||
2500 | + } | ||
2501 | + if(element.act_arr && element.act_arr.length>0){ | ||
2502 | + for (var ij = 0; ij < element.act_arr.length; ij++) { | ||
2503 | + var act_ite = element.act_arr[ij]; | ||
2504 | + delete act_ite.goods; | ||
2505 | + delete act_ite.act; | ||
2506 | + delete act_ite.key; | ||
2507 | + } | ||
2508 | + } | ||
2509 | + } | ||
2510 | + } | ||
2511 | + | ||
2413 | 2512 | ||
2414 | car[a].zh_map = null; | 2513 | car[a].zh_map = null; |
2415 | car[a].ladder_map = null; | 2514 | car[a].ladder_map = null; |
@@ -2514,7 +2613,9 @@ Page({ | @@ -2514,7 +2613,9 @@ Page({ | ||
2514 | } else if (item[c].prom_type == 10) { | 2613 | } else if (item[c].prom_type == 10) { |
2515 | ladder_calc.add_ladder_prom(car, a, obj); | 2614 | ladder_calc.add_ladder_prom(car, a, obj); |
2516 | } else { | 2615 | } else { |
2616 | + console.log("索引:"+c+",数量:"+item[c].goods_num+",单价:"+item[c].goods_price+",合计:"+item[c].goods_num * item[c].goods_price+",商品:"+item[c].goods_name); | ||
2517 | tfeel += item[c].goods_num * item[c].goods_price; | 2617 | tfeel += item[c].goods_num * item[c].goods_price; |
2618 | + console.log("累计:"+tfeel); | ||
2518 | } | 2619 | } |
2519 | t_num += item[c].goods_num; | 2620 | t_num += item[c].goods_num; |
2520 | } | 2621 | } |
@@ -2546,11 +2647,11 @@ Page({ | @@ -2546,11 +2647,11 @@ Page({ | ||
2546 | [txt]: Number(is_s_sele) | 2647 | [txt]: Number(is_s_sele) |
2547 | }); | 2648 | }); |
2548 | 2649 | ||
2549 | - var txt1 = "requestData[" + a + "].show_can_cx"; | ||
2550 | - var txt_g = "requestData[" + a + "].goods"; | 2650 | + var txt1 = "requestData[" + a + "].show_can_cx1"; |
2651 | + //-- 赋值不渲染 ,只后台计算 -- | ||
2652 | + th.data.requestData[a].show_can_cx=show_can_cx; | ||
2551 | th.setData({ | 2653 | th.setData({ |
2552 | - [txt1]: show_can_cx, | ||
2553 | - [txt_g]:item | 2654 | + [txt1]: show_can_cx1, |
2554 | }); | 2655 | }); |
2555 | 2656 | ||
2556 | //-- var et={show_can_cx:show_can_cx}; | 2657 | //-- var et={show_can_cx:show_can_cx}; |
@@ -2859,7 +2960,7 @@ Page({ | @@ -2859,7 +2960,7 @@ Page({ | ||
2859 | //-- 这个函数在计算的时候,要包含限购的那一部分 -- | 2960 | //-- 这个函数在计算的时候,要包含限购的那一部分 -- |
2860 | async normal_check(t, item, pitem, store_count, limit, goodsinfo, wareIds) { | 2961 | async normal_check(t, item, pitem, store_count, limit, goodsinfo, wareIds) { |
2861 | 2962 | ||
2862 | - var cx_arr = await getApp().get_has_cx_act(goodsinfo.goods_id); | 2963 | + var cx_arr = getApp().get_has_cx_act2(goodsinfo.goodsActinfo); |
2863 | 2964 | ||
2864 | var th = this; | 2965 | var th = this; |
2865 | // getApp().my_warnning('购买数量超出商品库存', 0, th); | 2966 | // getApp().my_warnning('购买数量超出商品库存', 0, th); |
@@ -3386,6 +3487,12 @@ Page({ | @@ -3386,6 +3487,12 @@ Page({ | ||
3386 | this.getCardList(); | 3487 | this.getCardList(); |
3387 | }, | 3488 | }, |
3388 | 3489 | ||
3490 | + | ||
3491 | + clear_checkouting(){ | ||
3492 | + wx.hideLoading(); | ||
3493 | + this.data.checkouting=0; | ||
3494 | + }, | ||
3495 | + | ||
3389 | //--------------去结算------------ | 3496 | //--------------去结算------------ |
3390 | async checkout() { | 3497 | async checkout() { |
3391 | if (getApp().is_sp_hao()) { | 3498 | if (getApp().is_sp_hao()) { |
@@ -3397,13 +3504,24 @@ Page({ | @@ -3397,13 +3504,24 @@ Page({ | ||
3397 | return false; | 3504 | return false; |
3398 | } | 3505 | } |
3399 | 3506 | ||
3400 | - if (!this.data.total_num || this.data.total_num <= 0) return false; | 3507 | + if (!this.data.total_num || this.data.total_num <= 0) { |
3508 | + wx.showToast({ | ||
3509 | + title: "请选择商品", | ||
3510 | + icon: 'none', | ||
3511 | + duration: 2000 | ||
3512 | + }); | ||
3513 | + return false; | ||
3514 | + } | ||
3401 | if (!this.data.is_load) return false; | 3515 | if (!this.data.is_load) return false; |
3402 | if (this.data.up_dating) { | 3516 | if (this.data.up_dating) { |
3403 | wx.showLoading({ | 3517 | wx.showLoading({ |
3404 | title: "计算中" | 3518 | title: "计算中" |
3405 | }) | 3519 | }) |
3406 | } | 3520 | } |
3521 | + | ||
3522 | + if(this.data.checkouting) return false; | ||
3523 | + this.data.checkouting=1; | ||
3524 | + | ||
3407 | var garr = this.data.requestData; | 3525 | var garr = this.data.requestData; |
3408 | var check_is_goods_selected = 0; | 3526 | var check_is_goods_selected = 0; |
3409 | 3527 | ||
@@ -3498,15 +3616,14 @@ Page({ | @@ -3498,15 +3616,14 @@ Page({ | ||
3498 | if(yh_by_map[ky]){ | 3616 | if(yh_by_map[ky]){ |
3499 | ky_n+=yh_by_map[ky]; | 3617 | ky_n+=yh_by_map[ky]; |
3500 | } | 3618 | } |
3501 | - | ||
3502 | //-- 判断优惠促销活动的商品的限购,can_yh 表示商品满足优惠促销的条件 -- | 3619 | //-- 判断优惠促销活动的商品的限购,can_yh 表示商品满足优惠促销的条件 -- |
3503 | if(i_arr[j].prom_type==3 && fd1.act.goodslimit>0 && i_arr[j].can_yh ){ | 3620 | if(i_arr[j].prom_type==3 && fd1.act.goodslimit>0 && i_arr[j].can_yh ){ |
3504 | - var p_can_by=fd1.act.goodslimit-fd1.act.goodslimited; | ||
3505 | - if(i_arr[j].goods_num+ky_n>p_can_by){ | ||
3506 | - getApp().confirmBox(i_arr[j].goods_name + "超出活动限购数量"+fd1.act.goodslimit+"件"); | ||
3507 | - wx.hideLoading(); | ||
3508 | - return false; | ||
3509 | - } | 3621 | + var p_can_by=fd1.act.goodslimit-fd1.act.goodslimited; |
3622 | + if(i_arr[j].goods_num+ky_n>p_can_by){ | ||
3623 | + getApp().confirmBox(i_arr[j].goods_name + "超出活动限购数量"+fd1.act.goodslimit+"件"); | ||
3624 | + wx.hideLoading(); | ||
3625 | + return false; | ||
3626 | + } | ||
3510 | } | 3627 | } |
3511 | //-- 把购物数量记录到map表中 -- | 3628 | //-- 把购物数量记录到map表中 -- |
3512 | if(!yh_by_map[ky]) yh_by_map[ky]=0; | 3629 | if(!yh_by_map[ky]) yh_by_map[ky]=0; |
@@ -3516,10 +3633,8 @@ Page({ | @@ -3516,10 +3633,8 @@ Page({ | ||
3516 | } | 3633 | } |
3517 | 3634 | ||
3518 | 3635 | ||
3519 | - | ||
3520 | - | ||
3521 | - | ||
3522 | if (i_arr[j].prom_type == 7 && i_arr[j].act && (i_arr[j].act.buy_limit>0 || i_arr[j].act.zh_num>0) ) { | 3636 | if (i_arr[j].prom_type == 7 && i_arr[j].act && (i_arr[j].act.buy_limit>0 || i_arr[j].act.zh_num>0) ) { |
3637 | + | ||
3523 | let userbuynum = await this.getUserBuyPromNum(i_arr[j].prom_id); | 3638 | let userbuynum = await this.getUserBuyPromNum(i_arr[j].prom_id); |
3524 | 3639 | ||
3525 | if(!zh_buyed_m[i_arr[j].prom_id]) zh_buyed_m[i_arr[j].prom_id]=userbuynum; | 3640 | if(!zh_buyed_m[i_arr[j].prom_id]) zh_buyed_m[i_arr[j].prom_id]=userbuynum; |
@@ -3537,10 +3652,10 @@ Page({ | @@ -3537,10 +3652,10 @@ Page({ | ||
3537 | checkArr7.push(i_arr[j]) | 3652 | checkArr7.push(i_arr[j]) |
3538 | }else{ | 3653 | }else{ |
3539 | if (zh_all_ck[i_arr[j].prom_id]) { | 3654 | if (zh_all_ck[i_arr[j].prom_id]) { |
3540 | - //相同门店只记录一单 | 3655 | + //相同门店只记录一单 |
3541 | if(zh_all_ck[i_arr[j].prom_id].indexOf(i)==-1) zh_all_ck[i_arr[j].prom_id].push(i); | 3656 | if(zh_all_ck[i_arr[j].prom_id].indexOf(i)==-1) zh_all_ck[i_arr[j].prom_id].push(i); |
3542 | } else { | 3657 | } else { |
3543 | - zh_all_ck[i_arr[j].prom_id] = [i]; | 3658 | + zh_all_ck[i_arr[j].prom_id] = [i]; |
3544 | } | 3659 | } |
3545 | 3660 | ||
3546 | } | 3661 | } |
@@ -3548,7 +3663,7 @@ Page({ | @@ -3548,7 +3663,7 @@ Page({ | ||
3548 | //-- 优惠活动次数限制,相同门店的相同prom_id只能算一次 -- | 3663 | //-- 优惠活动次数限制,相同门店的相同prom_id只能算一次 -- |
3549 | if (i_arr[j].prom_type == 3) { | 3664 | if (i_arr[j].prom_type == 3) { |
3550 | if (checkObj3[i_arr[j].prom_id]) { | 3665 | if (checkObj3[i_arr[j].prom_id]) { |
3551 | - if(checkObj3[i_arr[j].prom_id].indexOf(i)==-1) checkObj3[i_arr[j].prom_id].push(i); | 3666 | + if(checkObj3[i_arr[j].prom_id].indexOf(i)==-1) checkObj3[i_arr[j].prom_id].push(i); |
3552 | } else { | 3667 | } else { |
3553 | checkObj3[i_arr[j].prom_id] = [i]; | 3668 | checkObj3[i_arr[j].prom_id] = [i]; |
3554 | } | 3669 | } |
@@ -3556,11 +3671,11 @@ Page({ | @@ -3556,11 +3671,11 @@ Page({ | ||
3556 | 3671 | ||
3557 | //如果是普通购买的时候。 | 3672 | //如果是普通购买的时候。 |
3558 | if(i_arr[j].is_integral_normal || i_arr[j].is_pd_normal ){ | 3673 | if(i_arr[j].is_integral_normal || i_arr[j].is_pd_normal ){ |
3559 | - //-- 四大促销 -- | ||
3560 | - if([3,5,7,10].indexOf(i_arr[j].prom_tyoe)==-1){ | ||
3561 | - i_arr[j].prom_id=0; | ||
3562 | - i_arr[j].prom_type=0; | ||
3563 | - } | 3674 | + //-- 四大促销 -- |
3675 | + if([3,5,7,10].indexOf(i_arr[j].prom_tyoe)==-1){ | ||
3676 | + i_arr[j].prom_id=0; | ||
3677 | + i_arr[j].prom_type=0; | ||
3678 | + } | ||
3564 | } | 3679 | } |
3565 | 3680 | ||
3566 | //map 的key是不会重复,会覆盖,, | 3681 | //map 的key是不会重复,会覆盖,, |
@@ -3589,25 +3704,20 @@ Page({ | @@ -3589,25 +3704,20 @@ Page({ | ||
3589 | //glist += i_arr[j].goods_id + ","; | 3704 | //glist += i_arr[j].goods_id + ","; |
3590 | 3705 | ||
3591 | if(!i_arr[j].is_gift){ | 3706 | if(!i_arr[j].is_gift){ |
3592 | - var et= {"prom_type":i_arr[j].prom_type,"prom_id":i_arr[j].prom_id,"goods_id":i_arr[j].goods_id}; | ||
3593 | - glist.push(et); | 3707 | + var et= {"prom_type":i_arr[j].prom_type,"prom_id":i_arr[j].prom_id,"goods_id":i_arr[j].goods_id}; |
3708 | + glist.push(et); | ||
3594 | } | 3709 | } |
3595 | ab = 1; | 3710 | ab = 1; |
3596 | 3711 | ||
3597 | //-- 获取促销活动是不是有参与 -- | 3712 | //-- 获取促销活动是不是有参与 -- |
3598 | - var act = await getApp().get_has_cx_act(i_arr[j].goods_id); | 3713 | + var act = getApp().get_has_cx_act2(i_arr[j].goodsActinfo); |
3599 | //-- 判断商品的起订数量 -- | 3714 | //-- 判断商品的起订数量 -- |
3600 | var mo_num = getApp().get_limit_qty(i_arr[j], act.length); | 3715 | var mo_num = getApp().get_limit_qty(i_arr[j], act.length); |
3601 | var steep = getApp().get_limit_qty(i_arr[j], act.length, 1); | 3716 | var steep = getApp().get_limit_qty(i_arr[j], act.length, 1); |
3602 | var py_type = parseInt(i_arr[j].prom_type + ''); | 3717 | var py_type = parseInt(i_arr[j].prom_type + ''); |
3603 | 3718 | ||
3604 | - //商品只查一次。看一下有没有 | ||
3605 | - var gd = null; | ||
3606 | - //获取商品信息,包含线下商品ID,指定门店销售的信息 | ||
3607 | - await getApp().request.promiseGet("/api/weshop/goods/get/" + oo.stoid + "/" + i_arr[j].goods_id, {}).then(res => { | ||
3608 | - if (res.data.code == 0) gd = res.data.data; | ||
3609 | - }) | ||
3610 | - | 3719 | + //-- 商品只查一次。看一下有没有,门店之前第一次就赋值了 -- |
3720 | + var gd = i_arr[j]; | ||
3611 | //判断秒杀的指定门店和团购的指定门店 | 3721 | //判断秒杀的指定门店和团购的指定门店 |
3612 | if([1,2].indexOf(py_type)>-1 && i_arr[j].prom && i_arr[j].prom.pick_up_lists){ | 3722 | if([1,2].indexOf(py_type)>-1 && i_arr[j].prom && i_arr[j].prom.pick_up_lists){ |
3613 | var idx0=i_arr[j].prom.pick_up_lists.findIndex(function (e){ | 3723 | var idx0=i_arr[j].prom.pick_up_lists.findIndex(function (e){ |
@@ -3620,7 +3730,7 @@ Page({ | @@ -3620,7 +3730,7 @@ Page({ | ||
3620 | if(py_type==2) act_type='团购'; | 3730 | if(py_type==2) act_type='团购'; |
3621 | 3731 | ||
3622 | getApp().confirmBox(i_arr[j].goods_name + act_type+"活动的门店不可售"); | 3732 | getApp().confirmBox(i_arr[j].goods_name + act_type+"活动的门店不可售"); |
3623 | - wx.hideLoading(); | 3733 | + th.clear_checkouting(); |
3624 | return false; | 3734 | return false; |
3625 | } | 3735 | } |
3626 | } | 3736 | } |
@@ -3628,19 +3738,19 @@ Page({ | @@ -3628,19 +3738,19 @@ Page({ | ||
3628 | if ([0, 3, 5, 7, 10].indexOf(py_type) > -1) { | 3738 | if ([0, 3, 5, 7, 10].indexOf(py_type) > -1) { |
3629 | //如果是指定门店,就要判断 | 3739 | //如果是指定门店,就要判断 |
3630 | if(gd.pick_group_ids){ | 3740 | if(gd.pick_group_ids){ |
3631 | - var idx0=gd.pick_up_lists.findIndex(function (e){ | ||
3632 | - return e.pickup_id==i_arr[j].pick_id; | ||
3633 | - }) | ||
3634 | - if(idx0<0){ | ||
3635 | - getApp().confirmBox(i_arr[j].goods_name + "的门店不可售"); | ||
3636 | - wx.hideLoading(); | ||
3637 | - return false; | ||
3638 | - } | 3741 | + var idx0=gd.pick_up_lists.findIndex(function (e){ |
3742 | + return e.pickup_id==i_arr[j].pick_id; | ||
3743 | + }) | ||
3744 | + if(idx0<0){ | ||
3745 | + getApp().confirmBox(i_arr[j].goods_name + "的门店不可售"); | ||
3746 | + th.clear_checkouting(); | ||
3747 | + return false; | ||
3748 | + } | ||
3639 | } | 3749 | } |
3640 | 3750 | ||
3641 | if (mo_num > i_arr[j].goods_num) { | 3751 | if (mo_num > i_arr[j].goods_num) { |
3642 | getApp().confirmBox(i_arr[j].goods_name + "的未达到起订数量"); | 3752 | getApp().confirmBox(i_arr[j].goods_name + "的未达到起订数量"); |
3643 | - wx.hideLoading(); | 3753 | + th.clear_checkouting(); |
3644 | return false; | 3754 | return false; |
3645 | } | 3755 | } |
3646 | if (steep > 1 && (i_arr[j].goods_num - mo_num) % steep != 0) { | 3756 | if (steep > 1 && (i_arr[j].goods_num - mo_num) % steep != 0) { |
@@ -3655,7 +3765,7 @@ Page({ | @@ -3655,7 +3765,7 @@ Page({ | ||
3655 | 3765 | ||
3656 | th.postCardList(e, j, i); | 3766 | th.postCardList(e, j, i); |
3657 | 3767 | ||
3658 | - wx.hideLoading(); | 3768 | + th.clear_checkouting(); |
3659 | return false; | 3769 | return false; |
3660 | } | 3770 | } |
3661 | 3771 | ||
@@ -3672,7 +3782,7 @@ Page({ | @@ -3672,7 +3782,7 @@ Page({ | ||
3672 | }); | 3782 | }); |
3673 | if (ob.code == -1) { | 3783 | if (ob.code == -1) { |
3674 | t.my_warnning(gd.goods_name + "门店库存不足", 0, th); | 3784 | t.my_warnning(gd.goods_name + "门店库存不足", 0, th); |
3675 | - wx.hideLoading(); | 3785 | + th.clear_checkouting(); |
3676 | return false; | 3786 | return false; |
3677 | } | 3787 | } |
3678 | 3788 | ||
@@ -3685,7 +3795,7 @@ Page({ | @@ -3685,7 +3795,7 @@ Page({ | ||
3685 | if (res.data.code == 0) { | 3795 | if (res.data.code == 0) { |
3686 | if (!res.data.data.promGoodsLists) { | 3796 | if (!res.data.data.promGoodsLists) { |
3687 | t.my_warnning(i_arr[j].goods_name + "优惠活动已经过期", 0, th); | 3797 | t.my_warnning(i_arr[j].goods_name + "优惠活动已经过期", 0, th); |
3688 | - wx.hideLoading(); | 3798 | + th.clear_checkouting(); |
3689 | is_ok = 0; | 3799 | is_ok = 0; |
3690 | } | 3800 | } |
3691 | } | 3801 | } |
@@ -3698,20 +3808,21 @@ Page({ | @@ -3698,20 +3808,21 @@ Page({ | ||
3698 | 3808 | ||
3699 | } else { | 3809 | } else { |
3700 | if (i_arr[j].is_gift == 1) continue; | 3810 | if (i_arr[j].is_gift == 1) continue; |
3701 | - rq.put("/api/weshop/cart/update", { | ||
3702 | - data: { | ||
3703 | - id: i_arr[j].id, | ||
3704 | - selected: 0, | ||
3705 | - store_id: oo.stoid | ||
3706 | - }, | ||
3707 | - success: function (ee) { | ||
3708 | - console.log(ee); | ||
3709 | - } | ||
3710 | - }); | 3811 | + // rq.put("/api/weshop/cart/update", { |
3812 | + // data: { | ||
3813 | + // id: i_arr[j].id, | ||
3814 | + // selected: 0, | ||
3815 | + // store_id: oo.stoid | ||
3816 | + // }, | ||
3817 | + // success: function (ee) { | ||
3818 | + // console.log(ee); | ||
3819 | + // } | ||
3820 | + // }); | ||
3711 | } | 3821 | } |
3712 | } | 3822 | } |
3713 | } | 3823 | } |
3714 | 3824 | ||
3825 | + | ||
3715 | console.log(checkObj3); | 3826 | console.log(checkObj3); |
3716 | let checkObj3_off = false | 3827 | let checkObj3_off = false |
3717 | 3828 | ||
@@ -3761,7 +3872,7 @@ Page({ | @@ -3761,7 +3872,7 @@ Page({ | ||
3761 | 3872 | ||
3762 | if (checkObj3_off) { | 3873 | if (checkObj3_off) { |
3763 | t.my_warnning("已超出优惠促销次数", 0, th); | 3874 | t.my_warnning("已超出优惠促销次数", 0, th); |
3764 | - wx.hideLoading(); | 3875 | + th.clear_checkouting(); |
3765 | return false | 3876 | return false |
3766 | } | 3877 | } |
3767 | 3878 | ||
@@ -3770,23 +3881,23 @@ Page({ | @@ -3770,23 +3881,23 @@ Page({ | ||
3770 | let zh_ck_arr = Object.keys(zh_limit_m); | 3881 | let zh_ck_arr = Object.keys(zh_limit_m); |
3771 | if(zh_ck_arr && zh_ck_arr.length ){ | 3882 | if(zh_ck_arr && zh_ck_arr.length ){ |
3772 | for (let xg = 0; xg < zh_ck_arr.length; xg++) { | 3883 | for (let xg = 0; xg < zh_ck_arr.length; xg++) { |
3773 | - var ky=zh_ck_arr[xg]; | ||
3774 | - var zh_buyed=zh_buyed_m[ky]?zh_buyed_m[ky]:0; | ||
3775 | - var zh_limit=zh_limit_m[ky]?zh_limit_m[ky]:0; | ||
3776 | - var zh_all=zh_all_ck[ky]?zh_all_ck[ky].length:0; | ||
3777 | - if(zh_limit<=0) continue; | ||
3778 | - | ||
3779 | - if(zh_all+zh_buyed>zh_limit){ | ||
3780 | - zh_off=true; | ||
3781 | - break; | ||
3782 | - } | 3884 | + var ky=zh_ck_arr[xg]; |
3885 | + var zh_buyed=zh_buyed_m[ky]?zh_buyed_m[ky]:0; | ||
3886 | + var zh_limit=zh_limit_m[ky]?zh_limit_m[ky]:0; | ||
3887 | + var zh_all=zh_all_ck[ky]?zh_all_ck[ky].length:0; | ||
3888 | + if(zh_limit<=0) continue; | ||
3889 | + | ||
3890 | + if(zh_all+zh_buyed>zh_limit){ | ||
3891 | + zh_off=true; | ||
3892 | + break; | ||
3893 | + } | ||
3783 | } | 3894 | } |
3784 | } | 3895 | } |
3785 | 3896 | ||
3786 | if (zh_off) { | 3897 | if (zh_off) { |
3787 | - t.my_warnning("已超出组合购优惠次数", 0, th); | ||
3788 | - wx.hideLoading(); | ||
3789 | - return false | 3898 | + t.my_warnning("已超出组合购优惠次数", 0, th); |
3899 | + th.clear_checkouting(); | ||
3900 | + return false | ||
3790 | } | 3901 | } |
3791 | 3902 | ||
3792 | 3903 | ||
@@ -3839,7 +3950,7 @@ Page({ | @@ -3839,7 +3950,7 @@ Page({ | ||
3839 | }) | 3950 | }) |
3840 | if (ab == 0) { | 3951 | if (ab == 0) { |
3841 | t.my_warnning("未选择商品", 0, th); | 3952 | t.my_warnning("未选择商品", 0, th); |
3842 | - wx.hideLoading(); | 3953 | + th.clear_checkouting(); |
3843 | return false; | 3954 | return false; |
3844 | } | 3955 | } |
3845 | 3956 | ||
@@ -3848,7 +3959,7 @@ Page({ | @@ -3848,7 +3959,7 @@ Page({ | ||
3848 | 3959 | ||
3849 | 3960 | ||
3850 | } else if (res.cancel) { | 3961 | } else if (res.cancel) { |
3851 | - wx.hideLoading(); | 3962 | + th.clear_checkouting(); |
3852 | console.log('用户点击取消') | 3963 | console.log('用户点击取消') |
3853 | } | 3964 | } |
3854 | } | 3965 | } |
@@ -3871,7 +3982,7 @@ Page({ | @@ -3871,7 +3982,7 @@ Page({ | ||
3871 | }) | 3982 | }) |
3872 | if (ab == 0) { | 3983 | if (ab == 0) { |
3873 | t.my_warnning("未选择商品", 0, th); | 3984 | t.my_warnning("未选择商品", 0, th); |
3874 | - wx.hideLoading(); | 3985 | + th.clear_checkouting(); |
3875 | return false; | 3986 | return false; |
3876 | } | 3987 | } |
3877 | 3988 | ||
@@ -3903,7 +4014,7 @@ Page({ | @@ -3903,7 +4014,7 @@ Page({ | ||
3903 | }) | 4014 | }) |
3904 | if(idx0<0){ | 4015 | if(idx0<0){ |
3905 | getApp().confirmBox(i_arr[j].service_name + "秒杀活动的门店不可售"); | 4016 | getApp().confirmBox(i_arr[j].service_name + "秒杀活动的门店不可售"); |
3906 | - wx.hideLoading(); | 4017 | + th.clear_checkouting(); |
3907 | return false; | 4018 | return false; |
3908 | } | 4019 | } |
3909 | } | 4020 | } |
@@ -3923,8 +4034,6 @@ Page({ | @@ -3923,8 +4034,6 @@ Page({ | ||
3923 | } | 4034 | } |
3924 | }) | 4035 | }) |
3925 | 4036 | ||
3926 | - | ||
3927 | - wx.hideLoading(); | ||
3928 | getApp().goto("/packageA/pages/cart2_ser/cart2_ser?is_cart=1"); | 4037 | getApp().goto("/packageA/pages/cart2_ser/cart2_ser?is_cart=1"); |
3929 | } | 4038 | } |
3930 | }, | 4039 | }, |
@@ -3933,6 +4042,7 @@ Page({ | @@ -3933,6 +4042,7 @@ Page({ | ||
3933 | cart_buy_next(glist,map,g_arr,checkArr7){ | 4042 | cart_buy_next(glist,map,g_arr,checkArr7){ |
3934 | var th=this; | 4043 | var th=this; |
3935 | var map_limit = new Map(); //使用map值键进行存储限购 | 4044 | var map_limit = new Map(); //使用map值键进行存储限购 |
4045 | + var up_cart_data=[]; | ||
3936 | //--取一下商品的限购 以及活动的限购,redis数量-- | 4046 | //--取一下商品的限购 以及活动的限购,redis数量-- |
3937 | getApp().request.promisePost("/api/weshop/goods/listGoodsListNumNew", { | 4047 | getApp().request.promisePost("/api/weshop/goods/listGoodsListNumNew", { |
3938 | is_json:1, | 4048 | is_json:1, |
@@ -3941,182 +4051,166 @@ Page({ | @@ -3941,182 +4051,166 @@ Page({ | ||
3941 | store_id: oo.stoid | 4051 | store_id: oo.stoid |
3942 | } | 4052 | } |
3943 | }).then(async ee=>{ | 4053 | }).then(async ee=>{ |
3944 | - if (ee.data.code == 0) { | ||
3945 | - var ddata = ee.data.data, | ||
3946 | - isok = 1, | ||
3947 | - gname = "", | ||
3948 | - err = ""; | ||
3949 | - //--组装-- | ||
3950 | - for (var ij = 0; ij < ddata.length; ij++) { | ||
3951 | - var val = ddata[ij]; | ||
3952 | - | ||
3953 | - var ky=val.goods_id + "-"+val.prom_type + "-"+val.prom_id; | ||
3954 | - var obj = map_limit.get(ky); | ||
3955 | - if (obj) continue; | ||
3956 | - | ||
3957 | - var promgoodsbuynum = 0; | ||
3958 | - var goodsbuynum = 0; | ||
3959 | - | ||
3960 | - //--要获得商品,该用户买了多少件,同步应用-- | ||
3961 | - await getApp().request.promiseGet("/api/weshop/ordergoods/getUserBuyGoodsNum", { | ||
3962 | - data: { | ||
3963 | - store_id: oo.stoid, | ||
3964 | - user_id:getApp().globalData.user_id, | ||
3965 | - goods_id: val.goods_id, | ||
3966 | - prom_type: val.prom_type, | ||
3967 | - prom_id: val.prom_id, | ||
3968 | - isnew:1 | ||
3969 | - }, | ||
3970 | - }).then(res => { | ||
3971 | - var buy_num_data = res.data.data; | ||
3972 | - if (buy_num_data.promgoodsbuynum) promgoodsbuynum = buy_num_data.promgoodsbuynum; | ||
3973 | - goodsbuynum = buy_num_data.goodsbuynum; | ||
3974 | - }) | ||
3975 | - var ie = { | ||
3976 | - promgoodsbuynum: promgoodsbuynum, | ||
3977 | - goodsbuynum: goodsbuynum | ||
3978 | - }; | ||
3979 | - map_limit.set(ky, ie); | 4054 | + if (ee.data.code == 0 && ee.data.data && ee.data.data.length) { |
4055 | + var ddata = ee.data.data, | ||
4056 | + isok = 1, | ||
4057 | + gname = "", | ||
4058 | + err = ""; | ||
4059 | + //--组装-- | ||
4060 | + for (var ij = 0; ij < ddata.length; ij++) { | ||
4061 | + var val = ddata[ij]; | ||
4062 | + | ||
4063 | + var ky=val.goods_id + "-"+val.prom_type + "-"+val.prom_id; | ||
4064 | + var obj = map_limit.get(ky); | ||
4065 | + if (obj) continue; | ||
4066 | + | ||
4067 | + var promgoodsbuynum =val.promgoodsbuynum || 0; | ||
4068 | + var goodsbuynum =val.goodsbuynum || 0; | ||
4069 | + | ||
4070 | + var ie = { | ||
4071 | + promgoodsbuynum: promgoodsbuynum, | ||
4072 | + goodsbuynum: goodsbuynum | ||
4073 | + }; | ||
4074 | + map_limit.set(ky, ie); | ||
4075 | + } | ||
4076 | + | ||
4077 | + //try { | ||
4078 | + for (var ind in ddata) { | ||
4079 | + var val = ddata[ind]; | ||
4080 | + var num = map.get(val.goods_id + ""); | ||
4081 | + | ||
4082 | + var ky=val.goods_id + "-"+val.prom_type + "-"+val.prom_id; | ||
4083 | + var buyed = map_limit.get(ky); | ||
4084 | + | ||
4085 | + if (num <= 0) { | ||
4086 | + isok = 0; | ||
4087 | + gname = val.goods_name; | ||
4088 | + err= "购买数量不能为0"; | ||
4089 | + return false; | ||
3980 | } | 4090 | } |
3981 | 4091 | ||
3982 | - //try { | ||
3983 | - for (var ind in ddata) { | ||
3984 | - var val = ddata[ind]; | ||
3985 | - var num = map.get(val.goods_id + ""); | 4092 | + if (val.prom_type == 1 || val.prom_type == 2) { |
3986 | 4093 | ||
3987 | - var ky=val.goods_id + "-"+val.prom_type + "-"+val.prom_id; | ||
3988 | - var buyed = map_limit.get(ky); | 4094 | + var s_num=num; |
4095 | + if(th.data.sales_rules> 1) s_num=buyed; | ||
4096 | + if (s_num > val.store_count) { | ||
4097 | + isok = 0; | ||
4098 | + gname = val.goods_name; | ||
4099 | + err="超出库存"; | ||
4100 | + return false; | ||
4101 | + } | ||
3989 | 4102 | ||
3990 | - if (num <= 0) { | ||
3991 | - isok = 0; | ||
3992 | - gname = val.goods_name; | ||
3993 | - throw "购买数量不能为0"; | ||
3994 | - return false; | ||
3995 | - } | 4103 | + if (buyed > val.redisnum && val.redisnum) { |
4104 | + isok = 0; | ||
4105 | + gname = val.goods_name; | ||
4106 | + err="超出活动库存"; | ||
4107 | + break; | ||
4108 | + } | ||
4109 | + if (buyed > val.goods_num - val.buy_num && val.goods_num) { | ||
4110 | + isok = 0; | ||
4111 | + gname = val.goods_name; | ||
4112 | + err="超出活动库存"; | ||
4113 | + break; | ||
4114 | + } | ||
4115 | + } | ||
3996 | 4116 | ||
3997 | - if (val.prom_type == 1 || val.prom_type == 2) { | 4117 | + if (th.data.sales_rules == 1) { |
4118 | + if (num > val.store_count) { | ||
4119 | + isok = 0; | ||
4120 | + gname = val.goods_name; | ||
4121 | + err="超出库存"; | ||
4122 | + break; | ||
4123 | + } | ||
4124 | + } | ||
3998 | 4125 | ||
3999 | - var s_num=num; | ||
4000 | - if(th.data.sales_rules> 1) s_num=buyed; | ||
4001 | - if (s_num > val.store_count) { | ||
4002 | - isok = 0; | ||
4003 | - gname = val.goods_name; | ||
4004 | - throw "超出库存"; | ||
4005 | - return false; | ||
4006 | - } | 4126 | + if (num + buyed.goodsbuynum > val.viplimited && val.viplimited > 0) { |
4127 | + isok = 0; | ||
4128 | + gname = val.goods_name; | ||
4129 | + err="超出商品限购"; | ||
4130 | + break; | ||
4131 | + } | ||
4007 | 4132 | ||
4008 | - if (buyed > val.redisnum && val.redisnum) { | ||
4009 | - isok = 0; | ||
4010 | - gname = val.goods_name; | ||
4011 | - err="超出活动库存"; | ||
4012 | - break; | ||
4013 | - } | ||
4014 | - if (buyed > val.goods_num - val.buy_num && val.goods_num) { | ||
4015 | - isok = 0; | ||
4016 | - gname = val.goods_name; | ||
4017 | - err="超出活动库存"; | ||
4018 | - break; | ||
4019 | - } | 4133 | + if (num + buyed.promgoodsbuynum > val.buy_limit && val.buy_limit > 0) { |
4134 | + isok = 0; | ||
4135 | + gname = val.goods_name; | ||
4136 | + err="超出活动限购"; | ||
4137 | + break; | ||
4138 | + } | ||
4020 | 4139 | ||
4021 | - } | 4140 | + var card_field = th.data.card_field; |
4141 | + for (var i = 0; i < g_arr.length; i++) { | ||
4142 | + if (g_arr[i].goods_id == val.goods_id) { | ||
4022 | 4143 | ||
4023 | - if (th.data.sales_rules == 1) { | ||
4024 | - if (num > val.store_count) { | 4144 | + //如果会员是等级会员,商品有等级价,且不是活动商品 |
4145 | + if (card_field && val[card_field] > 0 && | ||
4146 | + ((val.prom_type == 0 && g_arr[i].prom_type == 0) || g_arr[i].prom_type == 5 || g_arr[i].prom_type == 7 || g_arr[i].prom_type == 10)) { | ||
4147 | + if (g_arr[i].goods_price != val[card_field]) { | ||
4025 | isok = 0; | 4148 | isok = 0; |
4026 | gname = val.goods_name; | 4149 | gname = val.goods_name; |
4027 | - err="超出库存"; | 4150 | + err="商品价格已经变化"; |
4151 | + break; | ||
4152 | + } | ||
4153 | + } else { | ||
4154 | + if (g_arr[i].goods_price != val.shop_price && g_arr[i].goods_price != val.prom_price && val.prom_price > 0) { | ||
4155 | + isok = 0; | ||
4156 | + gname = val.goods_name; | ||
4157 | + err="商品价格已经变化"; | ||
4028 | break; | 4158 | break; |
4029 | } | 4159 | } |
4030 | } | 4160 | } |
4031 | 4161 | ||
4162 | + //-- 数据的更新 -- | ||
4163 | + var data = { | ||
4164 | + id: g_arr[i].id, | ||
4165 | + selected: 1, | ||
4166 | + store_id: oo.stoid, | ||
4167 | + prom_type: g_arr[i].prom_type, | ||
4168 | + prom_id: g_arr[i].prom_id, | ||
4169 | + }; | ||
4032 | 4170 | ||
4171 | + // let gitem = checkArr7.find(item => item.goods_id == g_arr[i].goods_id) | ||
4172 | + // if (gitem) { | ||
4173 | + // data.prom_type = 0 | ||
4174 | + // data.prom_id = 0 | ||
4175 | + // } | ||
4033 | 4176 | ||
4034 | - if (num + buyed.goodsbuynum > val.viplimited && val.viplimited > 0) { | ||
4035 | - isok = 0; | ||
4036 | - gname = val.goods_name; | ||
4037 | - err="超出商品限购"; | ||
4038 | - break; | ||
4039 | - } | ||
4040 | - | ||
4041 | - if (num + buyed.promgoodsbuynum > val.buy_limit && val.buy_limit > 0) { | ||
4042 | - isok = 0; | ||
4043 | - gname = val.goods_name; | ||
4044 | - err="超出活动限购"; | ||
4045 | - break; | ||
4046 | - } | ||
4047 | - | ||
4048 | - var card_field = th.data.card_field; | ||
4049 | - for (var i = 0; i < g_arr.length; i++) { | ||
4050 | - if (g_arr[i].goods_id == val.goods_id) { | ||
4051 | - | ||
4052 | - //如果会员是等级会员,商品有等级价,且不是活动商品 | ||
4053 | - if (card_field && val[card_field] > 0 && | ||
4054 | - ((val.prom_type == 0 && g_arr[i].prom_type == 0) || g_arr[i].prom_type == 5 || g_arr[i].prom_type == 7 || g_arr[i].prom_type == 10)) { | ||
4055 | - if (g_arr[i].goods_price != val[card_field]) { | ||
4056 | - isok = 0; | ||
4057 | - gname = val.goods_name; | ||
4058 | - err="商品价格已经变化"; | ||
4059 | - break; | ||
4060 | - } | ||
4061 | - } else { | ||
4062 | - if (g_arr[i].goods_price != val.shop_price && g_arr[i].goods_price != val.prom_price && val.prom_price > 0) { | ||
4063 | - isok = 0; | ||
4064 | - gname = val.goods_name; | ||
4065 | - err="商品价格已经变化"; | ||
4066 | - break; | ||
4067 | - } | ||
4068 | - } | ||
4069 | - | ||
4070 | - //-- 数据的更新 -- | ||
4071 | - var data = { | ||
4072 | - id: g_arr[i].id, | ||
4073 | - selected: 1, | ||
4074 | - store_id: oo.stoid, | ||
4075 | - prom_type: g_arr[i].prom_type, | ||
4076 | - prom_id: g_arr[i].prom_id, | ||
4077 | - }; | ||
4078 | - | ||
4079 | - // let gitem = checkArr7.find(item => item.goods_id == g_arr[i].goods_id) | ||
4080 | - // if (gitem) { | ||
4081 | - // data.prom_type = 0 | ||
4082 | - // data.prom_id = 0 | ||
4083 | - // } | ||
4084 | - | ||
4085 | - //-- 如果有线下取价的时候 -- | ||
4086 | - if (g_arr[i].is_offline) { | ||
4087 | - data.pricing_type = g_arr[i].pricing_type; | ||
4088 | - data.offline_price = g_arr[i].offline_price; | ||
4089 | - } | ||
4090 | - rq.put("/api/weshop/cart/update", { | ||
4091 | - data: data, | ||
4092 | - success: function (ee) { | ||
4093 | - console.log(ee); | ||
4094 | - } | ||
4095 | - }); | ||
4096 | - } | 4177 | + //-- 如果有线下取价的时候 -- |
4178 | + if (g_arr[i].is_offline) { | ||
4179 | + data.pricing_type = g_arr[i].pricing_type; | ||
4180 | + data.offline_price = g_arr[i].offline_price; | ||
4097 | } | 4181 | } |
4098 | - | ||
4099 | - if(!isok) break; | 4182 | + //把更新数组存起来 |
4183 | + up_cart_data.push(data); | ||
4100 | 4184 | ||
4101 | } | 4185 | } |
4102 | - // } catch (e) { | ||
4103 | - // err = e; | ||
4104 | - // } | ||
4105 | - if (isok == 0) { | ||
4106 | - t.confirmBox(gname + ":" + err); | ||
4107 | - wx.hideLoading(); | ||
4108 | - return false; | ||
4109 | } | 4186 | } |
4110 | 4187 | ||
4188 | + if(!isok) break; | ||
4111 | 4189 | ||
4112 | - wx.hideLoading(); | ||
4113 | - wx.navigateTo({ | ||
4114 | - url: "/packageE/pages/cart/cart2/cart2" | ||
4115 | - }); | ||
4116 | } | 4190 | } |
4191 | + // } catch (e) { | ||
4192 | + // err = e; | ||
4193 | + // } | ||
4194 | + if (isok == 0) { | ||
4195 | + t.confirmBox(gname + ":" + err); | ||
4196 | + th.clear_checkouting(); | ||
4197 | + return false; | ||
4198 | + } | ||
4199 | + | ||
4200 | + getApp().request.promisePost("/api/weshop/cart/updateCartPromInfo", { | ||
4201 | + is_json: 1, | ||
4202 | + data: up_cart_data, | ||
4203 | + }); | ||
4204 | + | ||
4205 | + wx.navigateTo({ | ||
4206 | + url: "/packageE/pages/cart/cart2/cart2" | ||
4207 | + }); | ||
4208 | + } | ||
4117 | }) | 4209 | }) |
4118 | }, | 4210 | }, |
4119 | 4211 | ||
4212 | + | ||
4213 | + | ||
4120 | //结算到最后一个商品 | 4214 | //结算到最后一个商品 |
4121 | set_last: function (ab, isok, gname) { | 4215 | set_last: function (ab, isok, gname) { |
4122 | if (isok == 0) { | 4216 | if (isok == 0) { |
@@ -4312,10 +4406,15 @@ Page({ | @@ -4312,10 +4406,15 @@ Page({ | ||
4312 | 4406 | ||
4313 | //-- 所有的购物车的数据,要用拷贝的赖进行计算 -- | 4407 | //-- 所有的购物车的数据,要用拷贝的赖进行计算 -- |
4314 | var alllist = JSON.parse(JSON.stringify(this.data.requestData)); | 4408 | var alllist = JSON.parse(JSON.stringify(this.data.requestData)); |
4315 | - var list2 = alllist[cindex]; | 4409 | + //var list2 = alllist[cindex]; |
4316 | var no_gift_arr = []; | 4410 | var no_gift_arr = []; |
4317 | 4411 | ||
4318 | - | 4412 | + //用来存销赠品的--2024-2-1 |
4413 | + let cart_zp=this.data.cart_zp; | ||
4414 | + //要清空一下门店下的赠品 | ||
4415 | + if(cart_zp[list.pid]){ | ||
4416 | + cart_zp[list.pid]={}; | ||
4417 | + } | ||
4319 | //主要判断有没有促销活动 | 4418 | //主要判断有没有促销活动 |
4320 | var is_sele_prom = 0; | 4419 | var is_sele_prom = 0; |
4321 | var is_gift_del = 0; | 4420 | var is_gift_del = 0; |
@@ -4343,17 +4442,24 @@ Page({ | @@ -4343,17 +4442,24 @@ Page({ | ||
4343 | map.set(item.prom_id + "", ob); | 4442 | map.set(item.prom_id + "", ob); |
4344 | } | 4443 | } |
4345 | } | 4444 | } |
4346 | - if (item.is_gift == 1) { | ||
4347 | - var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; | ||
4348 | - //getApp().request.delete(url, {}); | ||
4349 | - await getApp().request.promiseDelete(url, {}) // 要用同步让赠品删除 | ||
4350 | - list2.goods.splice(i, 1); | ||
4351 | - list.goods.splice(i--, 1); | ||
4352 | - is_gift_del = 1; | ||
4353 | - } | 4445 | + //-- list中不再添加和删除赠品,优化list不再添加赠品,2024-02-01 -- |
4446 | + // if (item.is_gift == 1) { | ||
4447 | + // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; | ||
4448 | + // //getApp().request.delete(url, {}); | ||
4449 | + // await getApp().request.promiseDelete(url, {}) // 要用同步让赠品删除 | ||
4450 | + // list2.goods.splice(i, 1); | ||
4451 | + // list.goods.splice(i--, 1); | ||
4452 | + // is_gift_del = 1; | ||
4453 | + // } | ||
4354 | } | 4454 | } |
4355 | //--如果没有选中的促销活动的,直接退出 -- | 4455 | //--如果没有选中的促销活动的,直接退出 -- |
4356 | if (!is_sele_prom) { | 4456 | if (!is_sele_prom) { |
4457 | + | ||
4458 | + //--- 设置单赠品的显示---2024-2-1 | ||
4459 | + this.setData({ | ||
4460 | + cart_zp | ||
4461 | + }) | ||
4462 | + | ||
4357 | //如果有赠品,要重新更新购物车的前台渲染-- | 4463 | //如果有赠品,要重新更新购物车的前台渲染-- |
4358 | if (is_gift_del) { | 4464 | if (is_gift_del) { |
4359 | var rq_text = "requestData[" + cindex + "]"; | 4465 | var rq_text = "requestData[" + cindex + "]"; |
@@ -4374,6 +4480,10 @@ Page({ | @@ -4374,6 +4480,10 @@ Page({ | ||
4374 | 4480 | ||
4375 | return false; | 4481 | return false; |
4376 | } | 4482 | } |
4483 | + | ||
4484 | + | ||
4485 | + //用来判断有没有list大小发生变化 | ||
4486 | + let is_change_list=0; | ||
4377 | //-- 循环判断活动 -- | 4487 | //-- 循环判断活动 -- |
4378 | for (let p_item of map.entries()) { | 4488 | for (let p_item of map.entries()) { |
4379 | var prom = null; | 4489 | var prom = null; |
@@ -4398,12 +4508,15 @@ Page({ | @@ -4398,12 +4508,15 @@ Page({ | ||
4398 | //如果活动已经结束 | 4508 | //如果活动已经结束 |
4399 | if (!prom || prom.is_end || prom.end_time < ut.gettimestamp()) { | 4509 | if (!prom || prom.is_end || prom.end_time < ut.gettimestamp()) { |
4400 | for (var ii in list.goods) { | 4510 | for (var ii in list.goods) { |
4401 | - var item = list.goods[ii]; | ||
4402 | - list.goods.splice(ii, 1); | 4511 | + |
4403 | if (item.prom_id == p_item[0] && item.prom_type == 3) { | 4512 | if (item.prom_id == p_item[0] && item.prom_type == 3) { |
4404 | // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; | 4513 | // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; |
4405 | // getApp().request.delete(url, {}); | 4514 | // getApp().request.delete(url, {}); |
4406 | th.disInvalid(item); | 4515 | th.disInvalid(item); |
4516 | + | ||
4517 | + var item = list.goods[ii]; | ||
4518 | + list.goods.splice(ii, 1); | ||
4519 | + is_change_list=1; | ||
4407 | } | 4520 | } |
4408 | } | 4521 | } |
4409 | continue; | 4522 | continue; |
@@ -4479,7 +4592,7 @@ Page({ | @@ -4479,7 +4592,7 @@ Page({ | ||
4479 | 4592 | ||
4480 | if (discount) { | 4593 | if (discount) { |
4481 | if (!discount.zp_num || parseInt(discount.zp_num) == 0) discount.zp_num = 1; | 4594 | if (!discount.zp_num || parseInt(discount.zp_num) == 0) discount.zp_num = 1; |
4482 | - //判断一下赠品的模式 | 4595 | + //判断一下赠品的模式,如果是多赠品的时候 |
4483 | if (parseInt(discount.zp_mode) == 1) { | 4596 | if (parseInt(discount.zp_mode) == 1) { |
4484 | 4597 | ||
4485 | var can_zp_num = 0; | 4598 | var can_zp_num = 0; |
@@ -4514,7 +4627,7 @@ Page({ | @@ -4514,7 +4627,7 @@ Page({ | ||
4514 | } else { | 4627 | } else { |
4515 | //---如果有打折的信息,赠送的信息,赠送的时候要判断是不是限购数量--- | 4628 | //---如果有打折的信息,赠送的信息,赠送的时候要判断是不是限购数量--- |
4516 | if (discount && discount['goods_id'] && (!discount.limit_num || discount.limit_num >= discount.bs * discount.zp_num) && | 4629 | if (discount && discount['goods_id'] && (!discount.limit_num || discount.limit_num >= discount.bs * discount.zp_num) && |
4517 | - discount.gift_storecount >= discount.bs * discount.zp_num) { | 4630 | + discount.gift_storecount >= discount.bs * discount.zp_num) { |
4518 | //如果这礼品超了情况下 | 4631 | //如果这礼品超了情况下 |
4519 | if (no_gift_arr.indexOf(discount.gift_id) != -1) continue; | 4632 | if (no_gift_arr.indexOf(discount.gift_id) != -1) continue; |
4520 | var o = discount.goodsinfo; | 4633 | var o = discount.goodsinfo; |
@@ -4541,7 +4654,7 @@ Page({ | @@ -4541,7 +4654,7 @@ Page({ | ||
4541 | original_img: th.data.imgUrl + o.original_img | 4654 | original_img: th.data.imgUrl + o.original_img |
4542 | }; | 4655 | }; |
4543 | 4656 | ||
4544 | - list2.goods.push(newd); | 4657 | + //list2.goods.push(newd); |
4545 | var all_num = 0; | 4658 | var all_num = 0; |
4546 | var all_limit_num = 0; | 4659 | var all_limit_num = 0; |
4547 | 4660 | ||
@@ -4568,7 +4681,7 @@ Page({ | @@ -4568,7 +4681,7 @@ Page({ | ||
4568 | } | 4681 | } |
4569 | 4682 | ||
4570 | var url = "/api/weshop/cart/delGift?store_id=" + newd.store_id + "&user_id=" + | 4683 | var url = "/api/weshop/cart/delGift?store_id=" + newd.store_id + "&user_id=" + |
4571 | - newd.user_id + "&goods_id=" + newd.goods_id + "&is_gift=1&pick_id=" + newd.pick_id + "&prom_id=" + newd.prom_id | 4684 | + newd.user_id + "&goods_id=" + newd.goods_id + "&is_gift=1&pick_id=" + newd.pick_id + "&prom_id=" + newd.prom_id |
4572 | await getApp().request.promiseDelete(url, {}) | 4685 | await getApp().request.promiseDelete(url, {}) |
4573 | 4686 | ||
4574 | var add_data = null; | 4687 | var add_data = null; |
@@ -4581,18 +4694,30 @@ Page({ | @@ -4581,18 +4694,30 @@ Page({ | ||
4581 | }) | 4694 | }) |
4582 | if (add_data) { | 4695 | if (add_data) { |
4583 | newd.id = add_data.id; | 4696 | newd.id = add_data.id; |
4584 | - list.goods.push(newd); | 4697 | + //list.goods.push(newd); |
4698 | + if(!cart_zp[list.pid]) cart_zp[list.pid]={}; | ||
4699 | + if(!cart_zp[list.pid].goods) cart_zp[list.pid].goods=[]; | ||
4700 | + cart_zp[list.pid].goods.push(newd); | ||
4585 | } | 4701 | } |
4586 | } | 4702 | } |
4587 | } | 4703 | } |
4588 | } | 4704 | } |
4589 | 4705 | ||
4590 | } | 4706 | } |
4591 | - //--更新购物车的前台渲染-- | ||
4592 | - var rq_text = "requestData[" + cindex + "]"; | 4707 | + |
4708 | + //--- 设置单赠品的显示---2024-2-1 | ||
4593 | this.setData({ | 4709 | this.setData({ |
4594 | - [rq_text]: list | ||
4595 | - }); | 4710 | + cart_zp |
4711 | + }) | ||
4712 | + | ||
4713 | + //list大小有变换,才会渲染list | ||
4714 | + if(is_change_list) { | ||
4715 | + //--更新购物车的前台渲染-- | ||
4716 | + var rq_text = "requestData[" + cindex + "]"; | ||
4717 | + this.setData({ | ||
4718 | + [rq_text]: list | ||
4719 | + }); | ||
4720 | + } | ||
4596 | 4721 | ||
4597 | var diff_text = "requestData[" + cindex + "].make_up_arr"; | 4722 | var diff_text = "requestData[" + cindex + "].make_up_arr"; |
4598 | //-- 如果有凑单的话 -- | 4723 | //-- 如果有凑单的话 -- |
@@ -4620,6 +4745,8 @@ Page({ | @@ -4620,6 +4745,8 @@ Page({ | ||
4620 | 4745 | ||
4621 | }, | 4746 | }, |
4622 | 4747 | ||
4748 | + | ||
4749 | + | ||
4623 | //优惠促销用户参与次数 | 4750 | //优惠促销用户参与次数 |
4624 | async getUserBuyPromNum_pre(prom_id) { | 4751 | async getUserBuyPromNum_pre(prom_id) { |
4625 | var userInfo = getApp().globalData.userInfo; | 4752 | var userInfo = getApp().globalData.userInfo; |
@@ -4634,6 +4761,7 @@ Page({ | @@ -4634,6 +4761,7 @@ Page({ | ||
4634 | return user_pre_buynum | 4761 | return user_pre_buynum |
4635 | }, | 4762 | }, |
4636 | 4763 | ||
4764 | + | ||
4637 | async all_check_prom_activity() { | 4765 | async all_check_prom_activity() { |
4638 | this.data.duo_zp_num_arr = {}; | 4766 | this.data.duo_zp_num_arr = {}; |
4639 | for (var i in this.data.requestData) { | 4767 | for (var i in this.data.requestData) { |
@@ -4647,9 +4775,14 @@ Page({ | @@ -4647,9 +4775,14 @@ Page({ | ||
4647 | 4775 | ||
4648 | //-- 所有的购物车的数据,要用拷贝的赖进行计算 -- | 4776 | //-- 所有的购物车的数据,要用拷贝的赖进行计算 -- |
4649 | var alllist = JSON.parse(JSON.stringify(this.data.requestData)); | 4777 | var alllist = JSON.parse(JSON.stringify(this.data.requestData)); |
4650 | - var list2 = alllist[cindex]; | 4778 | + //var list2 = alllist[cindex]; |
4779 | + | ||
4651 | var no_gift_arr = []; | 4780 | var no_gift_arr = []; |
4652 | 4781 | ||
4782 | + //用来存销赠品的--2024-2-1 | ||
4783 | + let cart_zp=this.data.cart_zp; | ||
4784 | + //要清空一下赠品数组 | ||
4785 | + cart_zp={}; | ||
4653 | 4786 | ||
4654 | //主要判断有没有促销活动 | 4787 | //主要判断有没有促销活动 |
4655 | var is_sele_prom = 0; | 4788 | var is_sele_prom = 0; |
@@ -4677,25 +4810,30 @@ Page({ | @@ -4677,25 +4810,30 @@ Page({ | ||
4677 | map.set(item.prom_id + "", ob); | 4810 | map.set(item.prom_id + "", ob); |
4678 | } | 4811 | } |
4679 | } | 4812 | } |
4680 | - if (item.is_gift == 1) { | ||
4681 | - var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; | ||
4682 | - //getApp().request.delete(url, {}); | ||
4683 | - await getApp().request.promiseDelete(url, {}) // 要用同步让赠品删除 | ||
4684 | - list2.goods.splice(i, 1); | ||
4685 | - list.goods.splice(i--, 1); | ||
4686 | - is_gift_del = 1; | ||
4687 | - } | 4813 | + |
4814 | + //-- list中不再添加和删除赠品,优化list不再添加赠品,2024-02-01 -- | ||
4815 | + // if (item.is_gift == 1) { | ||
4816 | + // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; | ||
4817 | + // //getApp().request.delete(url, {}); | ||
4818 | + // await getApp().request.promiseDelete(url, {}) // 要用同步让赠品删除 | ||
4819 | + // list2.goods.splice(i, 1); | ||
4820 | + // list.goods.splice(i--, 1); | ||
4821 | + // is_gift_del = 1; | ||
4822 | + // } | ||
4688 | } | 4823 | } |
4689 | //--如果没有选中的促销活动的,直接退出 -- | 4824 | //--如果没有选中的促销活动的,直接退出 -- |
4690 | if (!is_sele_prom) { | 4825 | if (!is_sele_prom) { |
4691 | - //如果有赠品,要重新更新购物车的前台渲染-- | ||
4692 | - if (is_gift_del) { | ||
4693 | - var rq_text = "requestData[" + cindex + "]"; | ||
4694 | - this.setData({ | ||
4695 | - [rq_text]: list | ||
4696 | - }); | ||
4697 | - } | ||
4698 | - | 4826 | + //如果有赠品,要重新更新购物车的前台渲,list中不再显示-- |
4827 | + // if (is_gift_del) { | ||
4828 | + // var rq_text = "requestData[" + cindex + "]"; | ||
4829 | + // this.setData({ | ||
4830 | + // [rq_text]: list | ||
4831 | + // }); | ||
4832 | + // } | ||
4833 | + //--- 设置单赠品的显示---2024-2-1 | ||
4834 | + this.setData({ | ||
4835 | + cart_zp | ||
4836 | + }) | ||
4699 | var rq_text2 = "requestData[" + cindex + "].make_up_arr"; | 4837 | var rq_text2 = "requestData[" + cindex + "].make_up_arr"; |
4700 | this.setData({ | 4838 | this.setData({ |
4701 | [rq_text2]: null, | 4839 | [rq_text2]: null, |
@@ -4707,6 +4845,9 @@ Page({ | @@ -4707,6 +4845,9 @@ Page({ | ||
4707 | }) | 4845 | }) |
4708 | continue; | 4846 | continue; |
4709 | } | 4847 | } |
4848 | + | ||
4849 | + //用来判断有没有list大小发生变化 | ||
4850 | + let is_change_list=0; | ||
4710 | //-- 循环判断活动 -- | 4851 | //-- 循环判断活动 -- |
4711 | for (let p_item of map.entries()) { | 4852 | for (let p_item of map.entries()) { |
4712 | var prom = null; | 4853 | var prom = null; |
@@ -4728,13 +4869,17 @@ Page({ | @@ -4728,13 +4869,17 @@ Page({ | ||
4728 | } | 4869 | } |
4729 | //如果活动已经结束 | 4870 | //如果活动已经结束 |
4730 | if (!prom || prom.is_end || prom.end_time < ut.gettimestamp()) { | 4871 | if (!prom || prom.is_end || prom.end_time < ut.gettimestamp()) { |
4872 | + | ||
4731 | for (var ii in list.goods) { | 4873 | for (var ii in list.goods) { |
4732 | - var item = list.goods[ii]; | ||
4733 | - list.goods.splice(ii, 1); | 4874 | + |
4734 | if (item.prom_id == p_item[0] && item.prom_type == 3) { | 4875 | if (item.prom_id == p_item[0] && item.prom_type == 3) { |
4735 | // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; | 4876 | // var url = '/api/weshop/cart/del/' + oo.stoid + '/' + item.id; |
4736 | // getApp().request.delete(url, {}); | 4877 | // getApp().request.delete(url, {}); |
4737 | th.disInvalid(item); | 4878 | th.disInvalid(item); |
4879 | + | ||
4880 | + var item = list.goods[ii]; | ||
4881 | + list.goods.splice(ii, 1); | ||
4882 | + is_change_list=1; | ||
4738 | } | 4883 | } |
4739 | } | 4884 | } |
4740 | continue; | 4885 | continue; |
@@ -4792,8 +4937,6 @@ Page({ | @@ -4792,8 +4937,6 @@ Page({ | ||
4792 | } | 4937 | } |
4793 | } | 4938 | } |
4794 | 4939 | ||
4795 | - | ||
4796 | - | ||
4797 | //-- 只有在单赠品的时候,才要进行计算 -- | 4940 | //-- 只有在单赠品的时候,才要进行计算 -- |
4798 | await getApp().request.promiseGet("/api/weshop/goods/getDiscount", { | 4941 | await getApp().request.promiseGet("/api/weshop/goods/getDiscount", { |
4799 | data: { | 4942 | data: { |
@@ -4810,7 +4953,7 @@ Page({ | @@ -4810,7 +4953,7 @@ Page({ | ||
4810 | if (discount) { | 4953 | if (discount) { |
4811 | 4954 | ||
4812 | if (!discount.zp_num || parseInt(discount.zp_num) == 0) discount.zp_num = 1; | 4955 | if (!discount.zp_num || parseInt(discount.zp_num) == 0) discount.zp_num = 1; |
4813 | - //判断一下赠品的模式 | 4956 | + //-- 判断一下赠品的模式,如果是多赠品的模式 -- |
4814 | if (parseInt(discount.zp_mode) == 1) { | 4957 | if (parseInt(discount.zp_mode) == 1) { |
4815 | 4958 | ||
4816 | var can_zp_num = 0; | 4959 | var can_zp_num = 0; |
@@ -4843,7 +4986,7 @@ Page({ | @@ -4843,7 +4986,7 @@ Page({ | ||
4843 | } else { | 4986 | } else { |
4844 | //---如果有打折的信息,赠送的信息,赠送的时候要判断是不是限购数量,因为增加了限购数量不限的情况--- | 4987 | //---如果有打折的信息,赠送的信息,赠送的时候要判断是不是限购数量,因为增加了限购数量不限的情况--- |
4845 | if (discount && discount['goods_id'] && (!discount.limit_num || discount.limit_num >= discount.bs * discount.zp_num) && | 4988 | if (discount && discount['goods_id'] && (!discount.limit_num || discount.limit_num >= discount.bs * discount.zp_num) && |
4846 | - discount.gift_storecount >= discount.bs * discount.zp_num) { | 4989 | + discount.gift_storecount >= discount.bs * discount.zp_num) { |
4847 | //如果这礼品超了情况下 | 4990 | //如果这礼品超了情况下 |
4848 | if (no_gift_arr.indexOf(discount.gift_id) != -1) continue; | 4991 | if (no_gift_arr.indexOf(discount.gift_id) != -1) continue; |
4849 | var o = discount.goodsinfo; | 4992 | var o = discount.goodsinfo; |
@@ -4870,7 +5013,7 @@ Page({ | @@ -4870,7 +5013,7 @@ Page({ | ||
4870 | original_img: th.data.imgUrl + o.original_img | 5013 | original_img: th.data.imgUrl + o.original_img |
4871 | }; | 5014 | }; |
4872 | 5015 | ||
4873 | - list2.goods.push(newd); | 5016 | + //list2.goods.push(newd); |
4874 | var all_num = 0; | 5017 | var all_num = 0; |
4875 | var all_limit_num = 0; | 5018 | var all_limit_num = 0; |
4876 | 5019 | ||
@@ -4888,7 +5031,6 @@ Page({ | @@ -4888,7 +5031,6 @@ Page({ | ||
4888 | 5031 | ||
4889 | } | 5032 | } |
4890 | } | 5033 | } |
4891 | - | ||
4892 | //-- 赠品的数量超出库存数量和会员的限制,这里是保证所有的赠品部会超出 -- | 5034 | //-- 赠品的数量超出库存数量和会员的限制,这里是保证所有的赠品部会超出 -- |
4893 | if (discount.gift_storecount < all_num + newd.goods_num || (discount.limit_num && discount.limit_num < all_limit_num + newd.goods_num)) { | 5035 | if (discount.gift_storecount < all_num + newd.goods_num || (discount.limit_num && discount.limit_num < all_limit_num + newd.goods_num)) { |
4894 | no_gift_arr.push(discount.gift_id); | 5036 | no_gift_arr.push(discount.gift_id); |
@@ -4898,7 +5040,7 @@ Page({ | @@ -4898,7 +5040,7 @@ Page({ | ||
4898 | 5040 | ||
4899 | 5041 | ||
4900 | var url = "/api/weshop/cart/delGift?store_id=" + newd.store_id + "&user_id=" + | 5042 | var url = "/api/weshop/cart/delGift?store_id=" + newd.store_id + "&user_id=" + |
4901 | - newd.user_id + "&goods_id=" + newd.goods_id + "&is_gift=1&pick_id=" + newd.pick_id + "&prom_id=" + newd.prom_id | 5043 | + newd.user_id + "&goods_id=" + newd.goods_id + "&is_gift=1&pick_id=" + newd.pick_id + "&prom_id=" + newd.prom_id |
4902 | await getApp().request.promiseDelete(url, {}) | 5044 | await getApp().request.promiseDelete(url, {}) |
4903 | 5045 | ||
4904 | var add_data = null; | 5046 | var add_data = null; |
@@ -4911,18 +5053,29 @@ Page({ | @@ -4911,18 +5053,29 @@ Page({ | ||
4911 | }) | 5053 | }) |
4912 | if (add_data) { | 5054 | if (add_data) { |
4913 | newd.id = add_data.id; | 5055 | newd.id = add_data.id; |
4914 | - list.goods.push(newd); | 5056 | + //list.goods.push(newd); |
5057 | + if(!cart_zp[list.pid]) cart_zp[list.pid]={}; | ||
5058 | + if(!cart_zp[list.pid].goods) cart_zp[list.pid].goods=[]; | ||
5059 | + cart_zp[list.pid].goods.push(newd); | ||
4915 | } | 5060 | } |
4916 | } | 5061 | } |
4917 | } | 5062 | } |
4918 | } | 5063 | } |
4919 | - | ||
4920 | } | 5064 | } |
4921 | - //--更新购物车的前台渲染-- | ||
4922 | - var rq_text = "requestData[" + cindex + "]"; | 5065 | + |
5066 | + //--- 设置单赠品的显示---2024-2-1 | ||
4923 | this.setData({ | 5067 | this.setData({ |
4924 | - [rq_text]: list | ||
4925 | - }); | 5068 | + cart_zp |
5069 | + }) | ||
5070 | + | ||
5071 | + //list大小有变换,才会渲染list | ||
5072 | + if(is_change_list) { | ||
5073 | + //--更新购物车的前台渲染-- | ||
5074 | + var rq_text = "requestData[" + cindex + "]"; | ||
5075 | + this.setData({ | ||
5076 | + [rq_text]: list | ||
5077 | + }); | ||
5078 | + } | ||
4926 | 5079 | ||
4927 | var diff_text = "requestData[" + cindex + "].make_up_arr"; | 5080 | var diff_text = "requestData[" + cindex + "].make_up_arr"; |
4928 | //-- 如果有凑单的话 -- | 5081 | //-- 如果有凑单的话 -- |
@@ -4952,6 +5105,8 @@ Page({ | @@ -4952,6 +5105,8 @@ Page({ | ||
4952 | } | 5105 | } |
4953 | }, | 5106 | }, |
4954 | 5107 | ||
5108 | + | ||
5109 | + | ||
4955 | //去凑单 | 5110 | //去凑单 |
4956 | go_cou_dang: function (e) { | 5111 | go_cou_dang: function (e) { |
4957 | var prom_id = e.currentTarget.dataset.prom_id; | 5112 | var prom_id = e.currentTarget.dataset.prom_id; |
pages/cart/cart/cart.wxml
@@ -60,7 +60,7 @@ | @@ -60,7 +60,7 @@ | ||
60 | 60 | ||
61 | </view> | 61 | </view> |
62 | 62 | ||
63 | - <block wx:for="{{item.goods}}" wx:for-item="items" wx:for-index="idx" wx:key="{{idx}}"> | 63 | + <block wx:for="{{item.goods}}" wx:for-item="items" wx:for-index="idx" wx:key="{{idx}}"> |
64 | <view class="order-item" data-item="{{idx}}"> | 64 | <view class="order-item" data-item="{{idx}}"> |
65 | <block wx:if="{{!items.is_gift}}"> | 65 | <block wx:if="{{!items.is_gift}}"> |
66 | <view bindtap="check_th_item" class="order-raido flex-vertical " data-check="{{items.selected}}" data-item="{{idx}}" data-pitems="{{pidx}}"> | 66 | <view bindtap="check_th_item" class="order-raido flex-vertical " data-check="{{items.selected}}" data-item="{{idx}}" data-pitems="{{pidx}}"> |
@@ -134,7 +134,7 @@ | @@ -134,7 +134,7 @@ | ||
134 | 134 | ||
135 | <!-- 验证活动是不是多个,要不要显示切换 --> | 135 | <!-- 验证活动是不是多个,要不要显示切换 --> |
136 | <!-- 新增促销多活动的排版 --> | 136 | <!-- 新增促销多活动的排版 --> |
137 | - <block wx:if="{{g_filter.is_more_act(items,item.show_can_cx) && item.show_can_cx[items.goods_id] && item.show_can_cx[items.goods_id].act_arr.length>1}}"> | 137 | + <block wx:if="{{g_filter.is_more_act(items,item.show_can_cx1) && item.show_can_cx1[items.goods_id] && item.show_can_cx1[items.goods_id].act_arr.length>1}}"> |
138 | <view class="bdb16"> | 138 | <view class="bdb16"> |
139 | <view bindtap="switch_cx_group" | 139 | <view bindtap="switch_cx_group" |
140 | data-index="{{pidx}}" | 140 | data-index="{{pidx}}" |
@@ -142,7 +142,7 @@ | @@ -142,7 +142,7 @@ | ||
142 | class="cx-frame flex" style="position: relative"> | 142 | class="cx-frame flex" style="position: relative"> |
143 | <view class="cx-sizs fs30">可参促销</view> | 143 | <view class="cx-sizs fs30">可参促销</view> |
144 | <view class="flex ai_c f1 pdh20"> | 144 | <view class="flex ai_c f1 pdh20"> |
145 | - <view class="xc-coupon-fram" wx:for="{{item.show_can_cx[items.goods_id].act_arr}}" > | 145 | + <view class="xc-coupon-fram" wx:for="{{item.show_can_cx1[items.goods_id].act_arr}}" > |
146 | <view wx:if="{{item.prom_type==3}}" class="xc-coupon t-c four-level-word {{!item.sele?'gray':'' }}">优惠促销</view> | 146 | <view wx:if="{{item.prom_type==3}}" class="xc-coupon t-c four-level-word {{!item.sele?'gray':'' }}">优惠促销</view> |
147 | <view wx:if="{{item.prom_type==5}}" class="xc-coupon t-c four-level-word {{!item.sele?'gray':'' }} ">搭配促销</view> | 147 | <view wx:if="{{item.prom_type==5}}" class="xc-coupon t-c four-level-word {{!item.sele?'gray':'' }} ">搭配促销</view> |
148 | <view wx:if="{{item.prom_type==7}}" class="xc-coupon t-c four-level-word {{!item.sele?'gray':'' }} ">组合购</view> | 148 | <view wx:if="{{item.prom_type==7}}" class="xc-coupon t-c four-level-word {{!item.sele?'gray':'' }} ">组合购</view> |
@@ -159,11 +159,35 @@ | @@ -159,11 +159,35 @@ | ||
159 | 159 | ||
160 | </block > | 160 | </block > |
161 | 161 | ||
162 | + <!-- 判断有没有赠品2024-2-1 --> | ||
163 | + <block wx:if="{{cart_zp[item.pid] && cart_zp[item.pid].goods.length>0 }}"> | ||
164 | + <block wx:for="{{cart_zp[item.pid].goods}}" wx:for-item="items" wx:for-index="idx" wx:key="{{idx}}"> | ||
165 | + <view class="order-item" data-item="{{idx}}"> | ||
166 | + <view class="order-raido flex-vertical " style="width: 45rpx"></view> | ||
167 | + <navigator class="goods-img rel" bindtap="go_gd" data-item="{{items}}" data-gd="{{items.goods_id}}"> | ||
168 | + <image class="wh100" src="{{items.original_img}}" binderror="bind_bnerr2" data-errorimg="requestData[{{pidx}}].goods[{{idx}}].original_img" data-url="{{items.original_img}}"></image> | ||
169 | + <view style="background-color:red" class="abs flex-center fs26" wx:if="{{items.is_gift==1}}">赠品</view> | ||
170 | + </navigator> | ||
171 | + <view class="goods-cont"> | ||
172 | + <view class="goods-name"> | ||
173 | + <navigator bindtap="go_gd" class="ellipsis-2 fs30" data-item="{{items}}" data-gd="{{items.goods_id}}">{{items.goods_name}}</navigator> | ||
174 | + | ||
175 | + <view class="specifications ellipsis-1"> | ||
176 | + <view wx:if="{{items.goods_color || items.goods_spec}}"> | ||
177 | + {{items.goods_color}}{{items.goods_color?"/":''}}{{items.goods_spec}}</view> | ||
178 | + <view wx:else>规格1</view> | ||
179 | + </view> | ||
180 | + <view>{{items.goods_num}}件</view> | ||
181 | + </view> | ||
182 | + </view> | ||
183 | + </view> | ||
184 | + </block> | ||
185 | + </block> | ||
162 | 186 | ||
163 | <!--此时是多个商品参与活动的切换 验证活动是不是多个,要不要显示切换 --> | 187 | <!--此时是多个商品参与活动的切换 验证活动是不是多个,要不要显示切换 --> |
164 | <!-- 新增促销多活动的排版 --> | 188 | <!-- 新增促销多活动的排版 --> |
165 | - <block wx:if="{{item.show_can_cx}}"> | ||
166 | - <block wx:for="{{item.show_can_cx}}" wx:for-item="pitem"> | 189 | + <block wx:if="{{item.show_can_cx1}}"> |
190 | + <block wx:for="{{item.show_can_cx1}}" wx:for-item="pitem"> | ||
167 | <view class="bdb16" wx:if="{{pitem.is_duo_gd && pitem.act_arr.length>1}}" > | 191 | <view class="bdb16" wx:if="{{pitem.is_duo_gd && pitem.act_arr.length>1}}" > |
168 | <view bindtap="switch_cx_group" | 192 | <view bindtap="switch_cx_group" |
169 | data-index="{{pidx}}" | 193 | data-index="{{pidx}}" |
utils/more_cx.js
@@ -511,6 +511,10 @@ module.exports = { | @@ -511,6 +511,10 @@ module.exports = { | ||
511 | } | 511 | } |
512 | //-- 判断优惠促销要不要限购 -- | 512 | //-- 判断优惠促销要不要限购 -- |
513 | var fd=th.data.in_yhact[aid]; | 513 | var fd=th.data.in_yhact[aid]; |
514 | + if(!fd && th.data.yhcx_act_map && th.data.yhcx_act_map[aid] ){ | ||
515 | + fd=th.data.yhcx_act_map[aid]; | ||
516 | + th.data.in_yhact[aid]=fd; | ||
517 | + } | ||
514 | if(!fd) { | 518 | if(!fd) { |
515 | var fd_res = await getApp().request.promiseGet('/api/weshop/promgoods/get/' + os.stoid + '/' + aid, {}) | 519 | var fd_res = await getApp().request.promiseGet('/api/weshop/promgoods/get/' + os.stoid + '/' + aid, {}) |
516 | if (fd_res && fd_res.data.code == 0) { | 520 | if (fd_res && fd_res.data.code == 0) { |
@@ -624,9 +628,8 @@ module.exports = { | @@ -624,9 +628,8 @@ module.exports = { | ||
624 | zh_goods[h].zh_b_num=promgoodsbuynum; | 628 | zh_goods[h].zh_b_num=promgoodsbuynum; |
625 | th.data.in_zh_gd_buy_map[ky]=promgoodsbuynum; | 629 | th.data.in_zh_gd_buy_map[ky]=promgoodsbuynum; |
626 | } | 630 | } |
627 | - | ||
628 | - | ||
629 | } | 631 | } |
632 | + | ||
630 | //-- 放到参与组合优惠促销的map中 -- | 633 | //-- 放到参与组合优惠促销的map中 -- |
631 | th.data.zuhe_map_good[item_act_map.prom_id] = zhact_gdlist; | 634 | th.data.zuhe_map_good[item_act_map.prom_id] = zhact_gdlist; |
632 | if(!car_item.zh_prom_goods) car_item.zh_prom_goods={}; | 635 | if(!car_item.zh_prom_goods) car_item.zh_prom_goods={}; |