Commit 93cd196b1d659a2687025a0ff5034cb935a4208d
1 parent
a71d8615
多促销的优化
Showing
7 changed files
with
497 additions
and
167 deletions
packageE/pages/cart/cart2/cart2.js
| @@ -688,7 +688,7 @@ Page({ | @@ -688,7 +688,7 @@ Page({ | ||
| 688 | var sort_type=''; | 688 | var sort_type=''; |
| 689 | 689 | ||
| 690 | if(!auto_promote_sale){ | 690 | if(!auto_promote_sale){ |
| 691 | - sort_type='prom_id'; | 691 | + sort_type='prom_type'; |
| 692 | }else{ | 692 | }else{ |
| 693 | var auto_promote_sale=auto_promote_sale.split(','); | 693 | var auto_promote_sale=auto_promote_sale.split(','); |
| 694 | //-- 循环处理 -- | 694 | //-- 循环处理 -- |
| @@ -700,12 +700,12 @@ Page({ | @@ -700,12 +700,12 @@ Page({ | ||
| 700 | } | 700 | } |
| 701 | 701 | ||
| 702 | //-- 排序一下,进行升序 -- | 702 | //-- 排序一下,进行升序 -- |
| 703 | - function comp(a, b,sort_type) { | 703 | + function comp(a, b) { |
| 704 | return a[sort_type]-b[sort_type]; //升序 | 704 | return a[sort_type]-b[sort_type]; //升序 |
| 705 | } | 705 | } |
| 706 | 706 | ||
| 707 | //使用sort排序 | 707 | //使用sort排序 |
| 708 | - prom_list.sort(comp); | 708 | + prom_list.sort(comp(sort_type)); |
| 709 | }, | 709 | }, |
| 710 | 710 | ||
| 711 | //-----真的获取购物车,入口-------- | 711 | //-----真的获取购物车,入口-------- |
| @@ -1811,11 +1811,11 @@ Page({ | @@ -1811,11 +1811,11 @@ Page({ | ||
| 1811 | "user_id": user_id, | 1811 | "user_id": user_id, |
| 1812 | } | 1812 | } |
| 1813 | 1813 | ||
| 1814 | - await getApp().request.promiseGet(url, {data: req_d}).then(res => { | 1814 | + await getApp().request.promiseGet(url, {data: req_d}).then(e => { |
| 1815 | if (e.data.code == 0 && e.data.data && e.data.data.length > 0) { | 1815 | if (e.data.code == 0 && e.data.data && e.data.data.length > 0) { |
| 1816 | var arr = e.data.data; | 1816 | var arr = e.data.data; |
| 1817 | if (arr.length) { | 1817 | if (arr.length) { |
| 1818 | - arr3 = arr.filter(function (e) { | 1818 | + var arr3 = arr.filter(function (e) { |
| 1819 | return e.s_time < ut.gettimestamp() && e.prom_type == 7; | 1819 | return e.s_time < ut.gettimestamp() && e.prom_type == 7; |
| 1820 | }) | 1820 | }) |
| 1821 | if (arr3 && arr3.length) { | 1821 | if (arr3 && arr3.length) { |
| @@ -1923,7 +1923,7 @@ Page({ | @@ -1923,7 +1923,7 @@ Page({ | ||
| 1923 | } | 1923 | } |
| 1924 | 1924 | ||
| 1925 | //调用接口判断优惠, | 1925 | //调用接口判断优惠, |
| 1926 | - var m_res=await getApp().request.promiseGet("/api/weshop/goods/getGoodsPromListNew1/" + os.stoid + "/" + gd.goods_id + "/0" + "/" + user_id, {}); | 1926 | + var m_res=await getApp().request.promiseGet("/api/weshop/goods/getGoodsPromListNew1/" + os.stoid + "/" + item1.goods_id + "/0" + "/" + user_id, {}); |
| 1927 | if(m_res && m_res.data.code == 0 && m_res.data.data){ | 1927 | if(m_res && m_res.data.code == 0 && m_res.data.data){ |
| 1928 | 1928 | ||
| 1929 | var r_data = res.data.data; | 1929 | var r_data = res.data.data; |
| @@ -7230,7 +7230,6 @@ Page({ | @@ -7230,7 +7230,6 @@ Page({ | ||
| 7230 | if (cart_commission) { | 7230 | if (cart_commission) { |
| 7231 | th.setData({ cart_commission }); | 7231 | th.setData({ cart_commission }); |
| 7232 | } | 7232 | } |
| 7233 | - | ||
| 7234 | th.data.old_cartlist = cart_arr; | 7233 | th.data.old_cartlist = cart_arr; |
| 7235 | }, | 7234 | }, |
| 7236 | 7235 | ||
| @@ -7245,5 +7244,4 @@ Page({ | @@ -7245,5 +7244,4 @@ Page({ | ||
| 7245 | return false; | 7244 | return false; |
| 7246 | } | 7245 | } |
| 7247 | 7246 | ||
| 7248 | - | ||
| 7249 | }); | 7247 | }); |
pages/cart/cart/cart.js
| @@ -57,6 +57,7 @@ Page({ | @@ -57,6 +57,7 @@ Page({ | ||
| 57 | async buy_pro_group(item1, is_state) { | 57 | async buy_pro_group(item1, is_state) { |
| 58 | //-- 代发商品不参与任何活动 -- | 58 | //-- 代发商品不参与任何活动 -- |
| 59 | if(item1.whsle_id) return false; | 59 | if(item1.whsle_id) return false; |
| 60 | + var th=this; | ||
| 60 | var url = '/api/weshop/activitylist/listGoodActInfo2New'; | 61 | var url = '/api/weshop/activitylist/listGoodActInfo2New'; |
| 61 | var user_id = getApp().globalData.user_id; | 62 | var user_id = getApp().globalData.user_id; |
| 62 | var zh_id = 0; | 63 | var zh_id = 0; |
| @@ -69,11 +70,11 @@ Page({ | @@ -69,11 +70,11 @@ Page({ | ||
| 69 | "user_id": user_id, | 70 | "user_id": user_id, |
| 70 | } | 71 | } |
| 71 | 72 | ||
| 72 | - await getApp().request.promiseGet(url, {data: req_d}).then(res => { | 73 | + await getApp().request.promiseGet(url, {data: req_d}).then(e => { |
| 73 | if (e.data.code == 0 && e.data.data && e.data.data.length > 0) { | 74 | if (e.data.code == 0 && e.data.data && e.data.data.length > 0) { |
| 74 | var arr = e.data.data; | 75 | var arr = e.data.data; |
| 75 | if (arr.length) { | 76 | if (arr.length) { |
| 76 | - arr3 = arr.filter(function (e) { | 77 | + var arr3 = arr.filter(function (e) { |
| 77 | return e.s_time < ut.gettimestamp() && e.prom_type == 7; | 78 | return e.s_time < ut.gettimestamp() && e.prom_type == 7; |
| 78 | }) | 79 | }) |
| 79 | if (arr3 && arr3.length) { | 80 | if (arr3 && arr3.length) { |
| @@ -127,6 +128,10 @@ Page({ | @@ -127,6 +128,10 @@ Page({ | ||
| 127 | 128 | ||
| 128 | //-- 如果满足条件,才会显示活动 -- | 129 | //-- 如果满足条件,才会显示活动 -- |
| 129 | if (is_zh_ok) { | 130 | if (is_zh_ok) { |
| 131 | + | ||
| 132 | + //-- 组合的数组填充一下 -- | ||
| 133 | + th.data.zuhe_map[zh_pro0.id] = zh_pro0; | ||
| 134 | + | ||
| 130 | var url1 = "/api/weshop/prom/zhbuyGoods/page"; | 135 | var url1 = "/api/weshop/prom/zhbuyGoods/page"; |
| 131 | var req_data = { | 136 | var req_data = { |
| 132 | page: 1, pageSize: 2000, | 137 | page: 1, pageSize: 2000, |
| @@ -143,7 +148,7 @@ Page({ | @@ -143,7 +148,7 @@ Page({ | ||
| 143 | }) | 148 | }) |
| 144 | 149 | ||
| 145 | var zh_gd_fd = gdlist.find(function (e) { | 150 | var zh_gd_fd = gdlist.find(function (e) { |
| 146 | - return e.goods_id == item.goods_id; | 151 | + return e.goods_id == item1.goods_id; |
| 147 | }) | 152 | }) |
| 148 | 153 | ||
| 149 | if (is_zh_ok) { | 154 | if (is_zh_ok) { |
| @@ -181,7 +186,7 @@ Page({ | @@ -181,7 +186,7 @@ Page({ | ||
| 181 | if (is_state == 1) { | 186 | if (is_state == 1) { |
| 182 | //-- 看有没有必买商品不满足的时候 -- | 187 | //-- 看有没有必买商品不满足的时候 -- |
| 183 | var f_gd = gdlist.find(function (e) { | 188 | var f_gd = gdlist.find(function (e) { |
| 184 | - return e.zhqty > 0 && e.goods_id != item.goods_id; | 189 | + return e.zhqty > 0 && e.goods_id != item1.goods_id; |
| 185 | }) | 190 | }) |
| 186 | if (f_gd) { | 191 | if (f_gd) { |
| 187 | is_zh_ok = 0; | 192 | is_zh_ok = 0; |
| @@ -202,10 +207,10 @@ Page({ | @@ -202,10 +207,10 @@ Page({ | ||
| 202 | } | 207 | } |
| 203 | 208 | ||
| 204 | //调用接口判断优惠, | 209 | //调用接口判断优惠, |
| 205 | - var m_res=await getApp().request.promiseGet("/api/weshop/goods/getGoodsPromListNew1/" + os.stoid + "/" + gd.goods_id + "/0" + "/" + user_id, {}); | 210 | + var m_res=await getApp().request.promiseGet("/api/weshop/goods/getGoodsPromListNew1/" + os.stoid + "/" + item1.goods_id + "/0" + "/" + user_id, {}); |
| 206 | if(m_res && m_res.data.code == 0 && m_res.data.data){ | 211 | if(m_res && m_res.data.code == 0 && m_res.data.data){ |
| 207 | 212 | ||
| 208 | - var r_data = res.data.data; | 213 | + var r_data = m_res.data.data; |
| 209 | //-- 如果是搭配购的时候 -- | 214 | //-- 如果是搭配购的时候 -- |
| 210 | if (r_data.collocationList) { | 215 | if (r_data.collocationList) { |
| 211 | if(!item1.more_cx) item1.more_cx=[]; | 216 | if(!item1.more_cx) item1.more_cx=[]; |
| @@ -217,10 +222,28 @@ Page({ | @@ -217,10 +222,28 @@ Page({ | ||
| 217 | //-- 判断会员能不能参与阶梯促销 -- | 222 | //-- 判断会员能不能参与阶梯促销 -- |
| 218 | await getApp().request.promiseGet("/api/weshop/prom/ladderForm/getNew/" + os.stoid + "/" + user_id + "/" + act_id, {}).then(res => { | 223 | await getApp().request.promiseGet("/api/weshop/prom/ladderForm/getNew/" + os.stoid + "/" + user_id + "/" + act_id, {}).then(res => { |
| 219 | if (res.data.code == 0 && res.data.data) { | 224 | if (res.data.code == 0 && res.data.data) { |
| 225 | + th.data.ladder_map[act_id] = res.data.data; | ||
| 220 | if(!item1.more_cx) item1.more_cx=[]; | 226 | if(!item1.more_cx) item1.more_cx=[]; |
| 221 | item1.more_cx.push({prom_type:10,prom_id: act_id}); | 227 | item1.more_cx.push({prom_type:10,prom_id: act_id}); |
| 222 | } | 228 | } |
| 223 | }) | 229 | }) |
| 230 | + | ||
| 231 | + if(th.data.ladder_map[act_id]){ | ||
| 232 | + //-- 获取阶梯规则 -- | ||
| 233 | + var url1 = "/api/weshop/prom/ladderList/list"; | ||
| 234 | + var req_data0 = { | ||
| 235 | + store_id: os.stoid, | ||
| 236 | + form_id: act_id, | ||
| 237 | + } | ||
| 238 | + await getApp().request.promiseGet(url1, { | ||
| 239 | + data: req_data0 | ||
| 240 | + }).then(rs1 => { | ||
| 241 | + if (rs1.data.code == 0 && rs1.data.data) { | ||
| 242 | + var gdlist = rs1.data.data; | ||
| 243 | + th.data.ladder_map[act_id].ladder_list = gdlist; | ||
| 244 | + } | ||
| 245 | + }) | ||
| 246 | + } | ||
| 224 | } | 247 | } |
| 225 | //-- 优惠促销的时候 -- 此时要注意活动的限购次数,以及活动的购买金额或者购买数量有没有满足 | 248 | //-- 优惠促销的时候 -- 此时要注意活动的限购次数,以及活动的购买金额或者购买数量有没有满足 |
| 226 | if (r_data.promGoodsLists) { | 249 | if (r_data.promGoodsLists) { |
| @@ -246,7 +269,7 @@ Page({ | @@ -246,7 +269,7 @@ Page({ | ||
| 246 | } | 269 | } |
| 247 | }else{ | 270 | }else{ |
| 248 | //-- 按数量进行计算 -- | 271 | //-- 按数量进行计算 -- |
| 249 | - var all_price = item.goods_price * item1.goods_num; | 272 | + var all_price = item1.goods_price * item1.goods_num; |
| 250 | if (parseFloat(fir_act.condition) > parseFloat(parseFloat(all_price).toFixed(2))) { | 273 | if (parseFloat(fir_act.condition) > parseFloat(parseFloat(all_price).toFixed(2))) { |
| 251 | item1.more_cx.push(push_item); | 274 | item1.more_cx.push(push_item); |
| 252 | } | 275 | } |
| @@ -260,7 +283,6 @@ Page({ | @@ -260,7 +283,6 @@ Page({ | ||
| 260 | } | 283 | } |
| 261 | } | 284 | } |
| 262 | 285 | ||
| 263 | - | ||
| 264 | }, | 286 | }, |
| 265 | 287 | ||
| 266 | onLoad: function () { | 288 | onLoad: function () { |
| @@ -306,6 +328,7 @@ Page({ | @@ -306,6 +328,7 @@ Page({ | ||
| 306 | var is_open_offline = json_d.is_pricing_open; | 328 | var is_open_offline = json_d.is_pricing_open; |
| 307 | th.setData({ | 329 | th.setData({ |
| 308 | bconfig: e, | 330 | bconfig: e, |
| 331 | + json_d:json_d, | ||
| 309 | freight_free: e.freight_free, | 332 | freight_free: e.freight_free, |
| 310 | weight_free: e.weight_free, | 333 | weight_free: e.weight_free, |
| 311 | sales_rules: e.sales_rules, | 334 | sales_rules: e.sales_rules, |
| @@ -639,6 +662,9 @@ Page({ | @@ -639,6 +662,9 @@ Page({ | ||
| 639 | var th = this; | 662 | var th = this; |
| 640 | th.data.in_zhact_gdmap = {}; | 663 | th.data.in_zhact_gdmap = {}; |
| 641 | th.data.ladder_map = {}; | 664 | th.data.ladder_map = {}; |
| 665 | + th.data.zuhe_map={}; | ||
| 666 | + th.data.zuhe_map_good={}; | ||
| 667 | + | ||
| 642 | var rd = Math.random().toString(36).substr(2, 15); | 668 | var rd = Math.random().toString(36).substr(2, 15); |
| 643 | var user_id = getApp().globalData.user_id; | 669 | var user_id = getApp().globalData.user_id; |
| 644 | 670 | ||
| @@ -1999,9 +2025,6 @@ Page({ | @@ -1999,9 +2025,6 @@ Page({ | ||
| 1999 | all_num = 0; | 2025 | all_num = 0; |
| 2000 | 2026 | ||
| 2001 | 2027 | ||
| 2002 | - th.data.zuhe_map={}; | ||
| 2003 | - th.data.zuhe_map_good={}; | ||
| 2004 | - | ||
| 2005 | //-- 购物车 -- | 2028 | //-- 购物车 -- |
| 2006 | if (car && car.length > 0) { | 2029 | if (car && car.length > 0) { |
| 2007 | th.data.in_zhact_gdmap = {}; | 2030 | th.data.in_zhact_gdmap = {}; |
| @@ -2009,95 +2032,109 @@ Page({ | @@ -2009,95 +2032,109 @@ Page({ | ||
| 2009 | 2032 | ||
| 2010 | var item = car[a].goods, is_s_sele = 1; | 2033 | var item = car[a].goods, is_s_sele = 1; |
| 2011 | //-- 先批量判断一下活动的类型,同时要同步跟新 -- | 2034 | //-- 先批量判断一下活动的类型,同时要同步跟新 -- |
| 2012 | - await th.cart_cx_group(item,a); | ||
| 2013 | - | ||
| 2014 | - var offline_price = 0; | ||
| 2015 | - var offline_num = 0; | ||
| 2016 | - for (var c = 0; c < item.length; c++) { | ||
| 2017 | - if (item[c].is_gift) continue; | ||
| 2018 | - all_num += item[c].goods_num; | ||
| 2019 | - | ||
| 2020 | - //不管怎么样都要移出去 | ||
| 2021 | - var obj = JSON.parse(JSON.stringify(item[c])); | ||
| 2022 | - zh_calc.remove_zhprom(car, a, obj); | ||
| 2023 | - ladder_calc.remove_ladder_prom(car, a, obj); | ||
| 2024 | - | ||
| 2025 | - if (item[c].selected == 0) { | ||
| 2026 | - ischeck = 0; | ||
| 2027 | - is_s_sele = 0; | ||
| 2028 | - if (item[c].prom_type == 7) { | ||
| 2029 | - obj.goods_num = 0; | ||
| 2030 | - zh_calc.add_zhprom(car, a, obj); | 2035 | + await th.cart_cx_group(item,car[a],(show_can_cx)=>{ |
| 2036 | + var offline_price = 0; | ||
| 2037 | + var offline_num = 0; | ||
| 2038 | + for (var c = 0; c < item.length; c++) { | ||
| 2039 | + if (item[c].is_gift) continue; | ||
| 2040 | + all_num += item[c].goods_num; | ||
| 2041 | + | ||
| 2042 | + if(item[c].prom_type==7){ | ||
| 2043 | + item[c].act=th.data.zuhe_map[item[c].prom_id]; | ||
| 2031 | } | 2044 | } |
| 2032 | - if (item[c].prom_type == 10) { | ||
| 2033 | - obj.goods_num = 0; | ||
| 2034 | - ladder_calc.add_ladder_prom(car, a, obj); | 2045 | + if(item[c].prom_type==10){ |
| 2046 | + item[c].act=th.data.ladder_map[item[c].prom_id]; | ||
| 2035 | } | 2047 | } |
| 2036 | 2048 | ||
| 2049 | + //不管怎么样都要移出去 | ||
| 2050 | + var obj = JSON.parse(JSON.stringify(item[c])); | ||
| 2051 | + zh_calc.remove_zhprom(car, a, obj); | ||
| 2052 | + ladder_calc.remove_ladder_prom(car, a, obj); | ||
| 2053 | + | ||
| 2054 | + if (item[c].selected == 0) { | ||
| 2055 | + ischeck = 0; | ||
| 2056 | + is_s_sele = 0; | ||
| 2057 | + if (item[c].prom_type == 7) { | ||
| 2058 | + obj.goods_num = 0; | ||
| 2059 | + zh_calc.add_zhprom(car, a, obj); | ||
| 2060 | + } | ||
| 2061 | + if (item[c].prom_type == 10) { | ||
| 2062 | + obj.goods_num = 0; | ||
| 2063 | + ladder_calc.add_ladder_prom(car, a, obj); | ||
| 2064 | + } | ||
| 2037 | 2065 | ||
| 2038 | - } else { | ||
| 2039 | - if (item[c].prom_type == 7) { | ||
| 2040 | - //先把商品放入组合计算的专用的区域 | ||
| 2041 | - console.log('是组合商品---') | ||
| 2042 | - console.log(car); | ||
| 2043 | - console.log(a) | ||
| 2044 | - console.log(obj) | ||
| 2045 | - console.log('......................') | ||
| 2046 | - zh_calc.add_zhprom(car, a, obj); | ||
| 2047 | - } else if (item[c].prom_type == 10) { | ||
| 2048 | - ladder_calc.add_ladder_prom(car, a, obj); | ||
| 2049 | - } | ||
| 2050 | - else { | ||
| 2051 | - tfeel += item[c].goods_num * item[c].goods_price; | 2066 | + |
| 2067 | + } else { | ||
| 2068 | + if (item[c].prom_type == 7) { | ||
| 2069 | + //先把商品放入组合计算的专用的区域 | ||
| 2070 | + console.log('是组合商品---') | ||
| 2071 | + console.log(car); | ||
| 2072 | + console.log(a) | ||
| 2073 | + console.log(obj) | ||
| 2074 | + console.log('......................') | ||
| 2075 | + zh_calc.add_zhprom(car, a, obj); | ||
| 2076 | + } else if (item[c].prom_type == 10) { | ||
| 2077 | + ladder_calc.add_ladder_prom(car, a, obj); | ||
| 2078 | + } | ||
| 2079 | + else { | ||
| 2080 | + tfeel += item[c].goods_num * item[c].goods_price; | ||
| 2081 | + } | ||
| 2082 | + t_num += item[c].goods_num; | ||
| 2052 | } | 2083 | } |
| 2053 | - t_num += item[c].goods_num; | ||
| 2054 | - } | ||
| 2055 | 2084 | ||
| 2056 | - //-- 如果这个商品是线下取价的时候 -- | ||
| 2057 | - if (item[c].is_offline && item[c].prom_type != 7) { | ||
| 2058 | - offline_price += (item[c].goods_price - item[c].offline_price) * item[c].goods_num; | ||
| 2059 | - offline_num += item[c].goods_num; | 2085 | + //-- 如果这个商品是线下取价的时候 -- |
| 2086 | + if (item[c].is_offline && item[c].prom_type != 7) { | ||
| 2087 | + offline_price += (item[c].goods_price - item[c].offline_price) * item[c].goods_num; | ||
| 2088 | + offline_num += item[c].goods_num; | ||
| 2089 | + } | ||
| 2060 | } | 2090 | } |
| 2061 | - } | ||
| 2062 | 2091 | ||
| 2063 | - //总的价格,把组合商品的价格拿出来 | ||
| 2064 | - var zh_calc_res = zh_calc.calculate_zh(car, a, th); | ||
| 2065 | - console.log('.组合价-----------') | ||
| 2066 | - console.log(zh_calc_res) | ||
| 2067 | - //总的价格,把阶梯促销商品的价格拿出来 | ||
| 2068 | - var ladder_calc_res = ladder_calc.calculate_ladder(car, a, th); | 2092 | + //总的价格,把组合商品的价格拿出来 |
| 2093 | + var zh_calc_res = zh_calc.calculate_zh(car, a, th); | ||
| 2094 | + console.log('.组合价-----------') | ||
| 2095 | + console.log(zh_calc_res) | ||
| 2096 | + //总的价格,把阶梯促销商品的价格拿出来 | ||
| 2097 | + var ladder_calc_res = ladder_calc.calculate_ladder(car, a, th); | ||
| 2069 | 2098 | ||
| 2070 | - tfeel += zh_calc_res.tfeel; | ||
| 2071 | - offline_price += zh_calc_res.offline_price; | ||
| 2072 | - offline_num += zh_calc_res.offline_num; | 2099 | + tfeel += zh_calc_res.tfeel; |
| 2100 | + offline_price += zh_calc_res.offline_price; | ||
| 2101 | + offline_num += zh_calc_res.offline_num; | ||
| 2073 | 2102 | ||
| 2074 | - tfeel += ladder_calc_res.tfeel; | ||
| 2075 | - offline_price += ladder_calc_res.offline_price; | ||
| 2076 | - offline_num += ladder_calc_res.offline_num; | 2103 | + tfeel += ladder_calc_res.tfeel; |
| 2104 | + offline_price += ladder_calc_res.offline_price; | ||
| 2105 | + offline_num += ladder_calc_res.offline_num; | ||
| 2077 | 2106 | ||
| 2078 | - var txt = "requestData[" + a + "].selected"; | ||
| 2079 | - th.setData({ | ||
| 2080 | - [txt]: Number(is_s_sele) | ||
| 2081 | - }); | 2107 | + var txt = "requestData[" + a + "].selected"; |
| 2108 | + th.setData({ | ||
| 2109 | + [txt]: Number(is_s_sele) | ||
| 2110 | + }); | ||
| 2082 | 2111 | ||
| 2083 | - //当有线下取价的时候 | ||
| 2084 | - if (offline_price) { | ||
| 2085 | - var txt1 = "requestData[" + a + "].offline_price"; | ||
| 2086 | - var txt2 = "requestData[" + a + "].offline_num"; | 2112 | + var txt1 = "requestData[" + a + "].show_can_cx"; |
| 2087 | th.setData({ | 2113 | th.setData({ |
| 2088 | - [txt1]: offline_price.toFixed(2), | ||
| 2089 | - [txt2]: offline_num, | 2114 | + [txt1]: show_can_cx |
| 2090 | }); | 2115 | }); |
| 2091 | - } else { | ||
| 2092 | - if (car[a].offline_price > 0) { | 2116 | + |
| 2117 | + //当有线下取价的时候 | ||
| 2118 | + if (offline_price) { | ||
| 2093 | var txt1 = "requestData[" + a + "].offline_price"; | 2119 | var txt1 = "requestData[" + a + "].offline_price"; |
| 2094 | var txt2 = "requestData[" + a + "].offline_num"; | 2120 | var txt2 = "requestData[" + a + "].offline_num"; |
| 2095 | th.setData({ | 2121 | th.setData({ |
| 2096 | - [txt1]: 0, | ||
| 2097 | - [txt2]: 0 | 2122 | + [txt1]: offline_price.toFixed(2), |
| 2123 | + [txt2]: offline_num, | ||
| 2098 | }); | 2124 | }); |
| 2125 | + } else { | ||
| 2126 | + if (car[a].offline_price > 0) { | ||
| 2127 | + var txt1 = "requestData[" + a + "].offline_price"; | ||
| 2128 | + var txt2 = "requestData[" + a + "].offline_num"; | ||
| 2129 | + th.setData({ | ||
| 2130 | + [txt1]: 0, | ||
| 2131 | + [txt2]: 0 | ||
| 2132 | + }); | ||
| 2133 | + } | ||
| 2099 | } | 2134 | } |
| 2100 | - } | 2135 | + }); |
| 2136 | + | ||
| 2137 | + | ||
| 2101 | 2138 | ||
| 2102 | } | 2139 | } |
| 2103 | } | 2140 | } |
| @@ -2126,6 +2163,9 @@ Page({ | @@ -2126,6 +2163,9 @@ Page({ | ||
| 2126 | th.setData({ | 2163 | th.setData({ |
| 2127 | [txt]: Number(is_s_sele) | 2164 | [txt]: Number(is_s_sele) |
| 2128 | }); | 2165 | }); |
| 2166 | + | ||
| 2167 | + | ||
| 2168 | + | ||
| 2129 | } | 2169 | } |
| 2130 | } | 2170 | } |
| 2131 | 2171 | ||
| @@ -4297,16 +4337,76 @@ Page({ | @@ -4297,16 +4337,76 @@ Page({ | ||
| 4297 | }, | 4337 | }, |
| 4298 | 4338 | ||
| 4299 | //-- 判读一下促销分组的问题 -- | 4339 | //-- 判读一下促销分组的问题 -- |
| 4300 | - async cart_cx_group(goods,index){ | 4340 | + async cart_cx_group(goods,car_item,func){ |
| 4341 | + | ||
| 4342 | + if(car_item.change_act){ | ||
| 4343 | + | ||
| 4344 | + car_item.change_act=0; | ||
| 4345 | + var show_can_cx=car_item.show_can_cx; | ||
| 4346 | + | ||
| 4347 | + for(var k in show_can_cx){ | ||
| 4348 | + var k_item=show_can_cx[k]; | ||
| 4349 | + var ck_prom_type=null; | ||
| 4350 | + //-- 如果是多活动,先把活动按照后台的顺序排序一下, | ||
| 4351 | + //-- 同时确定一下商品最终要用什么活动来购买计算。 --就是要进行切换 -- | ||
| 4352 | + if(k_item.act_arr.length>1){ | ||
| 4353 | + var json_d =this.data.json_d; | ||
| 4354 | + var auto_promote_sale=json_d.auto_promote_sale; | ||
| 4355 | + var sort_type=''; | ||
| 4356 | + | ||
| 4357 | + if(!auto_promote_sale){ | ||
| 4358 | + sort_type='prom_type'; | ||
| 4359 | + }else{ | ||
| 4360 | + var auto_promote_sale=auto_promote_sale.split(','); | ||
| 4361 | + //-- 循环处理 -- | ||
| 4362 | + k_item.act_arr.map(function (e){ | ||
| 4363 | + var fd=auto_promote_sale.indexOf(e.prom_type+''); | ||
| 4364 | + e.sort=fd; | ||
| 4365 | + }) | ||
| 4366 | + sort_type='sort'; | ||
| 4367 | + } | ||
| 4368 | + //-- 排序一下,进行升序 -- | ||
| 4369 | + function comp(a, b) { | ||
| 4370 | + return a[sort_type]-b[sort_type]; //升序 | ||
| 4371 | + } | ||
| 4372 | + //活动要排序一下 | ||
| 4373 | + k_item.act_arr.sort(comp); | ||
| 4374 | + | ||
| 4375 | + //确定一下活动,先看一下有没有选择的活动 | ||
| 4376 | + ck_prom_type=k_item.act_arr.find(function (el){ | ||
| 4377 | + return el.sele; | ||
| 4378 | + }) | ||
| 4379 | + | ||
| 4380 | + } | ||
| 4381 | + //-- 此时已经确定了商品的活动是什么类型的,可以确定购物车中商品的具体活动进行金额的计算 -- | ||
| 4382 | + if(!ck_prom_type) ck_prom_type=k_item.act_arr[0]; | ||
| 4383 | + | ||
| 4384 | + //-- 此时要把购物车中的商品确定活动 -- | ||
| 4385 | + for (var b=0; b<ck_prom_type.goods.length;b++){ | ||
| 4386 | + //-- 开始查找 -- | ||
| 4387 | + var fg=goods.findIndex(function (g_item){ | ||
| 4388 | + return g_item.goods_id==ck_prom_type.goods[b].goods_id && [0,3,5,7,10].indexOf(g_item.prom_type)>-1; | ||
| 4389 | + }) | ||
| 4390 | + if(fg>-1){ | ||
| 4391 | + goods[fg].prom_type=ck_prom_type.prom_type; | ||
| 4392 | + goods[fg].prom_id=ck_prom_type.prom_id; | ||
| 4393 | + } | ||
| 4394 | + } | ||
| 4395 | + | ||
| 4396 | + } | ||
| 4397 | + | ||
| 4398 | + func(show_can_cx); | ||
| 4399 | + } | ||
| 4400 | + | ||
| 4301 | var th=this; | 4401 | var th=this; |
| 4302 | - //-- 促销活动对象表 --- | 4402 | + //-- 促销活动对象表,最初的map表,包含活动类型,活动id,goods商品 --- |
| 4303 | var cx_act_map=[]; | 4403 | var cx_act_map=[]; |
| 4304 | for(var i=0; i<goods.length;i++){ | 4404 | for(var i=0; i<goods.length;i++){ |
| 4305 | var c_item=goods[i]; | 4405 | var c_item=goods[i]; |
| 4306 | //没有选中 | 4406 | //没有选中 |
| 4307 | if(!c_item.selected) continue; | 4407 | if(!c_item.selected) continue; |
| 4308 | //如果是秒杀之类是商品 | 4408 | //如果是秒杀之类是商品 |
| 4309 | - if([1,2,4,6,8,9].indexOf(c_item.prom_type)) continue; | 4409 | + if([1,2,4,6,8,9].indexOf(c_item.prom_type)>-1) continue; |
| 4310 | 4410 | ||
| 4311 | //-- 把活动进行规整 -- | 4411 | //-- 把活动进行规整 -- |
| 4312 | var more_cx=c_item.more_cx; | 4412 | var more_cx=c_item.more_cx; |
| @@ -4319,7 +4419,7 @@ Page({ | @@ -4319,7 +4419,7 @@ Page({ | ||
| 4319 | if(fd){ | 4419 | if(fd){ |
| 4320 | fd.goods.push(c_item); | 4420 | fd.goods.push(c_item); |
| 4321 | }else{ | 4421 | }else{ |
| 4322 | - var p_item={key:key,prom_type:c_item.prom_type,prom_id:c_item.prom_id,goods:[],act:n_item}; | 4422 | + var p_item={key:key,prom_type:n_item.prom_type,prom_id:n_item.prom_id,goods:[],act:n_item}; |
| 4323 | p_item.goods.push(c_item); | 4423 | p_item.goods.push(c_item); |
| 4324 | cx_act_map.push(p_item); | 4424 | cx_act_map.push(p_item); |
| 4325 | } | 4425 | } |
| @@ -4327,16 +4427,13 @@ Page({ | @@ -4327,16 +4427,13 @@ Page({ | ||
| 4327 | goods[i].prom_type=0; | 4427 | goods[i].prom_type=0; |
| 4328 | goods[i].prom_id=0; | 4428 | goods[i].prom_id=0; |
| 4329 | } | 4429 | } |
| 4330 | - | ||
| 4331 | //-- 如果活动数量大于1个,那么活动就要排序一下,有商品种类数最多排再前面,降序进行排列 -- | 4430 | //-- 如果活动数量大于1个,那么活动就要排序一下,有商品种类数最多排再前面,降序进行排列 -- |
| 4332 | if(cx_act_map.length>1){ | 4431 | if(cx_act_map.length>1){ |
| 4333 | //门店分类要排序下 | 4432 | //门店分类要排序下 |
| 4334 | - function compare() { | ||
| 4335 | - return function (a, b) { | 4433 | + function compare(a, b) { |
| 4336 | var value1 = a.goods.length; | 4434 | var value1 = a.goods.length; |
| 4337 | var value2 = b.goods.length; | 4435 | var value2 = b.goods.length; |
| 4338 | return value2 - value1; | 4436 | return value2 - value1; |
| 4339 | - } | ||
| 4340 | } | 4437 | } |
| 4341 | cx_act_map.sort(compare); | 4438 | cx_act_map.sort(compare); |
| 4342 | } | 4439 | } |
| @@ -4347,8 +4444,8 @@ Page({ | @@ -4347,8 +4444,8 @@ Page({ | ||
| 4347 | 4444 | ||
| 4348 | var item_act_map=cx_act_map[ii]; | 4445 | var item_act_map=cx_act_map[ii]; |
| 4349 | //如果活动有交集的时候,商品数量一样多(不是完全相同时,就是参与的商品有交集),就按照后台确定的活动顺序 | 4446 | //如果活动有交集的时候,商品数量一样多(不是完全相同时,就是参与的商品有交集),就按照后台确定的活动顺序 |
| 4350 | - //如果活动的商品一样(那就是多活动切换),优先计算的活动按照后台确定的活动顺序 | ||
| 4351 | //如果活动商品数量少的和 活动数量多的 有交集,那么数量少的不显示,也不计算 | 4447 | //如果活动商品数量少的和 活动数量多的 有交集,那么数量少的不显示,也不计算 |
| 4448 | + //如果活动的商品一样(那就是多活动切换),优先计算的活动按照后台确定的活动顺序 | ||
| 4352 | if(!th.check_ok_cx_pro(item_act_map,can_calc_cx)){ | 4449 | if(!th.check_ok_cx_pro(item_act_map,can_calc_cx)){ |
| 4353 | continue; | 4450 | continue; |
| 4354 | } | 4451 | } |
| @@ -4363,6 +4460,24 @@ Page({ | @@ -4363,6 +4460,24 @@ Page({ | ||
| 4363 | all_pri+=t_goods[f].goods_num*t_goods[f].goods_price; | 4460 | all_pri+=t_goods[f].goods_num*t_goods[f].goods_price; |
| 4364 | } | 4461 | } |
| 4365 | 4462 | ||
| 4463 | + var yh_ok=1; | ||
| 4464 | + switch (fir_act.prom_type){ | ||
| 4465 | + case 0: | ||
| 4466 | + if(all_pri<fir_act.condition) { | ||
| 4467 | + yh_ok=0; | ||
| 4468 | + } | ||
| 4469 | + break; | ||
| 4470 | + case 1: | ||
| 4471 | + if(all_num<fir_act.condition) { | ||
| 4472 | + yh_ok=0; | ||
| 4473 | + } | ||
| 4474 | + break; | ||
| 4475 | + } | ||
| 4476 | + | ||
| 4477 | + //-- 如果有满足优惠条件的时候 -- | ||
| 4478 | + if(yh_ok){ | ||
| 4479 | + can_calc_cx.push(item_act_map) | ||
| 4480 | + } | ||
| 4366 | break | 4481 | break |
| 4367 | case 7: | 4482 | case 7: |
| 4368 | //-- 活动列表 -- | 4483 | //-- 活动列表 -- |
| @@ -4379,7 +4494,7 @@ Page({ | @@ -4379,7 +4494,7 @@ Page({ | ||
| 4379 | user_id: getApp().globalData.user_id, | 4494 | user_id: getApp().globalData.user_id, |
| 4380 | goods_id: zh_goods[h].goods_id, | 4495 | goods_id: zh_goods[h].goods_id, |
| 4381 | prom_type: 7, | 4496 | prom_type: 7, |
| 4382 | - prom_id: zh_id | 4497 | + prom_id: item_act_map.prom_id |
| 4383 | }, | 4498 | }, |
| 4384 | }) | 4499 | }) |
| 4385 | if(res.data.code==0 && res.data.data && res.data.data.promgoodsbuynum){ | 4500 | if(res.data.code==0 && res.data.data && res.data.data.promgoodsbuynum){ |
| @@ -4388,12 +4503,13 @@ Page({ | @@ -4388,12 +4503,13 @@ Page({ | ||
| 4388 | zh_goods[h].zh_b_num=promgoodsbuynum; | 4503 | zh_goods[h].zh_b_num=promgoodsbuynum; |
| 4389 | } | 4504 | } |
| 4390 | //-- 放到map中 -- | 4505 | //-- 放到map中 -- |
| 4391 | - th.data.zuhe_map[item.prom_id] = act; | ||
| 4392 | - th.data.zuhe_map_good[item.prom_id] = zhact_gdlist; | 4506 | + th.data.zuhe_map_good[item_act_map.prom_id] = zhact_gdlist; |
| 4507 | + if(!car_item.zh_prom_goods) car_item.zh_prom_goods={}; | ||
| 4508 | + car_item.zh_prom_goods[item_act_map.prom_id] = zhact_gdlist; | ||
| 4393 | 4509 | ||
| 4394 | var zh_pro0 = null; | 4510 | var zh_pro0 = null; |
| 4395 | //-- 获取活动信息 -- | 4511 | //-- 获取活动信息 -- |
| 4396 | - var url = "/api/weshop/prom/zhbuy/get/" + os.stoid + "/" + zh_id + "/" + getApp().globalData.user_id; | 4512 | + var url = "/api/weshop/prom/zhbuy/get/" + os.stoid + "/" + item_act_map.prom_id + "/" + getApp().globalData.user_id; |
| 4397 | await getApp().request.promiseGet(url, {}).then(rh => { | 4513 | await getApp().request.promiseGet(url, {}).then(rh => { |
| 4398 | zh_pro0 = rh.data.data; | 4514 | zh_pro0 = rh.data.data; |
| 4399 | }) | 4515 | }) |
| @@ -4409,13 +4525,116 @@ Page({ | @@ -4409,13 +4525,116 @@ Page({ | ||
| 4409 | 4525 | ||
| 4410 | } | 4526 | } |
| 4411 | 4527 | ||
| 4528 | + //-- 此时来给满足条件的活动进行分组~~相同参与商品和数量的归纳再一起, -- | ||
| 4529 | + //-- 同时相同商品数量的活动,还要看取那一个来进行计算金额。 默认的时候是按照后台的顺序。-- | ||
| 4530 | + //-- 有选择的时候,就按照切换选择了什么就按照什么来计算 -- | ||
| 4531 | + var show_can_cx={}; | ||
| 4412 | if(can_calc_cx.length){ | 4532 | if(can_calc_cx.length){ |
| 4413 | - | 4533 | + for(var p=0;p<can_calc_cx.length;p++){ |
| 4534 | + var ch_map=[]; | ||
| 4535 | + can_calc_cx[p].goods.map(function (gd){ | ||
| 4536 | + ch_map.push(gd.goods_id); | ||
| 4537 | + }) | ||
| 4538 | + ch_map.sort(); | ||
| 4539 | + //-- 先找一下,有没有参与的商品一模一样的 -- | ||
| 4540 | + var fd=show_can_cx[ch_map.join()]; | ||
| 4541 | + if(fd){ | ||
| 4542 | + //-- 把数组添加进去 --ch_map | ||
| 4543 | + fd.act_arr.push(can_calc_cx[p]) | ||
| 4544 | + }else{ | ||
| 4545 | + var e={ch_map:ch_map,act_arr:[]}; | ||
| 4546 | + e.act_arr.push(can_calc_cx[p]); | ||
| 4547 | + show_can_cx[ch_map.join()]=e; | ||
| 4548 | + } | ||
| 4549 | + } | ||
| 4414 | } | 4550 | } |
| 4415 | 4551 | ||
| 4416 | - th.setData({can_calc_cx}) | ||
| 4417 | - } | 4552 | + for(var k in show_can_cx){ |
| 4553 | + var k_item=show_can_cx[k]; | ||
| 4554 | + var ck_prom_type=null; | ||
| 4555 | + //-- 如果是多活动,先把活动按照后台的顺序排序一下, | ||
| 4556 | + //-- 同时确定一下商品最终要用什么活动来购买计算。 --就是要进行切换 -- | ||
| 4557 | + if(k_item.act_arr.length>1){ | ||
| 4558 | + var json_d =this.data.json_d; | ||
| 4559 | + var auto_promote_sale=json_d.auto_promote_sale; | ||
| 4560 | + var sort_type=''; | ||
| 4561 | + | ||
| 4562 | + if(!auto_promote_sale){ | ||
| 4563 | + sort_type='prom_type'; | ||
| 4564 | + }else{ | ||
| 4565 | + var auto_promote_sale=auto_promote_sale.split(','); | ||
| 4566 | + //-- 循环处理 -- | ||
| 4567 | + k_item.act_arr.map(function (e){ | ||
| 4568 | + var fd=auto_promote_sale.indexOf(e.prom_type+''); | ||
| 4569 | + e.sort=fd; | ||
| 4570 | + }) | ||
| 4571 | + sort_type='sort'; | ||
| 4572 | + } | ||
| 4573 | + //-- 排序一下,进行升序 -- | ||
| 4574 | + function comp(a, b) { | ||
| 4575 | + return a[sort_type]-b[sort_type]; //升序 | ||
| 4576 | + } | ||
| 4577 | + //活动要排序一下 | ||
| 4578 | + k_item.act_arr.sort(comp); | ||
| 4579 | + | ||
| 4580 | + //确定一下活动,先看一下有没有选择的活动 | ||
| 4581 | + ck_prom_type=k_item.act_arr.find(function (el){ | ||
| 4582 | + return el.sele; | ||
| 4583 | + }) | ||
| 4584 | + | ||
| 4585 | + } | ||
| 4586 | + //-- 此时已经确定了商品的活动是什么类型的,可以确定购物车中商品的具体活动进行金额的计算 -- | ||
| 4587 | + if(!ck_prom_type) ck_prom_type=k_item.act_arr[0]; | ||
| 4588 | + | ||
| 4589 | + //-- 此时要把购物车中的商品确定活动 -- | ||
| 4590 | + for (var b=0; b<ck_prom_type.goods.length;b++){ | ||
| 4591 | + //-- 开始查找 -- | ||
| 4592 | + var fg=goods.findIndex(function (g_item){ | ||
| 4593 | + return g_item.goods_id==ck_prom_type.goods[b].goods_id && [0,3,5,7,10].indexOf(g_item.prom_type)>-1; | ||
| 4594 | + }) | ||
| 4595 | + if(fg>-1){ | ||
| 4596 | + goods[fg].prom_type=ck_prom_type.prom_type; | ||
| 4597 | + goods[fg].prom_id=ck_prom_type.prom_id; | ||
| 4598 | + } | ||
| 4599 | + } | ||
| 4418 | 4600 | ||
| 4601 | + } | ||
| 4419 | 4602 | ||
| 4603 | + //-- 显示到前端,并切换 -- | ||
| 4604 | + //th.setData({show_can_cx}) | ||
| 4605 | + //--- 调用回调函数 --- | ||
| 4606 | + func(show_can_cx); | ||
| 4607 | + }, | ||
| 4608 | + //-- 查看活动参与的商品是不是有重复交集的地方,是不是一样的商品数量,can_calc_cx这个数组也是按照商品的数量降序排列的-- | ||
| 4609 | + check_ok_cx_pro(item_act_map,can_calc_cx){ | ||
| 4610 | + //-- 加入第一个,返回真 -- | ||
| 4611 | + if(!can_calc_cx.length) return true; | ||
| 4612 | + var th_goods=item_act_map.goods; | ||
| 4613 | + for(var i=0;i<can_calc_cx.length;i++){ | ||
| 4614 | + var can_goods=can_calc_cx[i].goods; | ||
| 4615 | + //计算一下有交集的数量,没有交集,OK | ||
| 4616 | + var num=this.hasJiao(can_goods,th_goods); | ||
| 4617 | + if(!num) continue; | ||
| 4618 | + //计算一下俩个shu | ||
| 4619 | + if(can_goods.length==th_goods.length && can_goods.length==num){ | ||
| 4620 | + return true; | ||
| 4621 | + } | ||
| 4622 | + if(can_goods.length>th_goods.length){ | ||
| 4623 | + return false; | ||
| 4624 | + } | ||
| 4625 | + } | ||
| 4626 | + return true; | ||
| 4627 | + }, | ||
| 4628 | + //-- 判断是不是有交集,返回交集的数量 -- | ||
| 4629 | + hasJiao(arr1, arr2){ | ||
| 4630 | + var num=0; | ||
| 4631 | + arr1.map(function (e){ | ||
| 4632 | + var idx=arr2.findIndex(function (g){ | ||
| 4633 | + return g.goods_id==e.goods_id; | ||
| 4634 | + }) | ||
| 4635 | + if(idx>-1) num++; | ||
| 4636 | + }) | ||
| 4637 | + return num; | ||
| 4638 | + } | ||
| 4420 | 4639 | ||
| 4421 | }); | 4640 | }); |
| 4422 | \ No newline at end of file | 4641 | \ No newline at end of file |
pages/cart/cart/cart.wxml
| @@ -38,7 +38,7 @@ | @@ -38,7 +38,7 @@ | ||
| 38 | 38 | ||
| 39 | <!-- 商品的列表 --> | 39 | <!-- 商品的列表 --> |
| 40 | <block wx:if="{{requestData && requestData.length>0}}"> | 40 | <block wx:if="{{requestData && requestData.length>0}}"> |
| 41 | - <block wx:for="{{requestData}}" wx:key="{{index}}" wx:for-index="pidx"> | 41 | + <block wx:for="{{requestData}}" wx:key="{{index}}" wx:for-item="item" wx:for-index="pidx"> |
| 42 | <!-- 门店底下的商品 --> | 42 | <!-- 门店底下的商品 --> |
| 43 | <view class="store"> | 43 | <view class="store"> |
| 44 | <view class="shmd_m"> | 44 | <view class="shmd_m"> |
| @@ -53,75 +53,101 @@ | @@ -53,75 +53,101 @@ | ||
| 53 | </view> | 53 | </view> |
| 54 | 54 | ||
| 55 | </view> | 55 | </view> |
| 56 | - <view class="order-item" data-item="{{idx}}" wx:for="{{item.goods}}" wx:for-item="items" wx:for-index="idx" wx:key="{{index}}"> | ||
| 57 | - <block wx:if="{{!items.is_gift}}"> | ||
| 58 | - <view bindtap="check_th_item" class="order-raido flex-vertical " data-check="{{items.selected}}" data-item="{{idx}}" data-pitems="{{pidx}}"> | ||
| 59 | - <!--<radio color="red" checked="{{checkAllToggle||items.selected}}"></radio>--> | ||
| 60 | - <icon wx:if="{{checkAllToggle||items.selected}}" color="red" size="20" type="success"></icon> | ||
| 61 | - <text wx:else class="icon_no_sele"></text> | ||
| 62 | - </view> | ||
| 63 | - </block> | ||
| 64 | - <block wx:else><view class="order-raido flex-vertical " style="width: 45rpx"></view></block> | ||
| 65 | 56 | ||
| 66 | - <navigator class="goods-img rel" bindtap="go_gd" data-item="{{items}}" data-gd="{{items.goods_id}}"> | ||
| 67 | - <image class="wh100" src="{{items.original_img}}" binderror="bind_bnerr2" data-errorimg="requestData[{{pidx}}].goods[{{idx}}].original_img" data-url="{{items.original_img}}"></image> | ||
| 68 | - <block wx:if="{{items.is_gift}}"> | ||
| 69 | - <view style="background-color:red" class="abs flex-center fs26" wx:if="{{items.is_gift==1}}">赠品</view> | ||
| 70 | - </block> | ||
| 71 | - <block wx:else> | ||
| 72 | - <view class="abs flex-center fs26" wx:if="{{items.distr_type==0}}">自选</view> | ||
| 73 | - <view class="abs flex-center fs26" wx:if="{{items.distr_type==1}}">自提</view> | ||
| 74 | - <view class="abs flex-center fs26" wx:if="{{items.distr_type==2}}">物流</view> | ||
| 75 | - </block> | ||
| 76 | - | ||
| 77 | - <block wx:if="{{items.prom_type==7}}"> | ||
| 78 | - <block wx:if="{{items.selected}}"> | ||
| 79 | - <!-- 主要显示限购 --> | ||
| 80 | - <text wx:if="{{items.zhqty>items.goods_num}}" class="abs2">还需购买{{items.zhqty-items.goods_num}}件</text> | ||
| 81 | - </block> | ||
| 82 | - <block wx:else> | ||
| 83 | - <text wx:if="{{items.zhqty}}" class="abs2">需购买{{items.zhqty}}件</text> | 57 | + <block wx:for="{{item.goods}}" wx:for-item="items" wx:for-index="idx" wx:key="{{index}}"> |
| 58 | + <view class="order-item" data-item="{{idx}}"> | ||
| 59 | + <block wx:if="{{!items.is_gift}}"> | ||
| 60 | + <view bindtap="check_th_item" class="order-raido flex-vertical " data-check="{{items.selected}}" data-item="{{idx}}" data-pitems="{{pidx}}"> | ||
| 61 | + <!--<radio color="red" checked="{{checkAllToggle||items.selected}}"></radio>--> | ||
| 62 | + <icon wx:if="{{checkAllToggle||items.selected}}" color="red" size="20" type="success"></icon> | ||
| 63 | + <text wx:else class="icon_no_sele"></text> | ||
| 64 | + </view> | ||
| 84 | </block> | 65 | </block> |
| 85 | - </block> | 66 | + <block wx:else><view class="order-raido flex-vertical " style="width: 45rpx"></view></block> |
| 86 | 67 | ||
| 68 | + <navigator class="goods-img rel" bindtap="go_gd" data-item="{{items}}" data-gd="{{items.goods_id}}"> | ||
| 69 | + <image class="wh100" src="{{items.original_img}}" binderror="bind_bnerr2" data-errorimg="requestData[{{pidx}}].goods[{{idx}}].original_img" data-url="{{items.original_img}}"></image> | ||
| 70 | + <block wx:if="{{items.is_gift}}"> | ||
| 71 | + <view style="background-color:red" class="abs flex-center fs26" wx:if="{{items.is_gift==1}}">赠品</view> | ||
| 72 | + </block> | ||
| 73 | + <block wx:else> | ||
| 74 | + <view class="abs flex-center fs26" wx:if="{{items.distr_type==0}}">自选</view> | ||
| 75 | + <view class="abs flex-center fs26" wx:if="{{items.distr_type==1}}">自提</view> | ||
| 76 | + <view class="abs flex-center fs26" wx:if="{{items.distr_type==2}}">物流</view> | ||
| 77 | + </block> | ||
| 87 | 78 | ||
| 88 | - </navigator> | ||
| 89 | - <view class="goods-cont"> | ||
| 90 | - <view class="goods-name"> | ||
| 91 | - <navigator bindtap="go_gd" class="ellipsis-2 fs30" data-item="{{items}}" data-gd="{{items.goods_id}}">{{items.goods_name}}</navigator> | 79 | + <block wx:if="{{items.prom_type==7}}"> |
| 80 | + <block wx:if="{{items.selected}}"> | ||
| 81 | + <!-- 主要显示限购 --> | ||
| 82 | + <text wx:if="{{items.zhqty>items.goods_num}}" class="abs2">还需购买{{items.zhqty-items.goods_num}}件</text> | ||
| 83 | + </block> | ||
| 84 | + <block wx:else> | ||
| 85 | + <text wx:if="{{items.zhqty}}" class="abs2">需购买{{items.zhqty}}件</text> | ||
| 86 | + </block> | ||
| 87 | + </block> | ||
| 92 | 88 | ||
| 93 | - <view class="specifications ellipsis-1"> | ||
| 94 | - <view wx:if="{{items.goods_color || items.goods_spec}}"> | ||
| 95 | - {{items.goods_color}}{{items.goods_color?"/":''}}{{items.goods_spec}}</view> | ||
| 96 | - <view wx:else>规格1</view> | ||
| 97 | - </view> | ||
| 98 | - <block wx:if="{{items.is_gift}}"> | ||
| 99 | - <view>{{items.goods_num}}件</view> | ||
| 100 | - </block> | ||
| 101 | - <view wx:if="{{items.buyqty>0}}" class="fs22 ml10 c-7b">组合限购{{items.buyqty}}件</view> | ||
| 102 | - </view> | ||
| 103 | 89 | ||
| 90 | + </navigator> | ||
| 91 | + <view class="goods-cont"> | ||
| 92 | + <view class="goods-name"> | ||
| 93 | + <navigator bindtap="go_gd" class="ellipsis-2 fs30" data-item="{{items}}" data-gd="{{items.goods_id}}">{{items.goods_name}}</navigator> | ||
| 104 | 94 | ||
| 105 | - <block wx:if="{{!items.is_gift}}"> | ||
| 106 | - <view class="flex alend jc_sb"> | ||
| 107 | - <view class="goods-price co-red baseline ellipsis-1"> | ||
| 108 | - <view class="fs20">¥</view> | ||
| 109 | - <view class="fs28">{{items.goods_price}}</view> | 95 | + <view class="specifications ellipsis-1"> |
| 96 | + <view wx:if="{{items.goods_color || items.goods_spec}}"> | ||
| 97 | + {{items.goods_color}}{{items.goods_color?"/":''}}{{items.goods_spec}}</view> | ||
| 98 | + <view wx:else>规格1</view> | ||
| 99 | + </view> | ||
| 100 | + <block wx:if="{{items.is_gift}}"> | ||
| 101 | + <view>{{items.goods_num}}件</view> | ||
| 102 | + </block> | ||
| 103 | + <view wx:if="{{items.buyqty>0}}" class="fs22 ml10 c-7b">组合限购{{items.buyqty}}件</view> | ||
| 104 | + </view> | ||
| 110 | 105 | ||
| 111 | - <view wx:if="{{items.is_offline}}" class="quan_color flex ai-center"><text>券后 ¥{{g_filter.toFix(items.offline_price,2)}}</text></view> | ||
| 112 | 106 | ||
| 107 | + <block wx:if="{{!items.is_gift}}"> | ||
| 108 | + <view class="flex alend jc_sb"> | ||
| 109 | + <view class="goods-price co-red baseline ellipsis-1"> | ||
| 110 | + <view class="fs20">¥</view> | ||
| 111 | + <view class="fs28">{{items.goods_price}}</view> | ||
| 113 | 112 | ||
| 114 | - </view> | ||
| 115 | - <view class="count"> | ||
| 116 | - <view bindtap="{{items.goods_num <= 1 ? '':'subNum'}}" class="sub fs28 {{items.goods_num <= 1 ? 'active':''}}" data-pitems="{{pidx}}" data-item="{{idx}}">一</view> | ||
| 117 | - <input class="goodadd" bindblur="valueToNum" data-pitems="{{pidx}}" data-item="{{idx}}" | ||
| 118 | - bindinput="refresh_input" type="number" value="{{items.goods_num}}"></input> | ||
| 119 | - <view class="add" bindtap="addNum" data-pitems="{{pidx}}" data-item="{{idx}}">+</view> | ||
| 120 | - </view> | 113 | + <view wx:if="{{items.is_offline}}" class="quan_color flex ai-center"><text>券后 ¥{{g_filter.toFix(items.offline_price,2)}}</text></view> |
| 114 | + | ||
| 115 | + | ||
| 116 | + </view> | ||
| 117 | + <view class="count"> | ||
| 118 | + <view bindtap="{{items.goods_num <= 1 ? '':'subNum'}}" class="sub fs28 {{items.goods_num <= 1 ? 'active':''}}" data-pitems="{{pidx}}" data-item="{{idx}}">一</view> | ||
| 119 | + <input class="goodadd" bindblur="valueToNum" data-pitems="{{pidx}}" data-item="{{idx}}" | ||
| 120 | + bindinput="refresh_input" type="number" value="{{items.goods_num}}"></input> | ||
| 121 | + <view class="add" bindtap="addNum" data-pitems="{{pidx}}" data-item="{{idx}}">+</view> | ||
| 122 | + </view> | ||
| 123 | + </view> | ||
| 124 | + </block> | ||
| 125 | + </view> | ||
| 121 | </view> | 126 | </view> |
| 122 | - </block> | ||
| 123 | - </view> | ||
| 124 | - </view> | 127 | + |
| 128 | + <!-- 验证活动是不是多个,要不要显示切换 --> | ||
| 129 | + <!-- 新增促销多活动的排版 --> | ||
| 130 | + <view class="bdt16" | ||
| 131 | + 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}}"> | ||
| 132 | + <view data-coupon="1" bindtap="switch_cx_group" class="cx-frame flex" style="position: relative"> | ||
| 133 | + <view class="cx-sizs fs30">促销</view> | ||
| 134 | + <view class="flex ai_c f1 pdh20"> | ||
| 135 | + <view class="xc-coupon-fram" wx:for="{{item.show_can_cx[items.goods_id].act_arr}}" > | ||
| 136 | + <view wx:if="{{item.prom_type==3}}" class="xc-coupon t-c four-level-word">优惠促销</view> | ||
| 137 | + <view wx:if="{{item.prom_type==5}}" class="xc-coupon t-c four-level-word">搭配促销</view> | ||
| 138 | + <view wx:if="{{item.prom_type==7}}" class="xc-coupon t-c four-level-word">组合购</view> | ||
| 139 | + <view wx:if="{{item.prom_type==10}}" class="xc-coupon t-c four-level-word">阶梯促销</view> | ||
| 140 | + </view> | ||
| 141 | + </view> | ||
| 142 | + <view class="cx-obtain-coupon wsize"> | ||
| 143 | + <text class="bg_jj"></text> | ||
| 144 | + </view> | ||
| 145 | + </view> | ||
| 146 | + </view> | ||
| 147 | + | ||
| 148 | + </block > | ||
| 149 | + | ||
| 150 | + | ||
| 125 | </view> | 151 | </view> |
| 126 | <!--- 去凑单 --> | 152 | <!--- 去凑单 --> |
| 127 | <view style="margin-top: 20rpx; padding: 0 30rpx"> | 153 | <view style="margin-top: 20rpx; padding: 0 30rpx"> |
pages/cart/cart/cart.wxss
| @@ -399,3 +399,80 @@ page { | @@ -399,3 +399,80 @@ page { | ||
| 399 | text-align: center; line-height: 30rpx; | 399 | text-align: center; line-height: 30rpx; |
| 400 | left: 0;bottom: 0;color: #fff; font-size: 20rpx; | 400 | left: 0;bottom: 0;color: #fff; font-size: 20rpx; |
| 401 | } | 401 | } |
| 402 | + | ||
| 403 | + | ||
| 404 | +.cx-frame { | ||
| 405 | + /* border-top:3rpx solid #eee; */ | ||
| 406 | + /* width:99%; | ||
| 407 | + height: 95rpx; | ||
| 408 | + line-height: 95rpx; | ||
| 409 | + padding-left:24rpx; */ | ||
| 410 | + padding: 20rpx; | ||
| 411 | +} | ||
| 412 | + | ||
| 413 | +.cx-frame .cx-sizs { | ||
| 414 | + /* width: 68rpx; */ | ||
| 415 | + /* height: 100%; */ | ||
| 416 | + /* line-height: 100rpx; */ | ||
| 417 | + /* overflow: hidden; */ | ||
| 418 | + /* margin-left: 10rpx; */ | ||
| 419 | +} | ||
| 420 | + | ||
| 421 | +.xc-coupon-fram { | ||
| 422 | + position: relative; | ||
| 423 | + margin-right: 16rpx; | ||
| 424 | + /* width:200rpx; */ | ||
| 425 | + /* padding-top:30rpx; */ | ||
| 426 | + | ||
| 427 | +} | ||
| 428 | + | ||
| 429 | +.xc-coupon-fram .xc-coupon { | ||
| 430 | + /* width:175rpx ; | ||
| 431 | + height: 40rpx; | ||
| 432 | + line-height: 40rpx; */ | ||
| 433 | + background-color: #d60021; | ||
| 434 | + /* margin:0 auto; */ | ||
| 435 | + color: #fff; | ||
| 436 | + padding: 6rpx 20rpx; | ||
| 437 | + | ||
| 438 | +} | ||
| 439 | + | ||
| 440 | +.xc-coupon-fram .xc-circular { | ||
| 441 | + width: 16rpx; | ||
| 442 | + height: 16rpx; | ||
| 443 | + background-color: white; | ||
| 444 | + position: absolute; | ||
| 445 | + top: 50%; | ||
| 446 | + /* left: -10rpx; */ | ||
| 447 | + transform: translateY(-50%); | ||
| 448 | +} | ||
| 449 | + | ||
| 450 | +.cx-obtain-coupon { | ||
| 451 | + /* width: 65rpx; | ||
| 452 | + height: 100%; | ||
| 453 | + padding-left:15rpx; */ | ||
| 454 | + color: #d70025; | ||
| 455 | + display: flex; | ||
| 456 | + align-items: center; | ||
| 457 | + /* position: absolute; | ||
| 458 | + right: 5rpx; */ | ||
| 459 | +} | ||
| 460 | + | ||
| 461 | +.bg_jj { | ||
| 462 | + width: 14rpx; | ||
| 463 | + height: 14rpx; | ||
| 464 | + border-top: 2rpx solid #d70026; | ||
| 465 | + border-right: 2rpx solid #d70026; | ||
| 466 | + transform: rotateZ(45deg); | ||
| 467 | + display: inline-block; | ||
| 468 | + margin-bottom: 3rpx; | ||
| 469 | +} | ||
| 470 | + | ||
| 471 | +.bg_jj.down { | ||
| 472 | + transform: rotateZ(135deg); | ||
| 473 | +} | ||
| 474 | + | ||
| 475 | +.bg_jj.up { | ||
| 476 | + transform: rotateZ(-45deg); | ||
| 477 | + margin-top: 6rpx; | ||
| 478 | +} |
pages/cart/cart/g_filter.wxs
| @@ -28,11 +28,19 @@ var g_filters = { | @@ -28,11 +28,19 @@ var g_filters = { | ||
| 28 | } | 28 | } |
| 29 | val = parseFloat(val); | 29 | val = parseFloat(val); |
| 30 | return val.toFixed(count) | 30 | return val.toFixed(count) |
| 31 | - } | 31 | + }, |
| 32 | + | ||
| 33 | + //判断商品是不是有活动切换 | ||
| 34 | + is_more_act:function (items,show_can_cx){ | ||
| 35 | + if([1,2,4,6,8,9].indexOf(items.prom_type)>-1) return false; | ||
| 36 | + if(!show_can_cx) return false; | ||
| 37 | + return true; | ||
| 38 | + } | ||
| 32 | } | 39 | } |
| 33 | module.exports = { | 40 | module.exports = { |
| 34 | has_char: g_filters.has_char, | 41 | has_char: g_filters.has_char, |
| 35 | beg_time: g_filters.beg_time, | 42 | beg_time: g_filters.beg_time, |
| 36 | end_time: g_filters.end_time, | 43 | end_time: g_filters.end_time, |
| 37 | toFix: g_filters.toFix, | 44 | toFix: g_filters.toFix, |
| 45 | + is_more_act: g_filters.is_more_act, | ||
| 38 | } | 46 | } |
| 39 | \ No newline at end of file | 47 | \ No newline at end of file |
pages/cart/cart/zh_calculate.js
| @@ -534,10 +534,12 @@ module.exports = { | @@ -534,10 +534,12 @@ module.exports = { | ||
| 534 | return 0; | 534 | return 0; |
| 535 | } | 535 | } |
| 536 | var goods =gdlist; | 536 | var goods =gdlist; |
| 537 | + var all_num=0; | ||
| 538 | + var need_to_buy=0; | ||
| 537 | for (var i in goods) { | 539 | for (var i in goods) { |
| 538 | var item = goods[i]; | 540 | var item = goods[i]; |
| 539 | var cart_num = get_num(item).goods_num; | 541 | var cart_num = get_num(item).goods_num; |
| 540 | - var zh_b_num = get_num2(item).zh_b_num; | 542 | + var zh_b_num = get_num(item).zh_b_num; |
| 541 | if (!cart_num) { | 543 | if (!cart_num) { |
| 542 | if (item.zhqty) { | 544 | if (item.zhqty) { |
| 543 | need_to_buy += item.zhqty; | 545 | need_to_buy += item.zhqty; |
pages/goods/goodsInfo/goodsInfo.js
| @@ -3026,7 +3026,7 @@ Page({ | @@ -3026,7 +3026,7 @@ Page({ | ||
| 3026 | this.sele_spec_chech_activity(nor); | 3026 | this.sele_spec_chech_activity(nor); |
| 3027 | 3027 | ||
| 3028 | //如果是秒杀,拼团等互动,就不重新算界面 | 3028 | //如果是秒杀,拼团等互动,就不重新算界面 |
| 3029 | - if([1,2,4,6,8,9].indexOf(this.data.base_nor_prom_type)>0){ return false; } | 3029 | + if([1,2,4,6,8,9].indexOf(this.data.base_nor_prom_type)>-1){ return false; } |
| 3030 | 3030 | ||
| 3031 | this.check_has_flash(gid); | 3031 | this.check_has_flash(gid); |
| 3032 | var url = '/api/weshop/activitylist/listGoodActInfo2New'; | 3032 | var url = '/api/weshop/activitylist/listGoodActInfo2New'; |