Bundling.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 山西牛酷信息科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com.cn
  8. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用。
  9. * 任何企业和个人不允许对程序代码以任何形式任何目的再发布。
  10. * =========================================================
  11. */
  12. namespace addon\bundling\model;
  13. use app\model\shop\Shop as ShopModel;
  14. use app\model\BaseModel;
  15. /**
  16. * 优惠套餐
  17. */
  18. class Bundling extends BaseModel
  19. {
  20. /**
  21. * TODO 添加优惠套餐
  22. * @param $data
  23. * @param $sku_ids
  24. * @return array|\multitype
  25. */
  26. public function addBundling($data, $sku_ids)
  27. {
  28. if($data["bl_price"] <= 0){
  29. return $this->error([], "优惠套餐价格不能小于或等与0");
  30. }
  31. model("promotion_bundling")->startTrans();
  32. try {
  33. $sku_id_array = explode(',', $sku_ids);
  34. $goods_money = 0;
  35. $sku_array = [];
  36. foreach ($sku_id_array as $k => $v) {
  37. $sku_info = model("goods_sku")->getInfo([ [ 'sku_id', '=', $v ] ], 'sku_id,sku_name,price,sku_image,is_virtual');
  38. if($sku_info["is_virtual"] == 1){
  39. model("promotion_bundling")->rollback();
  40. return $this->error([], "优惠套餐中不能包含虚拟商品");
  41. }
  42. unset($sku_info["is_virtual"]);
  43. $goods_money += $sku_info['price'];
  44. $sku_array[] = $sku_info;
  45. }
  46. $data["goods_money"] = $goods_money;
  47. $data["update_time"] = time();
  48. $shop_model = new ShopModel();
  49. $shop_info_result = $shop_model->getShopInfo([ [ "site_id", "=", $data["site_id"] ] ], "site_name");
  50. $shop_info = $shop_info_result["data"];
  51. $data["site_name"] = $shop_info["site_name"];
  52. $bundling_id = model("promotion_bundling")->add($data);
  53. foreach ($sku_array as $k => $v) {
  54. $v['bl_id'] = $bundling_id;
  55. $v['site_id'] = $data["site_id"];
  56. $v['promotion_price'] = $v['price'] / $goods_money * $data['bl_price'];
  57. model("promotion_bundling_goods")->add($v);
  58. }
  59. model("promotion_bundling")->commit();
  60. return $this->success($bundling_id);
  61. } catch (\Exception $e) {
  62. model("promotion_bundling")->rollback();
  63. return $this->error('', $e->getMessage());
  64. }
  65. }
  66. /**
  67. * 编辑优惠套餐
  68. * @param unknown $data
  69. * @param unknown $sku_ids
  70. */
  71. public function editBundling($data, $sku_ids, $condition)
  72. {
  73. if($data["bl_price"] <= 0){
  74. return $this->error([], "优惠套餐价格不能小于或等与0");
  75. }
  76. $check_condition = array_column($condition, 2, 0);
  77. model("promotion_bundling")->startTrans();
  78. try {
  79. model("promotion_bundling_goods")->delete($condition);
  80. $sku_id_array = explode(',', $sku_ids);
  81. $goods_money = 0;
  82. $sku_array = [];
  83. foreach ($sku_id_array as $k => $v) {
  84. $sku_info = model("goods_sku")->getInfo([ [ 'sku_id', '=', $v ] ], 'sku_id,sku_name,price,sku_image,is_virtual');
  85. if($sku_info["is_virtual"] == 1){
  86. model("promotion_bundling")->rollback();
  87. return $this->error([], "优惠套餐中不能包含虚拟商品");
  88. }
  89. unset($sku_info["is_virtual"]);
  90. $sku_info['bl_id'] = $check_condition['bl_id'];
  91. $goods_money += $sku_info['price'];
  92. $sku_array[] = $sku_info;
  93. }
  94. $data["goods_money"] = $goods_money;
  95. $data["update_time"] = time();
  96. $res = model("promotion_bundling")->update($data, $condition);
  97. foreach ($sku_array as $k => $v) {
  98. $v['promotion_price'] = $v['price'] / $goods_money * $data['bl_price'];
  99. $v["site_id"] = $check_condition["site_id"];
  100. model("promotion_bundling_goods")->add($v);
  101. }
  102. model("promotion_bundling")->commit();
  103. return $this->success($res);
  104. } catch (\Exception $e) {
  105. model("promotion_bundling")->rollback();
  106. return $this->error('', $e->getMessage());
  107. }
  108. }
  109. /**
  110. * 删除优惠套餐
  111. * @param number $bl_id
  112. * @param number $site_id
  113. */
  114. public function deleteBundling($bl_id, $site_id)
  115. {
  116. $condition = array(
  117. [ 'bl_id', "=", $bl_id ],
  118. [ "site_id", "=", $site_id ]
  119. );
  120. $res = model('promotion_bundling')->delete($condition);
  121. if ($res) {
  122. model('promotion_bundling_goods')->delete([ 'bl_id' => $bl_id ]);
  123. return $this->success($res);
  124. } else {
  125. return $this->error();
  126. }
  127. }
  128. /**
  129. * 获取优惠套餐详情
  130. * @param unknown $bundling_id
  131. */
  132. public function getBundlingInfo($condition)
  133. {
  134. $data = model("promotion_bundling")->getInfo($condition, 'bl_id,bl_name, site_id, site_name, bl_price, goods_money, shipping_fee_type,status');
  135. return $this->success($data);
  136. }
  137. /**
  138. * 获取优惠套餐详情
  139. * @param unknown $bundling_id
  140. */
  141. public function getBundlingDetail($condition)
  142. {
  143. $check_condition = array_column($condition, 2, 0);
  144. $bl_id = isset($check_condition['bl_id']) ? $check_condition['bl_id'] : '';
  145. $data = model("promotion_bundling")->getInfo($condition, 'bl_id,bl_name, site_id, site_name, bl_price, goods_money, shipping_fee_type,status');
  146. if (!empty($data)) {
  147. $field = 'pbg.sku_id, pbg.sku_name, pbg.price, pbg.sku_image, pbg.promotion_price,ngs.stock,ngs.unit';
  148. $order = '';
  149. $alias = 'pbg';
  150. $join = [
  151. [
  152. 'goods_sku ngs',
  153. 'pbg.sku_id = ngs.sku_id',
  154. 'inner'
  155. ],
  156. ];
  157. $data['bundling_goods'] = model("promotion_bundling_goods")->getList([ [ 'pbg.bl_id', '=', $bl_id ] ], $field, $order, $alias, $join);
  158. }
  159. return $this->success($data);
  160. }
  161. /**
  162. * 获取商品优惠套餐
  163. * @param $sku_id
  164. * @return array
  165. */
  166. public function getBundlingGoods($sku_id)
  167. {
  168. $bundling_ids = model("promotion_bundling_goods")->getList([ [ 'sku_id', '=', $sku_id ] ], 'bl_id');
  169. $bundling_array = [];
  170. foreach ($bundling_ids as $k => $v) {
  171. $temp_result = $this->getBundlingDetail([ [ 'bl_id', '=', $v["bl_id"] ] ]);
  172. $bundling_array[] = $temp_result["data"];
  173. }
  174. return $this->success($bundling_array);
  175. }
  176. /**
  177. * 获取优惠餐列表
  178. * @param array $condition
  179. * @param number $page
  180. * @param string $page_size
  181. * @param string $order
  182. * @param string $field
  183. */
  184. public function getBundlingPageList($condition = [], $page = 1, $page_size = PAGE_LIST_ROWS, $order = '', $field = '*')
  185. {
  186. $list = model('promotion_bundling')->pageList($condition, $field, $order, $page, $page_size);
  187. return $this->success($list);
  188. }
  189. }