Buy_1.php 75 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615
  1. <?php
  2. namespace app\common\logic;
  3. use think\facade\Db;
  4. /**
  5. * ============================================================================
  6. * DSMall多用户商城
  7. * ============================================================================
  8. * 版权所有 2014-2028 长沙德尚网络科技有限公司,并保留所有权利。
  9. * 网站地址: http://www.csdeshang.com
  10. * ----------------------------------------------------------------------------
  11. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
  12. * 不允许对程序代码以任何形式任何目的的再发布。
  13. * ============================================================================
  14. * 逻辑层模型
  15. */
  16. class Buy_1
  17. {
  18. public $lock = false;//是否加锁
  19. /**
  20. * 取得商品最新的属性及促销[购物车]
  21. * @param unknown $cart_list
  22. */
  23. public function getGoodsCartList($cart_list)
  24. {
  25. $cart_list = $this->_getOnlineCartList($cart_list);
  26. //优惠套装
  27. $this->_getBundlingCartList($cart_list);
  28. //会员等级折扣
  29. $this->getMgdiscountCartList($cart_list);
  30. //抢购
  31. $this->getGroupbuyCartList($cart_list);
  32. //限时折扣
  33. $this->getXianshiCartList($cart_list);
  34. //预售
  35. $this->getPresellCartList($cart_list);
  36. //批发
  37. $this->getWholesaleCartList($cart_list);
  38. //赠品
  39. $this->_getGiftCartList($cart_list);
  40. return $cart_list;
  41. }
  42. /**
  43. * 取得商品最新的属性及促销[立即购买]
  44. * @param type $goods_id
  45. * @param type $quantity
  46. * @param type $extra
  47. * @return array
  48. */
  49. public function getGoodsOnlineInfo($goods_id, $quantity, $extra = [], $member_id = 0)
  50. {
  51. $goods_info = $this->_getGoodsOnlineInfo($goods_id, $quantity);
  52. if (isset($extra['pintuan_id']) && intval($extra['pintuan_id']) > 0) {
  53. //如果是特定拼团商品,则只按照拼团的规则进行处理
  54. $this->getPintuanInfo($goods_info, $goods_info['goods_num'], $extra, $member_id);
  55. } else if (isset($extra['bargainorder_id']) && intval($extra['bargainorder_id']) > 0) {
  56. $this->getBargainInfo($goods_info, $goods_info['goods_num'], $extra);
  57. } else {
  58. //会员等级折扣
  59. $this->getMgdiscountInfo($goods_info);
  60. //抢购
  61. $this->getGroupbuyInfo($goods_info, $goods_info['goods_num']);
  62. //限时折扣
  63. $this->getXianshiInfo($goods_info, $goods_info['goods_num']);
  64. //预售
  65. $this->getPresellInfo($goods_info, $goods_info['goods_num']);
  66. //批发
  67. $this->getWholesaleInfo($goods_info, $goods_info['goods_num']);
  68. //赠品
  69. $this->_getGoodsgiftList($goods_info);
  70. }
  71. return $goods_info;
  72. }
  73. /**
  74. * 商品金额计算(分别对每个商品/优惠套装小计、每个店铺小计)
  75. * @param unknown $store_cart_list 以店铺ID分组的购物车商品信息
  76. * @return array
  77. */
  78. public function calcCartList($store_cart_list)
  79. {
  80. if (empty($store_cart_list) || !is_array($store_cart_list))
  81. return [$store_cart_list, [], 0];
  82. //存放每个店铺的商品总金额
  83. $store_goods_total = [];
  84. //存放本次下单所有店铺商品总金额
  85. $order_goods_total = 0;
  86. foreach ($store_cart_list as $store_id => $store_cart) {
  87. $tmp_amount = 0;
  88. $tmp_amount2 = 0;
  89. $tmp_amount3 = 0;
  90. foreach ($store_cart as $key => $cart_info) {
  91. $store_cart[$key]['goods_original_total'] = ds_price_format($cart_info['goods_original_price'] * $cart_info['goods_num']); //商品原价
  92. $store_cart[$key]['goods_total'] = ds_price_format($cart_info['goods_price'] * $cart_info['goods_num']);
  93. $store_cart[$key]['goods_discount_total'] = ds_price_format($store_cart[$key]['goods_original_total'] - $store_cart[$key]['goods_total']); //优惠金额
  94. $store_cart[$key]['goods_image_url'] = goods_cthumb($store_cart[$key]['goods_image']);
  95. $tmp_amount += $store_cart[$key]['goods_total'];
  96. $tmp_amount2 += $store_cart[$key]['goods_original_total'];
  97. $tmp_amount3 += $store_cart[$key]['goods_discount_total'];
  98. }
  99. $store_cart_list[$store_id] = $store_cart;
  100. $store_goods_total[$store_id] = ds_price_format($tmp_amount);
  101. $store_goods_original_total[$store_id] = ds_price_format($tmp_amount2);
  102. $store_goods_discount_total[$store_id] = ds_price_format($tmp_amount3);
  103. }
  104. return [$store_cart_list, $store_goods_total, $store_goods_original_total, $store_goods_discount_total];
  105. }
  106. /**
  107. * 取得店铺级优惠 - 跟据商品金额返回每个店铺当前符合的一条活动规则,如果有赠品,则自动追加到购买列表,价格为0
  108. * @param unknown $store_goods_total 每个店铺的商品金额小计,以店铺ID为下标
  109. * @return array($premiums_list,$mansong_rule_list) 分别为赠品列表[下标自增],店铺满送规则列表[店铺ID为下标]
  110. */
  111. public function getMansongruleCartListByTotal($store_goods_total)
  112. {
  113. if (!config('ds_config.promotion_allow') || empty($store_goods_total) || !is_array($store_goods_total))
  114. return [[], []];
  115. $pmansong_model = model('pmansong');
  116. //定义赠品数组,下标为店铺ID
  117. $premiums_list = [];
  118. //定义满送活动数组,下标为店铺ID
  119. $mansong_rule_list = [];
  120. foreach ($store_goods_total as $store_id => $goods_total) {
  121. $rule_info = $pmansong_model->getMansongruleByStoreID($store_id, $goods_total);
  122. if (is_array($rule_info) && !empty($rule_info)) {
  123. //即不减金额,也找不到促销商品时(已下架),此规则无效
  124. if (empty($rule_info['mansongrule_discount']) && empty($rule_info['mansong_goods_name'])) {
  125. continue;
  126. }
  127. $rule_info['desc'] = $this->_parseMansongruleDesc($rule_info);
  128. $rule_info['discount'] = ds_price_format($rule_info['mansongrule_discount']);
  129. $mansong_rule_list[$store_id] = $rule_info;
  130. //如果赠品在售,有库存,则追加到购买列表
  131. if (!empty($rule_info['mansong_goods_name']) && !empty($rule_info['goods_storage'])) {
  132. $data = [];
  133. $data['goods_id'] = $rule_info['goods_id'];
  134. $data['goods_name'] = $rule_info['mansong_goods_name'];
  135. $data['goods_num'] = 1;
  136. $data['goods_price'] = 0.00;
  137. $data['goods_image'] = $rule_info['goods_image'];
  138. $data['goods_image_url'] = goods_cthumb($rule_info['goods_image']);
  139. $data['goods_storage'] = $rule_info['goods_storage'];
  140. $premiums_list[$store_id][] = $data;
  141. }
  142. }
  143. }
  144. return [$premiums_list, $mansong_rule_list];
  145. }
  146. /**
  147. * 重新计算每个店铺最终商品总金额(最初计算金额减去各种优惠/加运费)
  148. * @param array $store_goods_total 店铺商品总金额
  149. * @param array $preferential_array 店铺优惠活动内容
  150. * @param string $preferential_type 优惠类型,目前只有一个 'mansong'
  151. * @return array 返回扣除优惠后的店铺商品总金额
  152. */
  153. public function reCalcGoodsTotal($store_goods_total, $preferential_array, $preferential_type)
  154. {
  155. $deny = empty($store_goods_total) || !is_array($store_goods_total) || empty($preferential_array) || !is_array($preferential_array);
  156. if ($deny)
  157. return $store_goods_total;
  158. switch ($preferential_type) {
  159. case 'mansong':
  160. if (!config('ds_config.promotion_allow'))
  161. return $store_goods_total;
  162. foreach ($preferential_array as $store_id => $rule_info) {
  163. if (is_array($rule_info) && $rule_info['discount'] > 0) {
  164. $store_goods_total[$store_id] -= $rule_info['discount'];
  165. }
  166. }
  167. break;
  168. case 'voucher':
  169. if (!config('ds_config.voucher_allow'))
  170. return $store_goods_total;
  171. foreach ($preferential_array as $store_id => $voucher_info) {
  172. $store_goods_total[$store_id] -= $voucher_info['voucher_price'];
  173. }
  174. break;
  175. case 'freight':
  176. foreach ($preferential_array as $store_id => $freight_total) {
  177. $store_goods_total[$store_id] += $freight_total;
  178. }
  179. break;
  180. }
  181. return $store_goods_total;
  182. }
  183. /**
  184. * 取得店铺可用的代金券
  185. * @param array $store_goods_total array(店铺ID=>商品总金额)
  186. * @return array
  187. */
  188. public function getStoreAvailableVoucherList($store_goods_total, $member_id)
  189. {
  190. if (!config('ds_config.voucher_allow'))
  191. return [];
  192. $voucher_list = [];
  193. $voucher_model = model('voucher');
  194. foreach ($store_goods_total as $store_id => $goods_total) {
  195. $condition = [];
  196. $condition[] = ['voucher_store_id', '=', $store_id];
  197. $condition[] = ['voucher_owner_id', '=', $member_id];
  198. $voucher_list[$store_id] = $voucher_model->getCurrentAvailableVoucher($condition, $goods_total);
  199. }
  200. return $voucher_list;
  201. }
  202. /**
  203. * 验证传过来的代金券是否可用有效,如果无效,直接删除
  204. * @param array $input_voucher_list 代金券列表
  205. * @param array $store_goods_total (店铺ID=>商品总金额)
  206. * @return array
  207. */
  208. public function reParseVoucherList($input_voucher_list = [], $store_goods_total = [], $member_id)
  209. {
  210. if (empty($input_voucher_list) || !is_array($input_voucher_list))
  211. return [];
  212. $store_voucher_list = $this->getStoreAvailableVoucherList($store_goods_total, $member_id);
  213. foreach ($input_voucher_list as $store_id => $voucher) {
  214. $tmp = $store_voucher_list[$store_id];
  215. if (is_array($tmp) && isset($tmp[$voucher['vouchertemplate_id']])) {
  216. $input_voucher_list[$store_id]['voucher_price'] = $tmp[$voucher['vouchertemplate_id']]['voucher_price'];
  217. $input_voucher_list[$store_id]['voucher_id'] = $tmp[$voucher['vouchertemplate_id']]['voucher_id'];
  218. $input_voucher_list[$store_id]['voucher_code'] = $tmp[$voucher['vouchertemplate_id']]['voucher_code'];
  219. $input_voucher_list[$store_id]['voucher_owner_id'] = $tmp[$voucher['vouchertemplate_id']]['voucher_owner_id'];
  220. } else {
  221. unset($input_voucher_list[$store_id]);
  222. }
  223. }
  224. return $input_voucher_list;
  225. }
  226. /**
  227. * 判断商品是不是限时折扣中,如果购买数量若>=规定的下限,按折扣价格计算,否则按原价计算
  228. * @param array $goods_info
  229. * @param number $quantity 购买数量
  230. */
  231. public function getXianshiInfo(& $goods_info, $quantity)
  232. {
  233. if (empty($quantity))
  234. $quantity = 1;
  235. if (!config('ds_config.promotion_allow') || empty($goods_info['xianshi_info']))
  236. return;
  237. $goods_info['xianshi_info']['down_price'] = ds_price_format($goods_info['goods_price'] - $goods_info['xianshi_info']['xianshigoods_price']);
  238. if ($quantity >= $goods_info['xianshi_info']['xianshigoods_lower_limit']) {
  239. $goods_info['goods_price'] = $goods_info['xianshi_info']['xianshigoods_price'];
  240. $goods_info['promotions_id'] = $goods_info['xianshi_info']['xianshi_id'];
  241. $goods_info['ifxianshi'] = true;
  242. }
  243. }
  244. /**
  245. * 判断商品是不是预售
  246. * @param array $goods_info
  247. * @param number $quantity 购买数量
  248. */
  249. public function getPresellInfo(& $goods_info, $quantity)
  250. {
  251. if (empty($quantity))
  252. $quantity = 1;
  253. if (!config('ds_config.promotion_allow') || empty($goods_info['presell_info']))
  254. return;
  255. $goods_info['presell_info']['down_price'] = ds_price_format($goods_info['goods_price'] - $goods_info['presell_info']['presell_price']);
  256. $goods_info['goods_price'] = $goods_info['presell_info']['presell_price'];
  257. $goods_info['promotions_id'] = $goods_info['presell_info']['presell_id'];
  258. $goods_info['ifpresell'] = true;
  259. }
  260. /**
  261. * 判断商品是不是批发中,如果购买数量若>=规定的下限,按批发价格计算,否则按原价计算
  262. * @param array $goods_info
  263. * @param number $quantity 购买数量
  264. */
  265. public function getWholesaleInfo(& $goods_info, $quantity)
  266. {
  267. if (empty($quantity))
  268. $quantity = 1;
  269. if (!config('ds_config.promotion_allow') || empty($goods_info['wholesale_info']))
  270. return;
  271. $if_wholesale = false;
  272. foreach ($goods_info['wholesale_info']['wholesalegoods_price'] as $val) {
  273. if ($val['num'] <= $quantity) {
  274. $if_wholesale = true;
  275. $goods_info['wholesale_info']['down_price'] = ds_price_format($goods_info['goods_price'] - $val['price']);
  276. $goods_info['goods_price'] = $val['price'];
  277. }
  278. }
  279. if ($if_wholesale) {
  280. $goods_info['ifwholesale'] = true;
  281. $goods_info['promotions_id'] = $goods_info['wholesale_info']['wholesale_id'];
  282. }
  283. }
  284. /**
  285. * 判断商品是不是砍价中,如果购买数量若>=规定的下限,则报错
  286. * @param array $goods_info
  287. * @param number $quantity 购买数量
  288. */
  289. public function getBargainInfo(& $goods_info, $quantity, $extra)
  290. {
  291. $pbargain_model = model('pbargain');
  292. $pbargainorder_model = model('pbargainorder');
  293. //是否正在进行的砍价活动
  294. $pbargainorder_info = $pbargainorder_model->getOnePbargainorder(['bargainorder_id' => $extra['bargainorder_id'], 'bargainorder_state' => 2], true);
  295. if (!$pbargainorder_info) {
  296. return;
  297. }
  298. $bargain_info = $pbargain_model->getOnlineBargainInfoByID($pbargainorder_info['bargain_id']);
  299. if (!$bargain_info) {
  300. return;
  301. }
  302. //之前是否已添加过订单
  303. if (model('order')->getOrdergoodsInfo(['goods_type' => 8, 'promotions_id' => $pbargainorder_info['bargainorder_id']])) {
  304. return;
  305. }
  306. //购买数量是否超过限制数量
  307. if ($quantity > $bargain_info['bargain_limit']) {
  308. return;
  309. }
  310. $goods_info['goods_price'] = $pbargainorder_info['bargainorder_current_price'];
  311. $goods_info['promotions_id'] = $pbargainorder_info['bargainorder_id'];
  312. $goods_info['ifbargain'] = true;
  313. }
  314. /**
  315. * 判断商品是不是拼团中,如果购买数量若>=规定的下限,则报错
  316. * @param array $goods_info
  317. * @param number $quantity 购买数量
  318. */
  319. public function getPintuanInfo(& $goods_info, $quantity, $extra, $member_id)
  320. {
  321. if (empty($quantity))
  322. $quantity = 1;
  323. //超过了购买限制按照原价
  324. if ($goods_info['pintuan_info'] && ($quantity > $goods_info['pintuan_info']['pintuan_limit_quantity'])) {
  325. return;
  326. }
  327. $pintuangroup_id = intval($extra['pintuangroup_id']);
  328. if ($pintuangroup_id > 0) {
  329. //判断非开团拼团订单,判断参团人数是否满足
  330. $pintuangroup = model('ppintuangroup')->getOnePpintuangroup(['pintuangroup_id' => $pintuangroup_id]);
  331. if (empty($pintuangroup) || $pintuangroup['pintuangroup_state'] != 1) {
  332. //不存在,或者拼团活动状态 不为1
  333. return;
  334. }
  335. //当开团拼团订单表中参团人数大于成团人团则按照正常价格购买
  336. if ($pintuangroup['pintuangroup_joined'] >= $pintuangroup['pintuangroup_limit_number']) {
  337. return;
  338. }
  339. }
  340. //不可以重复参加
  341. $order_id_list = Db::name('ppintuanorder')->where([['pintuan_id', '=', $goods_info['pintuan_info']['pintuan_id']], ['pintuanorder_state', '<>', 0]])->column('order_id');
  342. if ($order_id_list) {
  343. if (!$goods_info['is_virtual']) {
  344. if (Db::name('order')->where('buyer_id', $member_id)->where('order_id', 'in', $order_id_list)->value('order_id')) {
  345. return;
  346. }
  347. } else {
  348. if (Db::name('vrorder')->where('buyer_id', $member_id)->where('order_id', 'in', $order_id_list)->value('order_id')) {
  349. return;
  350. }
  351. }
  352. }
  353. $goods_info['pintuan_info']['down_price'] = ds_price_format($goods_info['goods_price'] * (1 - $goods_info['pintuan_info']['pintuan_zhe']));
  354. $goods_info['goods_price'] = round(($goods_info['pintuan_info']['pintuan_zhe'] * $goods_info['goods_price']) / 10, 2);
  355. $goods_info['promotions_id'] = $goods_info['pintuan_info']['pintuan_id'];
  356. $goods_info['ifpintuan'] = true;
  357. }
  358. public function updatePintuan($post_data, $goods_info, $order, $order_type, $member_id)
  359. {
  360. $res = [];
  361. //拼团订单的特殊性,还需要额外的进行处理.
  362. $pintuangroup_id = intval($post_data['pintuangroup_id']);
  363. $pintuan_id = intval($post_data['pintuan_id']);
  364. $res['pintuangroup_id'] = $pintuangroup_id;
  365. $pintuanorder_isfirst = 0; #是否为首团订单
  366. if ($pintuangroup_id == 0) {
  367. //首团订单新增
  368. $data = [
  369. 'pintuan_id' => $pintuan_id,
  370. 'pintuangroup_goods_id' => $goods_info['goods_id'],
  371. 'pintuangroup_is_virtual' => $goods_info['is_virtual'],
  372. 'pintuangroup_joined' => 0,
  373. 'pintuangroup_limit_number' => $goods_info['pintuan_info']['pintuan_limit_number'],
  374. 'pintuangroup_limit_hour' => $goods_info['pintuan_info']['pintuan_limit_hour'],
  375. 'pintuangroup_headid' => $member_id,
  376. 'pintuangroup_starttime' => TIMESTAMP,
  377. ];
  378. $pintuangroup_id = model('ppintuangroup')->addPpintuangroup($data);
  379. $res['pintuangroup_id'] = $pintuangroup_id;
  380. $pintuanorder_isfirst = 1;
  381. }
  382. //新增订单
  383. $data = [
  384. 'pintuan_id' => $pintuan_id,
  385. 'pintuangroup_id' => $pintuangroup_id,
  386. 'order_id' => $order['order_id'],
  387. 'order_sn' => $order['order_sn'],
  388. 'pintuanorder_isfirst' => $pintuanorder_isfirst,
  389. 'pintuanorder_type' => $order_type,
  390. ];
  391. model('ppintuanorder')->addPpintuanorder($data);
  392. //下单后清除缓存
  393. model('ppintuan')->_dGoodsPintuanCache($goods_info['pintuan_info']['pintuan_goods_commonid']);
  394. return $res;
  395. }
  396. /**
  397. * 判断商品是不是享受会员等级折扣,
  398. * @param array $goods_info
  399. * @param number $level 会员等级
  400. */
  401. public function getMgdiscountInfo(& $goods_info)
  402. {
  403. $member_model = model('member');
  404. $member_info = $member_model->getMemberInfoByID(session('member_id'));
  405. if (!$member_info) {
  406. return;
  407. }
  408. $member_gradeinfo = $member_model->getOneMemberGrade(intval($member_info['member_exppoints']));
  409. if (!$member_gradeinfo) {
  410. return;
  411. }
  412. $level = intval($member_gradeinfo['level']);
  413. if (!config('ds_config.mgdiscount_allow') || empty($goods_info['mgdiscount_info']) || $level <= 0) {
  414. return;
  415. }
  416. $mgdiscount = $goods_info['mgdiscount_info'][$level];
  417. if (empty($mgdiscount)) {
  418. return;
  419. } else {
  420. if ($mgdiscount['level_discount'] < 10) {
  421. $goods_info['goods_price'] = round(($mgdiscount['level_discount'] * $goods_info['goods_price']) / 10, 2);
  422. $goods_info['mgdiscount_desc'] = '会员享受' . $mgdiscount['level_discount'] . '折';
  423. $goods_info['ifmgdiscount'] = true;
  424. }
  425. }
  426. }
  427. /**
  428. * 输出有货到付款时,在线支付和货到付款及每种支付下商品数量和详细列表
  429. * @param $buy_list 商品列表
  430. * @return 返回 以支付方式为下标分组的商品列表
  431. */
  432. public function getOfflineGoodsPay($buy_list)
  433. {
  434. //以支付方式为下标,存放购买商品
  435. $buy_goods_list = [];
  436. $offline_pay = model('payment')->getPaymentOpenInfo([['payment_code', '=', 'offline']]);
  437. if ($offline_pay) {
  438. //下单里包括平台自营商品并且平台已开启货到付款,则显示货到付款项及对应商品数量,取出支持货到付款的店铺ID组成的数组,目前就一个,DEFAULT_PLATFORM_STORE_ID
  439. $offline_store_id_array = model('store')->getOwnShopIds();
  440. foreach ($buy_list as $value) {
  441. if (in_array($value['store_id'], $offline_store_id_array)) {
  442. $buy_goods_list['offline'][] = $value;
  443. } else {
  444. $buy_goods_list['online'][] = $value;
  445. }
  446. }
  447. }
  448. return $buy_goods_list;
  449. }
  450. /**
  451. * 计算每个店铺(所有店铺级优惠活动)总共优惠多少金额
  452. * @param array $store_goods_total 最初店铺商品总金额
  453. * @param array $store_final_goods_total 去除各种店铺级促销后,最终店铺商品总金额(不含运费)
  454. * @return array
  455. */
  456. public function getStorePromotionTotal($store_goods_total, $store_final_goods_total)
  457. {
  458. if (!is_array($store_goods_total) || !is_array($store_final_goods_total))
  459. return [];
  460. $store_promotion_total = [];
  461. foreach ($store_goods_total as $store_id => $goods_total) {
  462. $store_promotion_total[$store_id] = abs($goods_total - $store_final_goods_total[$store_id]);
  463. }
  464. return $store_promotion_total;
  465. }
  466. /**
  467. * 返回需要计算运费的店铺ID组成的数组 和 免运费店铺ID及免运费下限金额描述
  468. * @param array $store_goods_total 每个店铺的商品金额小计,以店铺ID为下标
  469. * @return array
  470. */
  471. public function getStoreFreightDescList($store_goods_total)
  472. {
  473. if (empty($store_goods_total) || !is_array($store_goods_total))
  474. return [[], []];
  475. //定义返回数组
  476. $need_calc_sid_array = [];
  477. $cancel_calc_sid_array = [];
  478. //如果商品金额未达到免运费设置下线,则需要计算运费
  479. $condition = [];
  480. $condition[] = ['store_id', 'in', array_keys($store_goods_total)];
  481. $store_list = model('store')->getStoreOnlineList($condition, null, '', 'store_id,store_free_price');
  482. foreach ($store_list as $store_info) {
  483. $limit_price = floatval($store_info['store_free_price']);
  484. if ($limit_price == 0 || $limit_price > $store_goods_total[$store_info['store_id']]) {
  485. //需要计算运费
  486. $need_calc_sid_array[] = $store_info['store_id'];
  487. } else {
  488. //返回免运费金额下限
  489. $cancel_calc_sid_array[$store_info['store_id']]['free_price'] = $limit_price;
  490. $cancel_calc_sid_array[$store_info['store_id']]['desc'] = sprintf('满%s免运费', $limit_price);
  491. }
  492. }
  493. return [$need_calc_sid_array, $cancel_calc_sid_array];
  494. }
  495. /**
  496. * 取得店铺运费(使用运费模板的商品运费不会计算,但会返回模板信息)
  497. * 先将免运费的店铺运费置0,然后算出店铺里没使用运费模板的商品运费之和 ,存到iscalced下标中
  498. * 然后再计算使用运费模板的信息(array(店铺ID=>array(运费模板ID=>购买数量)),放到nocalced下标里
  499. * @param array $buy_list 购买商品列表
  500. * @param array $free_freight_sid_list 免运费的店铺ID数组
  501. */
  502. public function getStoreFreightList($buy_list = [], $free_freight_sid_list)
  503. {
  504. //定义返回数组
  505. $return = [];
  506. //先将免运费的店铺运费置0(格式:店铺ID=>0)
  507. $freight_list = [];
  508. if (!empty($free_freight_sid_list) && is_array($free_freight_sid_list)) {
  509. foreach ($free_freight_sid_list as $store_id) {
  510. $freight_list[$store_id] = 0;
  511. }
  512. }
  513. //然后算出店铺里没使用运费模板(优惠套装商品除外)的商品运费之和(格式:店铺ID=>运费)
  514. //定义数组,存放店铺优惠套装商品运费总额 store_id=>运费
  515. $store_bl_goods_freight = [];
  516. foreach ($buy_list as $key => $goods_info) {
  517. //免运费店铺的商品不需要计算
  518. if (in_array($goods_info['store_id'], $free_freight_sid_list)) {
  519. unset($buy_list[$key]);
  520. continue;
  521. }
  522. //优惠套装商品运费另算
  523. if (intval($goods_info['bl_id'])) {
  524. unset($buy_list[$key]);
  525. $store_bl_goods_freight[$goods_info['store_id']] = $goods_info['bl_id'];
  526. continue;
  527. }
  528. //自提商品不需要计算
  529. if ($goods_info['chain_id']) {
  530. $freight_list[$goods_info['store_id']] = 0;
  531. unset($buy_list[$key]);
  532. continue;
  533. }
  534. if (!intval($goods_info['transport_id']) && !in_array($goods_info['store_id'], $free_freight_sid_list)) {
  535. if (!isset($freight_list[$goods_info['store_id']])) {
  536. $freight_list[$goods_info['store_id']] = $goods_info['goods_freight'];
  537. } else {
  538. $freight_list[$goods_info['store_id']] += $goods_info['goods_freight'];
  539. }
  540. unset($buy_list[$key]);
  541. }
  542. }
  543. //计算优惠套装商品运费
  544. if (!empty($store_bl_goods_freight)) {
  545. $pbundling_model = model('pbundling');
  546. foreach (array_unique($store_bl_goods_freight) as $store_id => $bl_id) {
  547. $bl_info = $pbundling_model->getBundlingInfo(['bl_id' => $bl_id]);
  548. if (!empty($bl_info)) {
  549. if (!isset($freight_list[$store_id])) {
  550. $freight_list[$store_id] = $bl_info['bl_freight'];
  551. } else {
  552. $freight_list[$store_id] += $bl_info['bl_freight'];
  553. }
  554. }
  555. }
  556. }
  557. $return['iscalced'] = $freight_list;
  558. //最后再计算使用运费模板的信息(店铺ID,运费模板ID,购买数量),使用使用相同运费模板的商品数量累加
  559. $freight_list = [];
  560. foreach ($buy_list as $goods_info) {
  561. if (!isset($freight_list[$goods_info['store_id']])) {
  562. $freight_list[$goods_info['store_id']] = [];
  563. }
  564. if (!isset($freight_list[$goods_info['store_id']][$goods_info['transport_id']])) {
  565. $freight_list[$goods_info['store_id']][$goods_info['transport_id']] = ['count' => 0, 'weight' => 0];
  566. }
  567. $freight_list[$goods_info['store_id']][$goods_info['transport_id']]['count'] += $goods_info['goods_num'];
  568. $freight_list[$goods_info['store_id']][$goods_info['transport_id']]['weight'] += $goods_info['goods_num'] * $goods_info['goods_weight'];
  569. }
  570. $return['nocalced'] = $freight_list;
  571. return $return;
  572. }
  573. /**
  574. * 根据地区选择计算出所有店铺最终运费
  575. * @param array $freight_list 运费信息(店铺ID,运费,运费模板ID,购买数量)
  576. * @param int $city_id 市级ID
  577. * @return array 返回店铺ID=>运费
  578. */
  579. public function calcStoreFreight($freight_list, $city_id)
  580. {
  581. if (!is_array($freight_list) || empty($freight_list) || empty($city_id))
  582. return;
  583. //免费和固定运费计算结果
  584. $return_list = $freight_list['iscalced'];
  585. //使用运费模板的信息(array(店铺ID=>array(运费模板ID=>购买数量))
  586. $nocalced_list = $freight_list['nocalced'];
  587. //然后计算使用运费运费模板的在该$city_id时的运费值
  588. if (!empty($nocalced_list) && is_array($nocalced_list)) {
  589. //如果有商品使用的运费模板,先计算这些商品的运费总金额
  590. $transport_model = model('transport');
  591. foreach ($nocalced_list as $store_id => $value) {
  592. if (is_array($value)) {
  593. foreach ($value as $transport_id => $v) {
  594. $freight_total = $transport_model->calcTransport($transport_id, $city_id, $v['count'], $v['weight']);
  595. if ($freight_total === false) {
  596. return;
  597. } else {
  598. if (empty($return_list[$store_id])) {
  599. $return_list[$store_id] = $freight_total;
  600. } else {
  601. $return_list[$store_id] += $freight_total;
  602. }
  603. }
  604. }
  605. }
  606. }
  607. }
  608. return $return_list;
  609. }
  610. /**
  611. * 追加赠品到下单列表,并更新购买数量
  612. * @param array $store_cart_list 购买列表
  613. * @param array $store_premiums_list 赠品列表
  614. * @param array $store_mansong_rule_list 满即送规则
  615. */
  616. public function appendPremiumsToCartList($store_cart_list, $store_premiums_list = [], $store_mansong_rule_list = [], $member_id)
  617. {
  618. if (empty($store_cart_list))
  619. return [];
  620. //处理商品级赠品
  621. foreach ($store_cart_list as $store_id => $cart_list) {
  622. foreach ($cart_list as $cart_info) {
  623. if (empty($cart_info['gift_list']))
  624. continue;
  625. if (!is_array($store_premiums_list))
  626. $store_premiums_list = [];
  627. if (!array_key_exists($store_id, $store_premiums_list))
  628. $store_premiums_list[$store_id] = [];
  629. $zenpin_info = [];
  630. foreach ($cart_info['gift_list'] as $gift_info) {
  631. $zenpin_info['goods_id'] = $gift_info['gift_goodsid'];
  632. $zenpin_info['goods_name'] = $gift_info['gift_goodsname'];
  633. $zenpin_info['goods_image'] = $gift_info['gift_goodsimage'];
  634. $zenpin_info['goods_storage'] = $gift_info['goods_storage'];
  635. $zenpin_info['goods_num'] = $cart_info['goods_num'] * $gift_info['gift_amount'];
  636. $store_premiums_list[$store_id][] = $zenpin_info;
  637. }
  638. }
  639. }
  640. //取得每种商品的库存[含赠品]
  641. $goods_storage_quantity = $this->_getEachGoodsStorageQuantity($store_cart_list, $store_premiums_list);
  642. //取得每种商品的购买量[不含赠品]
  643. $goods_buy_quantity = $this->_getEachGoodsBuyQuantity($store_cart_list);
  644. //halt($goods_buy_quantity);
  645. foreach ($goods_buy_quantity as $goods_id => $quantity) {
  646. $goods_storage_quantity[$goods_id] -= $quantity;
  647. if ($goods_storage_quantity[$goods_id] < 0) {
  648. //商品库存不足,请重购买
  649. return false;
  650. }
  651. }
  652. //将赠品追加到购买列表
  653. if (is_array($store_premiums_list)) {
  654. foreach ($store_premiums_list as $store_id => $goods_list) {
  655. $zp_list = [];
  656. $gift_desc = '';
  657. foreach ($goods_list as $goods_info) {
  658. //如果没有库存了,则不再送赠品
  659. if ($goods_storage_quantity[$goods_info['goods_id']] == 0) {
  660. $gift_desc = ',赠品库存不足,未能全部送出 ';
  661. continue;
  662. }
  663. $new_data = [];
  664. $new_data['chain_id'] = 0;
  665. $new_data['buyer_id'] = $member_id;
  666. $new_data['store_id'] = $store_id;
  667. $new_data['store_name'] = $store_cart_list[$store_id][0]['store_name'];
  668. $new_data['goods_id'] = $goods_info['goods_id'];
  669. $new_data['goods_name'] = $goods_info['goods_name'];
  670. $new_data['goods_price'] = 0;
  671. $new_data['goods_image'] = $goods_info['goods_image'];
  672. $new_data['bl_id'] = 0;
  673. $new_data['state'] = true;
  674. $new_data['storage_state'] = true;
  675. $new_data['gc_id'] = 0;
  676. $new_data['goods_weight'] = 0;
  677. $new_data['gc_id_1'] = 0;
  678. $new_data['gc_id_2'] = 0;
  679. $new_data['gc_id_3'] = 0;
  680. $new_data['transport_id'] = 0;
  681. $new_data['goods_freight'] = 0;
  682. $new_data['goods_vat'] = 0;
  683. $new_data['goods_total'] = 0;
  684. $new_data['ifzengpin'] = true;
  685. //计算赠送数量,有就赠,赠完为止
  686. if ($goods_storage_quantity[$goods_info['goods_id']] - $goods_info['goods_num'] >= 0) {
  687. if (!isset($goods_buy_quantity[$goods_info['goods_id']])) {
  688. $goods_buy_quantity[$goods_info['goods_id']] = $goods_info['goods_num'];
  689. } else {
  690. $goods_buy_quantity[$goods_info['goods_id']] += $goods_info['goods_num'];
  691. }
  692. $goods_storage_quantity[$goods_info['goods_id']] -= $goods_info['goods_num'];
  693. $new_data['goods_num'] = $goods_info['goods_num'];
  694. } else {
  695. $new_data['goods_num'] = $goods_storage_quantity[$goods_info['goods_id']];
  696. $goods_buy_quantity[$goods_info['goods_id']] += $goods_storage_quantity[$goods_info['goods_id']];
  697. $goods_storage_quantity[$goods_info['goods_id']] = 0;
  698. }
  699. if (array_key_exists($goods_info['goods_id'], $zp_list)) {
  700. $zp_list[$goods_info['goods_id']]['goods_num'] += $new_data['goods_num'];
  701. } else {
  702. $zp_list[$goods_info['goods_id']] = $new_data;
  703. }
  704. }
  705. sort($zp_list);
  706. $store_cart_list[$store_id] = array_merge($store_cart_list[$store_id], $zp_list);
  707. @$store_mansong_rule_list[$store_id]['desc'] .= $gift_desc;
  708. @$store_mansong_rule_list[$store_id]['desc'] = trim($store_mansong_rule_list[$store_id]['desc'], ',');
  709. }
  710. }
  711. return [$store_cart_list, $goods_buy_quantity, $store_mansong_rule_list];
  712. }
  713. /**
  714. * 充值卡支付,依次循环每个订单
  715. * 如果充值卡足够就单独支付了该订单,如果不足就暂时冻结,等API支付成功了再彻底扣除
  716. */
  717. public function rcbPay($order_list, $input, $buyer_info)
  718. {
  719. $member_id = $buyer_info['member_id'];
  720. $member_name = $buyer_info['member_name'];
  721. $available_rcb_amount = floatval($buyer_info['available_rc_balance']);
  722. if ($available_rcb_amount <= 0)
  723. return;
  724. $order_model = model('order');
  725. $logic_order = model('order', 'logic');
  726. $predeposit_model = model('predeposit');
  727. $canPay = false;
  728. foreach ($order_list as $key => $order_info) {
  729. //货到付款的订单跳过
  730. if ($order_info['payment_code'] == 'offline')
  731. continue;
  732. if (!isset($order_info['rcb_amount'])) {
  733. $order_list[$key]['rcb_amount'] = $order_info['rcb_amount'] = 0;
  734. }
  735. if (!isset($order_info['pd_amount'])) {
  736. $order_list[$key]['pd_amount'] = $order_info['pd_amount'] = 0;
  737. }
  738. $order_amount = round(($order_info['order_state'] == ORDER_STATE_DEPOSIT ? $order_info['presell_deposit_amount'] : $order_info['order_amount']) - $order_info['rcb_amount'] - $order_info['pd_amount'], 2);
  739. $data_pd = [];
  740. $data_pd['member_id'] = $member_id;
  741. $data_pd['member_name'] = $member_name;
  742. $data_pd['order_sn'] = $order_info['order_sn'];
  743. //暂冻结充值卡,后面还需要 API彻底完成支付
  744. if ($available_rcb_amount > 0) {
  745. if ($available_rcb_amount >= $order_amount) {
  746. $available_rcb_amount -= $order_amount;
  747. $data_pd['amount'] = $order_amount;
  748. $canPay = true;
  749. } else {
  750. $available_rcb_amount = 0;
  751. $data_pd['amount'] = $available_rcb_amount;
  752. $canPay = false;
  753. }
  754. $predeposit_model->changeRcb('order_freeze', $data_pd);
  755. //支付金额保存到订单
  756. $data_order = [];
  757. $order_list[$key]['rcb_amount'] = $data_order['rcb_amount'] = round($order_info['rcb_amount'] + $data_pd['amount'], 2);
  758. $result = $order_model->editOrder($data_order, ['order_id' => $order_info['order_id']]);
  759. if (!$result) {
  760. throw new \think\Exception('订单更新失败', 10006);
  761. }
  762. }
  763. }
  764. if ($canPay) {//收到货款
  765. $logic_order->changeOrderReceivePay($order_list, 'buyer', $member_name);
  766. }
  767. return $order_list;
  768. }
  769. /**
  770. * 预存款支付,依次循环每个订单
  771. * 如果预存款足够就单独支付了该订单,如果不足就暂时冻结,等API支付成功了再彻底扣除
  772. */
  773. public function pdPay($order_list, $input, $buyer_info)
  774. {
  775. $member_id = $buyer_info['member_id'];
  776. $member_name = $buyer_info['member_name'];
  777. // $payment_model = model('payment');
  778. // $pd_payment_info = $payment_model->getPaymentOpenInfo(array('payment_code'=>'predeposit'));
  779. // if (empty($pd_payment_info)) return;
  780. $available_pd_amount = floatval($buyer_info['available_predeposit']);
  781. if ($available_pd_amount <= 0)
  782. return;
  783. $order_model = model('order');
  784. $logic_order = model('order', 'logic');
  785. $predeposit_model = model('predeposit');
  786. $canPay = false;
  787. foreach ($order_list as $key => $order_info) {
  788. //货到付款的订单、已经充值卡支付的订单跳过
  789. if ($order_info['payment_code'] == 'offline')
  790. continue;
  791. if ($order_info['order_state'] == ORDER_STATE_PAY)
  792. continue;
  793. if (!isset($order_info['rcb_amount'])) {
  794. $order_list[$key]['rcb_amount'] = $order_info['rcb_amount'] = 0;
  795. }
  796. if (!isset($order_info['pd_amount'])) {
  797. $order_list[$key]['pd_amount'] = $order_info['pd_amount'] = 0;
  798. }
  799. $order_amount = round(($order_info['order_state'] == ORDER_STATE_DEPOSIT ? $order_info['presell_deposit_amount'] : $order_info['order_amount']) - $order_info['rcb_amount'] - $order_info['pd_amount'], 2);
  800. $data_pd = [];
  801. $data_pd['member_id'] = $member_id;
  802. $data_pd['member_name'] = $member_name;
  803. $data_pd['order_sn'] = $order_info['order_sn'];
  804. //暂冻结预存款,后面还需要 API彻底完成支付
  805. if ($available_pd_amount > 0) {
  806. if ($available_pd_amount >= $order_amount) {
  807. $data_pd['amount'] = $order_amount;
  808. $available_pd_amount -= $order_amount;
  809. $canPay = true;
  810. } else {
  811. $data_pd['amount'] = $available_pd_amount;
  812. $available_pd_amount = 0;
  813. $canPay = false;
  814. }
  815. $predeposit_model->changePd('order_freeze', $data_pd);
  816. //预存款支付金额保存到订单
  817. $data_order = [];
  818. $order_list[$key]['pd_amount'] = $data_order['pd_amount'] = round($order_info['pd_amount'] + $data_pd['amount'], 2);
  819. $result = $order_model->editOrder($data_order, ['order_id' => $order_info['order_id']]);
  820. if (!$result) {
  821. throw new \think\Exception('订单更新失败', 10006);
  822. }
  823. }
  824. }
  825. if ($canPay) {//收到货款
  826. $logic_order->changeOrderReceivePay($order_list, 'buyer', $member_name);
  827. }
  828. return $order_list;
  829. }
  830. /**
  831. * 积分支付
  832. */
  833. public function pointPay($order_list, $input, $buyer_info)
  834. {
  835. $point_ratio = config('app.point_ratio');
  836. $point_amount = floatval($buyer_info['point'] / $point_ratio);
  837. if ($point_amount <= 0)
  838. return $order_list;
  839. $order_model = model('order');
  840. $predeposit_model = model('predeposit');
  841. foreach ($order_list as &$order_info) {
  842. $order_amount = round($order_info['order_amount'] - $order_info['rcb_amount'] - $order_info['pd_amount'], 2);
  843. $data_point = [];
  844. $data_point['member_id'] = $buyer_info['member_id'];
  845. $data_point['union_id'] = $buyer_info['member_wxunionid'];
  846. $data_point['member_name'] = $buyer_info['member_name'];
  847. $data_point['amount'] = $order_amount;
  848. $data_point['order_sn'] = $order_info['order_sn'];
  849. if ($point_amount >= $order_amount) {
  850. //积分立即支付,订单支付完成
  851. $predeposit_model->changePoint('order_pay', $data_point);
  852. // 订单状态 置为已支付
  853. $data_order = [];
  854. $order_info['order_state'] = $data_order['order_state'] = 40;
  855. $data_order['payment_time'] = TIMESTAMP;
  856. $data_order['payment_code'] = 'predeposit';
  857. $order_info['point_amount'] = $data_order['point_amount'] = round($order_info['point_amount'] + ($order_amount * $point_ratio), 2);
  858. $result = $order_model->editorder($data_order, ['order_id' => $order_info['order_id']]);
  859. if (!$result) {
  860. throw new \think\Exception('订单更新失败', 10006);
  861. }
  862. } else {
  863. //暂冻结预存款,后面还需要 API彻底完成支付
  864. $data_point['amount'] = $point_amount;
  865. $predeposit_model->changeRcb('order_freeze', $data_point);
  866. //预存款支付金额保存到订单
  867. $data_order = [];
  868. $order_info['point_amount'] = $data_order['point_amount'] = $order_info['point_amount'] + $point_amount * $point_ratio;
  869. $result = $order_model->editorder($data_order, ['order_id' => $order_info['order_id']]);
  870. if (!$result) {
  871. throw new \think\Exception('订单更新失败', 10006);
  872. }
  873. }
  874. unset($order_info);
  875. }
  876. return $order_list;
  877. }
  878. /**
  879. * 订单编号生成规则,n(n>=1)个订单表对应一个支付表,
  880. * 生成订单编号(年取1位 + $pay_id取13位 + 第N个子订单取2位)
  881. * 1000个会员同一微秒提订单,重复机率为1/100
  882. * @param $pay_id 支付表自增ID
  883. * @return string
  884. */
  885. public function makeOrderSn($pay_id)
  886. {
  887. //记录生成子订单的个数,如果生成多个子订单,该值会累加
  888. static $num;
  889. if (empty($num)) {
  890. $num = 1;
  891. } else {
  892. $num++;
  893. }
  894. return (date('y', TIMESTAMP) % 9 + 1) . sprintf('%013d', $pay_id) . sprintf('%02d', $num);
  895. }
  896. /**
  897. * 更新库存与销量
  898. *
  899. * @param array $buy_items 商品ID => 购买数量
  900. */
  901. public function editGoodsNum($buy_items)
  902. {
  903. foreach ($buy_items as $goods_id => $buy_num) {
  904. $data = [
  905. 'goods_storage' => Db::raw('goods_storage-' . $buy_num),
  906. 'goods_salenum' => Db::raw('goods_salenum+' . $buy_num),
  907. ];
  908. $result = model('goods')->editGoods($data, ['goods_id' => $goods_id]);
  909. if (!$result)
  910. throw new \think\Exception(lang('cart_step2_submit_fail'), 10006);
  911. }
  912. }
  913. /**
  914. * 取得店铺级活动 - 每个店铺可用的满即送活动规则列表
  915. * @param unknown $store_id_array 店铺ID数组
  916. */
  917. public function getMansongruleList($store_id_array)
  918. {
  919. if (!config('ds_config.promotion_allow') || empty($store_id_array) || !is_array($store_id_array))
  920. return [];
  921. $pmansong_model = model('pmansong');
  922. $mansong_rule_list = [];
  923. foreach ($store_id_array as $store_id) {
  924. $store_mansong_rule = $pmansong_model->getMansongInfoByStoreID($store_id);
  925. if (!empty($store_mansong_rule['rules']) && is_array($store_mansong_rule['rules'])) {
  926. foreach ($store_mansong_rule['rules'] as $rule_info) {
  927. //如果减金额 或 有赠品(在售且有库存)
  928. if (!empty($rule_info['mansongrule_discount']) || (!empty($rule_info['mansong_goods_name']) && !empty($rule_info['goods_storage']))) {
  929. $mansong_rule_list[$store_id][] = $this->_parseMansongruleDesc($rule_info);
  930. }
  931. }
  932. }
  933. }
  934. return $mansong_rule_list;
  935. }
  936. /**
  937. * 取得哪些店铺有满免运费活动
  938. * @param array $store_id_array 店铺ID数组
  939. * @return array
  940. */
  941. public function getFreeFreightActiveList($store_id_array)
  942. {
  943. if (empty($store_id_array) || !is_array($store_id_array))
  944. return [];
  945. //定义返回数组
  946. $store_free_freight_active = [];
  947. //如果商品金额未达到免运费设置下线,则需要计算运费
  948. $condition = [];
  949. $condition[] = ['store_id', 'in', $store_id_array];
  950. $store_list = model('store')->getStoreOnlineList($condition, null, '', 'store_id,store_free_price');
  951. foreach ($store_list as $store_info) {
  952. $limit_price = floatval($store_info['store_free_price']);
  953. if ($limit_price > 0) {
  954. $store_free_freight_active[$store_info['store_id']] = sprintf('满%s免运费', $limit_price);
  955. }
  956. }
  957. return $store_free_freight_active;
  958. }
  959. /**
  960. * 取得收货人地址信息
  961. * @param array $address_info
  962. * @return array
  963. */
  964. public function getReciverAddr($address_info = [])
  965. {
  966. if (intval($address_info['chain_id'])) {
  967. $reciver_info['phone'] = trim($address_info['address_mob_phone'] . ($address_info['address_tel_phone'] ? ',' . $address_info['address_tel_phone'] : null), ',');
  968. $reciver_info['tel_phone'] = $address_info['address_tel_phone'];
  969. $reciver_info['mob_phone'] = $address_info['address_mob_phone'];
  970. $reciver_info['address'] = $address_info['chain_area_info'] . ' ' . $address_info['chain_address'];
  971. $reciver_info['area'] = $address_info['chain_area_info'];
  972. $reciver_info['street'] = $address_info['chain_address'];
  973. $reciver_info['chain'] = 1;
  974. $reciver_info = serialize($reciver_info);
  975. $reciver_name = $address_info['chain_addressname'];
  976. } else {
  977. $reciver_info['phone'] = trim($address_info['address_mob_phone'] . ($address_info['address_tel_phone'] ? ',' . $address_info['address_tel_phone'] : null), ',');
  978. $reciver_info['mob_phone'] = $address_info['address_mob_phone'];
  979. $reciver_info['tel_phone'] = $address_info['address_tel_phone'];
  980. $reciver_info['address'] = $address_info['area_info'] . ' ' . $address_info['address_detail'];
  981. $reciver_info['area'] = $address_info['area_info'];
  982. $reciver_info['street'] = $address_info['address_detail'];
  983. $reciver_info = serialize($reciver_info);
  984. $reciver_name = $address_info['address_realname'];
  985. }
  986. return [$reciver_info, $reciver_name];
  987. }
  988. /**
  989. * 整理发票信息
  990. * @param array $invoice_info 发票信息数组
  991. * @return string
  992. */
  993. public function createInvoiceData($invoice_info)
  994. {
  995. //发票信息
  996. $inv = [];
  997. if (isset($invoice_info['invoice_state']) && $invoice_info['invoice_state'] == 1) {
  998. $inv['类型'] = '普通发票 ';
  999. $inv['抬头'] = isset($invoice_info['invoice_title']) ? $invoice_info['invoice_title'] : '个人';
  1000. $inv['内容'] = $invoice_info['invoice_content'];
  1001. $inv['纳税人识别号'] = $invoice_info['invoice_code'];
  1002. } elseif (!empty($invoice_info)) {
  1003. $inv['单位名称'] = $invoice_info['invoice_company'];
  1004. $inv['纳税人识别号'] = $invoice_info['invoice_company_code'];
  1005. $inv['注册地址'] = $invoice_info['invoice_reg_addr'];
  1006. $inv['注册电话'] = $invoice_info['invoice_reg_phone'];
  1007. $inv['开户银行'] = $invoice_info['invoice_reg_bname'];
  1008. $inv['银行账户'] = $invoice_info['invoice_reg_baccount'];
  1009. // $inv['收票人姓名'] = $invoice_info['invoice_rec_name'];
  1010. // $inv['收票人手机号'] = $invoice_info['invoice_rec_mobphone'];
  1011. // $inv['收票人省份'] = $invoice_info['invoice_rec_province'];
  1012. // $inv['送票地址'] = $invoice_info['invoice_goto_addr'];
  1013. }
  1014. return !empty($inv) ? serialize($inv) : serialize([]);
  1015. }
  1016. /**
  1017. * 计算本次下单中每个店铺订单是货到付款还是线上支付,店铺ID=>付款方式[online在线支付offline货到付款]
  1018. * @param array $store_id_array 店铺ID数组
  1019. * @param boolean $if_offpay 是否支持货到付款 true/false
  1020. * @param string $pay_name 付款方式 online/offline
  1021. * @return array
  1022. */
  1023. public function getStorePayTypeList($store_id_array, $if_offpay, $pay_name)
  1024. {
  1025. $store_pay_type_list = [];
  1026. if ($pay_name == 'online') {
  1027. foreach ($store_id_array as $store_id) {
  1028. $store_pay_type_list[$store_id] = 'online';
  1029. }
  1030. } else {
  1031. $offline_pay = model('payment')->getPaymentOpenInfo([['payment_code', '=', 'offline']]);
  1032. if ($offline_pay) {
  1033. //下单里包括平台自营商品并且平台已开启货到付款
  1034. $offline_store_id_array = model('store')->getOwnShopIds();
  1035. foreach ($store_id_array as $store_id) {
  1036. //if (in_array($store_id,$offline_store_id_array)) {
  1037. $store_pay_type_list[$store_id] = 'offline';
  1038. //} else {
  1039. // $store_pay_type_list[$store_id] = 'online';
  1040. //}
  1041. }
  1042. }
  1043. }
  1044. return $store_pay_type_list;
  1045. }
  1046. /**
  1047. * 直接购买时返回最新的在售商品信息(需要在售)
  1048. *
  1049. * @param int $goods_id 所购商品ID
  1050. * @param int $quantity 购买数量
  1051. * @return array
  1052. */
  1053. private function _getGoodsOnlineInfo($goods_id, $quantity)
  1054. {
  1055. //取目前在售商品
  1056. $goods_model = model('goods');
  1057. $goods_model->lock = $this->lock;
  1058. $goods_info = $goods_model->getGoodsOnlineInfoAndPromotionById($goods_id);
  1059. if (empty($goods_info)) {
  1060. return null;
  1061. }
  1062. $new_array = [];
  1063. $new_array['goods_num'] = $goods_info['is_goodsfcode'] ? 1 : $quantity;
  1064. $new_array['goods_id'] = $goods_id;
  1065. $new_array['goods_commonid'] = $goods_info['goods_commonid'];
  1066. $new_array['is_virtual'] = $goods_info['is_virtual'];
  1067. $new_array['gc_id'] = $goods_info['gc_id'];
  1068. $new_array['goods_weight'] = $goods_info['goods_weight'];
  1069. $new_array['gc_id_1'] = $goods_info['gc_id_1'];
  1070. $new_array['gc_id_2'] = $goods_info['gc_id_2'];
  1071. $new_array['gc_id_3'] = $goods_info['gc_id_3'];
  1072. $new_array['store_id'] = $goods_info['store_id'];
  1073. $new_array['goods_name'] = $goods_info['goods_name'];
  1074. $new_array['goods_price'] = $goods_info['goods_price'];
  1075. $new_array['goods_original_price'] = $goods_info['goods_original_price'];
  1076. $new_array['store_name'] = $goods_info['store_name'];
  1077. $new_array['goods_image'] = $goods_info['goods_image'];
  1078. $new_array['transport_id'] = $goods_info['transport_id'];
  1079. $new_array['goods_freight'] = $goods_info['goods_freight'];
  1080. $new_array['goods_vat'] = $goods_info['goods_vat'];
  1081. $new_array['goods_storage'] = $goods_info['goods_storage'];
  1082. $new_array['goods_storage_alarm'] = $goods_info['goods_storage_alarm'];
  1083. $new_array['is_goodsfcode'] = $goods_info['is_goodsfcode'];
  1084. $new_array['is_have_gift'] = $goods_info['is_have_gift'];
  1085. $new_array['state'] = true;
  1086. $new_array['storage_state'] = intval($goods_info['goods_storage']) < intval($quantity) ? false : true;
  1087. $new_array['groupbuy_info'] = $goods_info['groupbuy_info'];
  1088. $new_array['xianshi_info'] = $goods_info['xianshi_info'];
  1089. $new_array['presell_info'] = $goods_info['presell_info'];
  1090. $new_array['wholesale_info'] = $goods_info['wholesale_info'];
  1091. $new_array['pintuan_info'] = $goods_info['pintuan_info'];
  1092. $new_array['bargain_info'] = $goods_info['bargain_info'];
  1093. $new_array['mgdiscount_info'] = $goods_info['mgdiscount_info'];
  1094. //填充必要下标,方便后面统一使用购物车方法与模板
  1095. //cart_id=goods_id,优惠套装目前只能进购物车,不能立即购买
  1096. $new_array['cart_id'] = $goods_id;
  1097. $new_array['bl_id'] = 0;
  1098. return $new_array;
  1099. }
  1100. /**
  1101. * 直接购买时,判断商品是不是正在抢购中,如果是,按抢购价格计算,购买数量若超过抢购规定的上限,则按抢购上限计算
  1102. * @param array $goods_info
  1103. */
  1104. public function getGroupbuyInfo(& $goods_info = [], $quantity)
  1105. {
  1106. if (!config('ds_config.groupbuy_allow') || empty($goods_info['groupbuy_info']))
  1107. return;
  1108. $groupbuy_info = $goods_info['groupbuy_info'];
  1109. $temp = [];
  1110. $temp['goods_num'] = $quantity;
  1111. $temp['goods_price'] = $groupbuy_info['groupbuy_price'];
  1112. if ($groupbuy_info['groupbuy_upper_limit'] && $quantity > $groupbuy_info['groupbuy_upper_limit']) {
  1113. $temp['goods_num'] = $groupbuy_info['groupbuy_upper_limit'];
  1114. }
  1115. $temp['upper_limit'] = $groupbuy_info['groupbuy_upper_limit'];
  1116. $temp['promotions_id'] = $temp['groupbuy_id'] = $groupbuy_info['groupbuy_id'];
  1117. $temp['ifgroupbuy'] = true;
  1118. if ($groupbuy_info['groupbuy_upper_limit'] > 0) {//如果限购
  1119. $ordergoods = Db::name('ordergoods')->where(['buyer_id' => session('member_id'), 'goods_type' => 2, 'promotions_id' => $groupbuy_info['groupbuy_id']])->sum('goods_num');
  1120. if (!empty($ordergoods) && intval($ordergoods) > 0) {
  1121. $tnum = intval($groupbuy_info['groupbuy_upper_limit']) - intval($ordergoods); //-intval($goods_info['goods_num']);
  1122. if ($tnum <= 0)
  1123. // $goods_info = null;
  1124. return;
  1125. else {
  1126. if ($temp['goods_num'] > $tnum) {
  1127. $temp['goods_num'] = $tnum;
  1128. }
  1129. }
  1130. }
  1131. }
  1132. $goods_info = array_merge($goods_info, $temp);
  1133. //end
  1134. }
  1135. /**
  1136. * 取得某商品赠品列表信息
  1137. * @param array $goods_info
  1138. */
  1139. private function _getGoodsgiftList(& $goods_info)
  1140. {
  1141. if (!isset($goods_info['is_have_gift']))
  1142. return;
  1143. $gift_list = model('goodsgift')->getGoodsgiftListByGoodsId($goods_info['goods_id']);
  1144. //取得赠品当前信息,如果未在售踢除,如果在售取出库存
  1145. if (empty($gift_list))
  1146. return [];
  1147. $goods_model = model('goods');
  1148. foreach ($gift_list as $k => $v) {
  1149. $goods_online_info = $goods_model->getGoodsOnlineInfoByID($v['gift_goodsid']);
  1150. if (empty($goods_online_info)) {
  1151. unset($gift_list[$k]);
  1152. } else {
  1153. $gift_list[$k]['goods_storage'] = $goods_online_info['goods_storage'];
  1154. }
  1155. }
  1156. $goods_info['gift_list'] = $gift_list;
  1157. }
  1158. /**
  1159. * 取商品最新的在售信息
  1160. * @param unknown $cart_list
  1161. * @return array
  1162. */
  1163. private function _getOnlineCartList($cart_list)
  1164. {
  1165. if (empty($cart_list) || !is_array($cart_list))
  1166. return $cart_list;
  1167. //验证商品是否有效
  1168. $goods_id_array = [];
  1169. foreach ($cart_list as $key => $cart_info) {
  1170. if (!intval($cart_info['bl_id'])) {
  1171. $goods_id_array[] = $cart_info['goods_id'];
  1172. }
  1173. }
  1174. $goods_model = model('goods');
  1175. $goods_model->lock = $this->lock;
  1176. $goods_online_list = $goods_model->getGoodsOnlineListAndPromotionByIdArray($goods_id_array);
  1177. $goods_online_array = [];
  1178. foreach ($goods_online_list as $goods) {
  1179. $goods_online_array[$goods['goods_id']] = $goods;
  1180. }
  1181. foreach ((array)$cart_list as $key => $cart_info) {
  1182. if (intval($cart_info['bl_id']))
  1183. continue;
  1184. $cart_list[$key]['state'] = true;
  1185. $cart_list[$key]['storage_state'] = true;
  1186. $cart_list[$key]['chain_id'] = 0;
  1187. if (in_array($cart_info['goods_id'], array_keys($goods_online_array))) {
  1188. $goods_online_info = $goods_online_array[$cart_info['goods_id']];
  1189. $cart_list[$key]['goods_commonid'] = $goods_online_info['goods_commonid'];
  1190. $cart_list[$key]['goods_name'] = $goods_online_info['goods_name'];
  1191. $cart_list[$key]['gc_id'] = $goods_online_info['gc_id'];
  1192. $cart_list[$key]['goods_weight'] = $goods_online_info['goods_weight'];
  1193. $cart_list[$key]['gc_id_1'] = $goods_online_info['gc_id_1'];
  1194. $cart_list[$key]['gc_id_2'] = $goods_online_info['gc_id_2'];
  1195. $cart_list[$key]['gc_id_3'] = $goods_online_info['gc_id_3'];
  1196. $cart_list[$key]['goods_image'] = $goods_online_info['goods_image'];
  1197. $cart_list[$key]['goods_price'] = $goods_online_info['goods_price'];
  1198. $cart_list[$key]['goods_original_price'] = $goods_online_info['goods_original_price'];
  1199. $cart_list[$key]['transport_id'] = $goods_online_info['transport_id'];
  1200. $cart_list[$key]['goods_freight'] = $goods_online_info['goods_freight'];
  1201. $cart_list[$key]['goods_vat'] = $goods_online_info['goods_vat'];
  1202. $cart_list[$key]['goods_storage'] = $goods_online_info['goods_storage'];
  1203. $cart_list[$key]['goods_storage_alarm'] = $goods_online_info['goods_storage_alarm'];
  1204. $cart_list[$key]['is_goodsfcode'] = $goods_online_info['is_goodsfcode'];
  1205. $cart_list[$key]['is_have_gift'] = $goods_online_info['is_have_gift'];
  1206. if ($cart_info['goods_num'] > $goods_online_info['goods_storage']) {
  1207. $cart_list[$key]['storage_state'] = false;
  1208. }
  1209. $cart_list[$key]['groupbuy_info'] = $goods_online_info['groupbuy_info'];
  1210. $cart_list[$key]['mgdiscount_info'] = $goods_online_info['mgdiscount_info'];
  1211. $cart_list[$key]['xianshi_info'] = $goods_online_info['xianshi_info'];
  1212. $cart_list[$key]['presell_info'] = $goods_online_info['presell_info'];
  1213. $cart_list[$key]['wholesale_info'] = $goods_online_info['wholesale_info'];
  1214. } else {
  1215. //如果商品下架
  1216. $cart_list[$key]['state'] = false;
  1217. $cart_list[$key]['storage_state'] = false;
  1218. }
  1219. }
  1220. return $cart_list;
  1221. }
  1222. /**
  1223. * 直接购买时,判断商品是不是正在抢购中,如果是,按抢购价格计算,购买数量若超过抢购规定的上限,则按抢购上限计算
  1224. * @param array $cart_list
  1225. */
  1226. public function getGroupbuyCartList(& $cart_list)
  1227. {
  1228. if (!config('ds_config.promotion_allow') || empty($cart_list))
  1229. return;
  1230. foreach ($cart_list as $key => $cart_info) {
  1231. if ((isset($cart_info['bl_id']) && $cart_info['bl_id'] === '1') || empty($cart_info['groupbuy_info']))
  1232. continue;
  1233. $this->getGroupbuyInfo($cart_info, $cart_info['goods_num']);
  1234. if ($cart_info) {
  1235. $cart_list[$key] = $cart_info;
  1236. } else {
  1237. unset($cart_list[$key]);
  1238. }
  1239. }
  1240. }
  1241. /**
  1242. * 批量判断购物车内的商品是不是限时折扣中,如果购买数量若>=规定的下限,按折扣价格计算,否则按原价计算
  1243. * 并标识该商品为限时商品
  1244. * @param array $cart_list
  1245. */
  1246. public function getXianshiCartList(& $cart_list)
  1247. {
  1248. if (!config('ds_config.promotion_allow') || empty($cart_list))
  1249. return;
  1250. foreach ($cart_list as $key => $cart_info) {
  1251. if ((isset($cart_info['bl_id']) && $cart_info['bl_id'] === '1') || empty($cart_info['xianshi_info']))
  1252. continue;
  1253. $this->getXianshiInfo($cart_info, $cart_info['goods_num']);
  1254. $cart_list[$key] = $cart_info;
  1255. }
  1256. }
  1257. /**
  1258. * 批量判断购物车内的商品是不是预售
  1259. * 并标识该商品为限时商品
  1260. * @param array $cart_list
  1261. */
  1262. public function getPresellCartList(& $cart_list)
  1263. {
  1264. if (!config('ds_config.promotion_allow') || empty($cart_list))
  1265. return;
  1266. foreach ($cart_list as $key => $cart_info) {
  1267. if ((isset($cart_info['bl_id']) && $cart_info['bl_id'] === '1') || empty($cart_info['presell_info']))
  1268. continue;
  1269. $this->getPresellInfo($cart_info, $cart_info['goods_num']);
  1270. $cart_list[$key] = $cart_info;
  1271. if (count($cart_list) > 1) {
  1272. $cart_list[$key]['state'] = false;//预售商品只能直接购买
  1273. }
  1274. }
  1275. }
  1276. /**
  1277. * 批量判断购物车内的商品是不是批发中,如果购买数量若>=规定的下限,按批发价格计算,否则按原价计算
  1278. * 并标识该商品为限时商品
  1279. * @param array $cart_list
  1280. */
  1281. public function getWholesaleCartList(& $cart_list)
  1282. {
  1283. if (!config('ds_config.promotion_allow') || empty($cart_list))
  1284. return;
  1285. foreach ($cart_list as $key => $cart_info) {
  1286. if ((isset($cart_info['bl_id']) && $cart_info['bl_id'] === '1') || empty($cart_info['wholesale_info']))
  1287. continue;
  1288. $this->getWholesaleInfo($cart_info, $cart_info['goods_num']);
  1289. $cart_list[$key] = $cart_info;
  1290. }
  1291. }
  1292. /**
  1293. * 批量判断购物车内的商品是不是会员等级折扣中,如果平台开启会员折扣、商家开启会员折扣并设置,则按折扣价格计算,否则按原价计算
  1294. * 并标识该商品为会员等级折扣
  1295. * @param type $cart_list
  1296. * @return type
  1297. */
  1298. public function getMgdiscountCartList(& $cart_list)
  1299. {
  1300. if (!config('ds_config.mgdiscount_allow') || empty($cart_list))
  1301. return;
  1302. foreach ($cart_list as $key => $cart_info) {
  1303. if (empty($cart_info['mgdiscount_info']))
  1304. continue;
  1305. $this->getMgdiscountInfo($cart_info);
  1306. $cart_list[$key] = $cart_info;
  1307. }
  1308. }
  1309. /**
  1310. * 取得购物车商品的赠品列表[商品级赠品]
  1311. *
  1312. * @param array $cart_list
  1313. */
  1314. private function _getGiftCartList(& $cart_list)
  1315. {
  1316. foreach ($cart_list as $k => $cart_info) {
  1317. if ($cart_info['bl_id'])
  1318. continue;
  1319. $this->_getGoodsgiftList($cart_info);
  1320. $cart_list[$k] = $cart_info;
  1321. }
  1322. }
  1323. /**
  1324. * 取得购买车内组合销售信息以及包含的商品及有效状态
  1325. * @param array $cart_list
  1326. */
  1327. private function _getBundlingCartList(& $cart_list)
  1328. {
  1329. if (!config('ds_config.promotion_allow') || empty($cart_list))
  1330. return;
  1331. $pbundling_model = model('pbundling');
  1332. $goods_model = model('goods');
  1333. foreach ($cart_list as $key => $cart_info) {
  1334. if (!intval($cart_info['bl_id']))
  1335. continue;
  1336. $cart_list[$key]['state'] = true;
  1337. $cart_list[$key]['storage_state'] = true;
  1338. $bl_info = $pbundling_model->getBundlingInfo(['bl_id' => $cart_info['bl_id']]);
  1339. //标志优惠套装是否处于有效状态
  1340. if (empty($bl_info) || !intval($bl_info['bl_state'])) {
  1341. $cart_list[$key]['state'] = false;
  1342. }
  1343. //取得优惠套装商品列表
  1344. $cart_list[$key]['bl_goods_list'] = $pbundling_model->getBundlingGoodsList(['bl_id' => $cart_info['bl_id']]);
  1345. //取最新在售商品信息
  1346. $goods_id_array = [];
  1347. foreach ($cart_list[$key]['bl_goods_list'] as $goods_info) {
  1348. $goods_id_array[] = $goods_info['goods_id'];
  1349. }
  1350. $goods_model->lock = $this->lock;
  1351. $goods_list = $goods_model->getGoodsOnlineListAndPromotionByIdArray($goods_id_array);
  1352. $goods_online_list = [];
  1353. foreach ($goods_list as $goods_info) {
  1354. $goods_online_list[$goods_info['goods_id']] = $goods_info;
  1355. }
  1356. unset($goods_list);
  1357. //使用最新的商品名称、图片,如果一旦有商品下架,则整个套装置置为无效状态
  1358. $total_down_price = 0;
  1359. $tmp_amount = 0;
  1360. foreach ($cart_list[$key]['bl_goods_list'] as $k => $goods_info) {
  1361. if (array_key_exists($goods_info['goods_id'], $goods_online_list)) {
  1362. $goods_online_info = $goods_online_list[$goods_info['goods_id']];
  1363. //如果库存不足,标识false
  1364. if ($cart_info['goods_num'] > $goods_online_info['goods_storage']) {
  1365. $cart_list[$key]['storage_state'] = false;
  1366. }
  1367. $cart_list[$key]['bl_goods_list'][$k]['chain_id'] = 0;
  1368. $cart_list[$key]['bl_goods_list'][$k]['goods_id'] = $goods_online_info['goods_id'];
  1369. $cart_list[$key]['bl_goods_list'][$k]['goods_commonid'] = $goods_online_info['goods_commonid'];
  1370. $cart_list[$key]['bl_goods_list'][$k]['goods_original_price'] = $goods_online_info['goods_original_price'];
  1371. $cart_list[$key]['bl_goods_list'][$k]['store_id'] = $goods_online_info['store_id'];
  1372. $cart_list[$key]['bl_goods_list'][$k]['store_name'] = $goods_online_info['store_name'];
  1373. $cart_list[$key]['bl_goods_list'][$k]['goods_name'] = $goods_online_info['goods_name'];
  1374. $cart_list[$key]['bl_goods_list'][$k]['goods_image'] = $goods_online_info['goods_image'];
  1375. $cart_list[$key]['bl_goods_list'][$k]['transport_id'] = $goods_online_info['transport_id'];
  1376. $cart_list[$key]['bl_goods_list'][$k]['goods_freight'] = $goods_online_info['goods_freight'];
  1377. $cart_list[$key]['bl_goods_list'][$k]['goods_vat'] = $goods_online_info['goods_vat'];
  1378. $cart_list[$key]['bl_goods_list'][$k]['goods_storage'] = $goods_online_info['goods_storage'];
  1379. $cart_list[$key]['bl_goods_list'][$k]['goods_storage_alarm'] = $goods_online_info['goods_storage_alarm'];
  1380. $cart_list[$key]['bl_goods_list'][$k]['gc_id'] = $goods_online_info['gc_id'];
  1381. $cart_list[$key]['bl_goods_list'][$k]['goods_weight'] = $goods_online_info['goods_weight'];
  1382. $cart_list[$key]['bl_goods_list'][$k]['gc_id_1'] = $goods_online_info['gc_id_1'];
  1383. $cart_list[$key]['bl_goods_list'][$k]['gc_id_2'] = $goods_online_info['gc_id_2'];
  1384. $cart_list[$key]['bl_goods_list'][$k]['gc_id_3'] = $goods_online_info['gc_id_3'];
  1385. //每个商品直降多少
  1386. $total_down_price += $cart_list[$key]['bl_goods_list'][$k]['down_price'] = ds_price_format($goods_online_info['goods_price'] - $goods_info['blgoods_price']);
  1387. $tmp_amount += $goods_online_info['goods_original_price'];
  1388. } else {
  1389. //商品已经下架
  1390. $cart_list[$key]['state'] = false;
  1391. $cart_list[$key]['storage_state'] = false;
  1392. }
  1393. }
  1394. $cart_list[$key]['down_price'] = ds_price_format($total_down_price);
  1395. $cart_list[$key]['goods_original_price'] = ds_price_format($tmp_amount);
  1396. }
  1397. }
  1398. /**
  1399. * 取得每种商品的库存
  1400. * @param array $store_cart_list 购买列表
  1401. * @param array $store_premiums_list 赠品列表
  1402. * @return array 商品ID=>库存
  1403. */
  1404. private function _getEachGoodsStorageQuantity($store_cart_list, $store_premiums_list = [])
  1405. {
  1406. if (empty($store_cart_list) || !is_array($store_cart_list))
  1407. return [];
  1408. $goods_storage_quangity = [];
  1409. foreach ($store_cart_list as $store_cart) {
  1410. foreach ($store_cart as $cart_info) {
  1411. if (!intval($cart_info['bl_id'])) {
  1412. //正常商品
  1413. $goods_storage_quangity[$cart_info['goods_id']] = $cart_info['goods_storage'];
  1414. } elseif (!empty($cart_info['bl_goods_list']) && is_array($cart_info['bl_goods_list'])) {
  1415. //优惠套装
  1416. foreach ($cart_info['bl_goods_list'] as $goods_info) {
  1417. $goods_storage_quangity[$goods_info['goods_id']] = $goods_info['goods_storage'];
  1418. }
  1419. }
  1420. }
  1421. }
  1422. //取得赠品商品的库存
  1423. if (is_array($store_premiums_list)) {
  1424. foreach ($store_premiums_list as $store_id => $goods_list) {
  1425. foreach ($goods_list as $goods_info) {
  1426. if (!isset($goods_storage_quangity[$goods_info['goods_id']])) {
  1427. $goods_storage_quangity[$goods_info['goods_id']] = $goods_info['goods_storage'];
  1428. }
  1429. }
  1430. }
  1431. }
  1432. return $goods_storage_quangity;
  1433. }
  1434. /**
  1435. * 取得每种商品的购买量
  1436. * @param array $store_cart_list 购买列表
  1437. * @return array 商品ID=>购买数量
  1438. */
  1439. private function _getEachGoodsBuyQuantity($store_cart_list)
  1440. {
  1441. if (empty($store_cart_list) || !is_array($store_cart_list))
  1442. return [];
  1443. $goods_buy_quangity = [];
  1444. foreach ($store_cart_list as $store_cart) {
  1445. foreach ($store_cart as $cart_info) {
  1446. if (!intval($cart_info['bl_id'])) {
  1447. //正常商品
  1448. if (!isset($goods_buy_quangity[$cart_info['goods_id']])) {
  1449. $goods_buy_quangity[$cart_info['goods_id']] = $cart_info['goods_num'];
  1450. } else {
  1451. $goods_buy_quangity[$cart_info['goods_id']] += $cart_info['goods_num'];
  1452. }
  1453. } elseif (!empty($cart_info['bl_goods_list']) && is_array($cart_info['bl_goods_list'])) {
  1454. //优惠套装
  1455. foreach ($cart_info['bl_goods_list'] as $goods_info) {
  1456. if (!isset($goods_buy_quangity[$goods_info['goods_id']])) {
  1457. $goods_buy_quangity[$goods_info['goods_id']] = $cart_info['goods_num'];
  1458. } else {
  1459. $goods_buy_quangity[$goods_info['goods_id']] += $cart_info['goods_num'];
  1460. }
  1461. }
  1462. }
  1463. }
  1464. }
  1465. return $goods_buy_quangity;
  1466. }
  1467. /**
  1468. * 得到所购买的id和数量
  1469. *
  1470. */
  1471. private function _parseItems($cart_id)
  1472. {
  1473. //存放所购商品ID和数量组成的键值对
  1474. $buy_items = [];
  1475. if (is_array($cart_id)) {
  1476. foreach ($cart_id as $value) {
  1477. if (preg_match_all('/^(\d{1,10})\|(\d{1,6})$/', $value, $match)) {
  1478. $buy_items[$match[1][0]] = $match[2][0];
  1479. }
  1480. }
  1481. }
  1482. return $buy_items;
  1483. }
  1484. /**
  1485. * 拼装单条满即送规则页面描述信息
  1486. * @param array $rule_info 满即送单条规则信息
  1487. * @return string
  1488. */
  1489. private function _parseMansongruleDesc($rule_info)
  1490. {
  1491. if (empty($rule_info) || !is_array($rule_info))
  1492. return;
  1493. $discount_desc = !empty($rule_info['mansongrule_discount']) ? '减' . $rule_info['mansongrule_discount'] : '';
  1494. $goods_desc = (!empty($rule_info['mansong_goods_name']) && !empty($rule_info['goods_storage'])) ? " 送<a href='" . (string)url('home/Goods/index', ['goods_id' => $rule_info['goods_id']]) . "' title='{$rule_info['mansong_goods_name']}' target='_blank'>[赠品]</a>" : '';
  1495. return sprintf('满%s%s%s', $rule_info['mansongrule_price'], $discount_desc, $goods_desc);
  1496. }
  1497. }