BlindboxGoods.php 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace addon\blindbox\model;
  11. use app\model\BaseModel;
  12. class BlindboxGoods extends BaseModel
  13. {
  14. /**
  15. * 获取分页列表
  16. * @param array $condition
  17. * @param number $page
  18. * @param string $page_size
  19. * @param string $order
  20. * @param string $field
  21. */
  22. public function getBlindboxGoodsPageList($condition = [], $page = 1, $page_size = PAGE_LIST_ROWS, $order = 'id desc', $field = '*', $alias = 'a', $join = [])
  23. {
  24. $list = model('blindbox_goods')->pageList($condition, $field, $order, $page, $page_size, $alias, $join);
  25. return $this->success($list);
  26. }
  27. /**
  28. * 获取盲盒盒子信息
  29. * @param array $condition
  30. * @param bool $field
  31. * @param string $alias
  32. * @param null $join
  33. * @param null $data
  34. * @return array
  35. */
  36. public function getBlindboxGoodsInfo($condition = [], $field = true, $alias = 'a', $join = null, $data = null)
  37. {
  38. $res = model('blindbox_goods')->getInfo($condition, $field, $alias, $join, $data);
  39. return $this->success($res);
  40. }
  41. /**
  42. * 新增盲盒盒子
  43. * @param $data
  44. * @return array
  45. */
  46. public function addBlindboxGoods($data)
  47. {
  48. $blindbox_id = $data[ 'blindbox_id' ];
  49. $sku_id_arr = $data[ 'sku_id_arr' ];
  50. $site_id = $data[ 'site_id' ];
  51. $data = [
  52. 'blindbox_id' => $blindbox_id,
  53. 'site_id' => $site_id,
  54. 'create_time' => time(),
  55. ];
  56. $temp = [];
  57. model('blindbox_goods')->startTrans();
  58. try {
  59. if ($sku_id_arr) {
  60. foreach ($sku_id_arr as $k => $v) {
  61. $temp[ $k ] = $data;
  62. $temp[ $k ][ 'sku_id' ] = $v;
  63. $temp[ $k ][ 'sort' ] = rand(0, 100000);
  64. }
  65. $blindbox_condition = [
  66. [ 'blindbox_id', '=', $blindbox_id ]
  67. ];
  68. $goods_ids = model("blindbox")->getValue($blindbox_condition, 'goods_ids');
  69. #初始的父表下的sku_id
  70. $goods_data = explode(',', $goods_ids);
  71. #新的 父类下sku_id
  72. $goods_temp = array_unique(array_merge($goods_data, $sku_id_arr));
  73. model("blindbox")->update([ 'goods_ids' => implode(',', $goods_temp) ], $blindbox_condition);
  74. model("blindbox")->setInc($blindbox_condition, 'blindbox_count', count($sku_id_arr));
  75. model("blindbox")->setInc($blindbox_condition, 'blindbox_inventory', count($sku_id_arr));
  76. }
  77. $res = model("blindbox_goods")->addList($temp);
  78. model('blindbox_goods')->commit();
  79. return $this->success($res);
  80. } catch (\Exception $e) {
  81. model('blindbox_goods')->rollback();
  82. return $this->error($e->getMessage());
  83. }
  84. }
  85. /**
  86. * 编辑盲盒盒子
  87. * @param $data
  88. * @return array
  89. */
  90. public function editBlindboxGoods($data)
  91. {
  92. $blindbox_id = $data[ 'blindbox_id' ];
  93. $id = $data[ 'id' ];
  94. $sku_id = $data[ 'sku_id' ];
  95. $site_id = $data[ 'site_id' ];
  96. #父表
  97. $blindbox_condition = [
  98. [ 'blindbox_id', '=', $blindbox_id ]
  99. ];
  100. #子表
  101. $condition = [
  102. [ 'id', '=', $id ]
  103. ];
  104. model('blindbox_goods')->startTrans();
  105. try {
  106. $goods_ids = model("blindbox")->getValue($blindbox_condition, 'goods_ids');
  107. #初始的父表下的sku_id
  108. $goods_data = explode(',', $goods_ids);
  109. #获取当前盒子下sku_id(子表)(被修改的sku_id)
  110. $box_sku_id = model("blindbox_goods")->getValue($condition, 'sku_id');
  111. #获取要修改的sku_id的值
  112. $new_sku_num = model("blindbox_goods")->getCount([ [ 'site_id', '=', $site_id ], [ 'sku_id', '=', $sku_id ], [ 'blindbox_id', '=', $blindbox_id ] ]);
  113. #获取被修改的sku_id的值
  114. $old_sku_num = model("blindbox_goods")->getCount([ [ 'site_id', '=', $site_id ], [ 'sku_id', '=', $box_sku_id ], [ 'blindbox_id', '=', $blindbox_id ] ]);
  115. if ($new_sku_num > 0) {
  116. #存在不用变父表
  117. if ($old_sku_num == 1) {
  118. #只有一个改父表
  119. $key = array_search($box_sku_id, $goods_data);
  120. unset($goods_data[ $key ]);
  121. } else {
  122. #存在多个 不用改父表
  123. }
  124. } else {
  125. #变父表
  126. if ($old_sku_num == 1) {
  127. #只有一个改父表
  128. $key = array_search($box_sku_id, $goods_data);
  129. unset($goods_data[ $key ]);
  130. $goods_data = array_merge($goods_data, [ $sku_id ]);
  131. } else {
  132. #存在多个 不用改父表
  133. $goods_data = array_merge($goods_data, [ $sku_id ]);
  134. }
  135. }
  136. model("blindbox")->update([ 'goods_ids' => implode(',', $goods_data) ], $blindbox_condition);
  137. $res = model("blindbox_goods")->update([ 'sku_id' => $sku_id ], $condition);
  138. model('blindbox_goods')->commit();
  139. return $this->success($res);
  140. } catch (\Exception $e) {
  141. model('blindbox_goods')->rollback();
  142. return $this->error($e->getMessage());
  143. }
  144. }
  145. /**
  146. * 删除盲盒盒子
  147. * @param $data
  148. * @return array
  149. */
  150. public function delBlindboxGoods($data)
  151. {
  152. $blindbox_id = $data[ 'blindbox_id' ];
  153. $ids = $data[ 'ids' ];
  154. $sku_ids = $data[ 'sku_ids' ];
  155. $site_id = $data[ 'site_id' ];
  156. $blindbox_condition = [
  157. [ 'blindbox_id', '=', $blindbox_id ]
  158. ];
  159. model('blindbox_goods')->startTrans();
  160. try {
  161. #要删除的盒子 Id
  162. $ids_arr = explode(',', $ids);
  163. $count = model("blindbox_goods")->getCount([ [ 'site_id', '=', $site_id ], [ 'id', 'in', $ids_arr ], [ 'status', '=', 0 ] ]) ?? 0;
  164. if ($count != count($ids_arr)) {
  165. return $this->error('', '已拆的盲盒不可删除哦');
  166. }
  167. #要删除的sku
  168. $sku_ids_arr = explode(',', $sku_ids);
  169. $box_list = model("blindbox_goods")->getList([ [ 'site_id', '=', $site_id ], [ 'blindbox_id', '=', $blindbox_id ] ], 'sku_id') ?? [];
  170. #拥有的sku
  171. $sku_arr = [];
  172. if ($box_list) {
  173. $sku_arr = array_column($box_list, 'sku_id');
  174. }
  175. #删除操作
  176. foreach ($sku_arr as $k => $v) {
  177. foreach ($sku_ids_arr as $key => $val) {
  178. if ($v == $val) {
  179. unset($sku_arr[ $k ]);
  180. unset($sku_ids_arr[ $key ]);
  181. break;
  182. }
  183. }
  184. }
  185. #删除完的sku $sku_arr
  186. #去除重复值
  187. $sku_arr = array_unique($sku_arr);
  188. $goods_data = implode(',', $sku_arr);
  189. model("blindbox")->update([ 'goods_ids' => $goods_data ], $blindbox_condition);
  190. #库存减一 发放量减一
  191. model("blindbox")->setDec($blindbox_condition, 'blindbox_count', $count);
  192. model("blindbox")->setDec($blindbox_condition, 'blindbox_inventory', $count);
  193. $condition = [ [ 'id', 'in', $ids_arr ] ];
  194. $res = model("blindbox_goods")->delete($condition);
  195. model('blindbox_goods')->commit();
  196. return $this->success($res);
  197. } catch (\Exception $e) {
  198. model('blindbox_goods')->rollback();
  199. return $this->error($e->getMessage());
  200. }
  201. }
  202. /**
  203. * 盲盒盒子列表
  204. * @param $condition
  205. * @param bool $field
  206. * @param string $order
  207. * @param string $alias
  208. * @param array $join
  209. * @return array
  210. */
  211. public function getBlindboxGoodsList($condition)
  212. {
  213. $alias = 'a';
  214. $field = 'a.*,gs.sku_name,gs.price,gs.sku_image,gs.stock,gs.goods_id';
  215. $join = [
  216. [ 'goods_sku gs', 'gs.sku_id = a.sku_id', 'left' ]
  217. ];
  218. $order = '';
  219. $list = model("blindbox_goods")->getList($condition, $field, $order, $alias, $join);
  220. return $this->success($list);
  221. }
  222. public function getBlindboxGoodsCount($condition, $field = '*')
  223. {
  224. $res = model('blindbox_goods')->getCount($condition, $field);
  225. return $this->success($res);
  226. }
  227. public function getSkuInfo($condition, $field = '*')
  228. {
  229. $info = model('goods_sku')->getInfo($condition, $field);
  230. return $this->success($info);
  231. }
  232. }