FenxiaoGoodsSku.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace addon\fenxiao\model;
  11. use app\model\BaseModel;
  12. /**
  13. * 分销
  14. */
  15. class FenxiaoGoodsSku extends BaseModel
  16. {
  17. /**
  18. * 添加分销商品
  19. * @param $data
  20. * @return array
  21. */
  22. public function addSku($data)
  23. {
  24. $res = model('fenxiao_goods_sku')->add($data);
  25. return $this->success($res);
  26. }
  27. /**
  28. * 编辑分销商品
  29. * @param $data
  30. * @param array $condition
  31. * @return array
  32. */
  33. public function editSku($data, $condition = [])
  34. {
  35. $data[ 'update_time' ] = time();
  36. $res = model('fenxiao_goods_sku')->update($data, $condition);
  37. return $this->success($res);
  38. }
  39. /**
  40. * 删除分销商品
  41. * @param array $condition
  42. * @return array
  43. */
  44. public function deleteSku($condition = [])
  45. {
  46. $res = model('fenxiao_goods_sku')->delete($condition);
  47. return $this->success($res);
  48. }
  49. /**
  50. * 获取分销商品详情
  51. * @param array $condition
  52. * @param string $field
  53. */
  54. public function getFenxiaoGoodsSkuDetail($condition = [], $field = 'fgs.goods_sku_id,fgs.goods_id,fgs.sku_id,fgs.level_id,fgs.one_rate,fgs.one_money,fgs.two_rate,fgs.two_money,fgs.three_rate,fgs.three_money,gs.discount_price,gs.fenxiao_price')
  55. {
  56. $alias = 'fgs';
  57. $join = [
  58. [ 'goods_sku gs', 'fgs.sku_id = gs.sku_id', 'inner' ],
  59. [ 'goods g', 'g.goods_id = gs.goods_id', 'inner' ]
  60. ];
  61. $list = model('fenxiao_goods_sku')->getInfo($condition, $field, $alias, $join);
  62. return $this->success($list);
  63. }
  64. /**
  65. * 获取分销sku列表
  66. * @param array $condition
  67. * @param string $field
  68. * @param string $order
  69. * @param string $limit
  70. */
  71. public function getSkuList($condition = [], $field = '*', $order = '', $limit = null)
  72. {
  73. $list = model('fenxiao_goods_sku')->getList($condition, $field, $order, '', '', '', $limit);
  74. return $this->success($list);
  75. }
  76. /**
  77. * 获取分销商品分页列表
  78. * @param array $condition
  79. * @param int $page
  80. * @param int $page_size
  81. * @param string $order
  82. * @param string $field
  83. * @param string $order
  84. * @return array
  85. */
  86. public function getFenxiaoGoodsSkuPageList($condition = [], $page = 1, $page_size = PAGE_LIST_ROWS, $order = 'g.create_time desc', $field = 'g.goods_id,g.label_name,g.goods_name,g.goods_image,g.sku_id,gs.sku_name,gs.discount_price,gs.price,gs.stock,gs.sale_num,gs.sku_image,gs.fenxiao_price,g.fenxiao_type,(g.sale_num + g.virtual_sale) as sale_sort')
  87. {
  88. $alias = 'g';
  89. $join = [
  90. [ 'goods_sku gs', 'g.sku_id = gs.sku_id', 'inner' ],
  91. ];
  92. $res = model('goods')->pageList($condition, $field, $order, $page, $page_size, $alias, $join);
  93. foreach ($res[ 'list' ] as $k => $v) {
  94. if (isset($v[ 'goods_stock' ])) {
  95. $res[ 'list' ][ $k ][ 'goods_stock' ] = numberFormat($res[ 'list' ][ $k ][ 'goods_stock' ]);
  96. }
  97. if (isset($v[ 'sale_num' ])) {
  98. $res[ 'list' ][ $k ][ 'sale_num' ] = numberFormat($res[ 'list' ][ $k ][ 'sale_num' ]);
  99. }
  100. if (isset($v[ 'virtual_sale' ])) {
  101. $res[ 'list' ][ $k ][ 'virtual_sale' ] = numberFormat($res[ 'list' ][ $k ][ 'virtual_sale' ]);
  102. }
  103. if (isset($v[ 'real_stock' ])) {
  104. $res[ 'list' ][ $k ][ 'real_stock' ] = numberFormat($res[ 'list' ][ $k ][ 'real_stock' ]);
  105. }
  106. if (isset($v[ 'stock' ])) {
  107. $res[ 'list' ][ $k ][ 'stock' ] = numberFormat($res[ 'list' ][ $k ][ 'stock' ]);
  108. }
  109. if (isset($v[ 'sale_sort' ])) {
  110. $res[ 'list' ][ $k ][ 'sale_sort' ] = numberFormat($res[ 'list' ][ $k ][ 'sale_sort' ]);
  111. }
  112. }
  113. return $this->success($res);
  114. }
  115. /**
  116. * 批量添加分销商品
  117. * @param $data
  118. */
  119. public function addSkuList($data)
  120. {
  121. $re = model('fenxiao_goods_sku')->addList($data);
  122. return $this->success($re);
  123. }
  124. /**
  125. * 获取分销商品信息
  126. * @param array $condition
  127. * @param string $field
  128. * @return array
  129. */
  130. public function getFenxiaoGoodsSkuInfo($condition = [], $field = "*")
  131. {
  132. $res = model('fenxiao_goods_sku')->getInfo($condition, $field);
  133. return $this->success($res);
  134. }
  135. /**
  136. * 获取商品一级分销佣金
  137. * @param $sku_id
  138. * @param $member_id
  139. */
  140. public function getSkuFenxiaoCommission($sku_id, $level_id)
  141. {
  142. $commission = 0.00;
  143. $condition = [ [ 'gs.sku_id', '=', $sku_id ], [ 'g.is_fenxiao', '=', 1 ] ];
  144. $join = [
  145. [ 'goods g', 'g.goods_id = gs.goods_id', 'inner' ]
  146. ];
  147. $sku_info = model('goods_sku')->getInfo($condition, 'g.fenxiao_type,gs.fenxiao_price,gs.discount_price', 'gs', $join);
  148. if (!empty($sku_info)) {
  149. $discount_price = $sku_info[ 'fenxiao_price' ] > 0 ? $sku_info[ 'fenxiao_price' ] : $sku_info[ 'discount_price' ];
  150. // 默认规则
  151. if ($sku_info[ 'fenxiao_type' ] == 1) {
  152. $fenxiao_level = new FenxiaoLevel();
  153. $level_info = $fenxiao_level->getLevelInfo([ [ 'level_id', '=', $level_id ] ], 'one_rate')[ 'data' ];
  154. if (!empty($level_info)) {
  155. $commission = number_format($discount_price * $level_info[ 'one_rate' ] / 100, 2, '.', '');
  156. }
  157. } else {
  158. $fenxiao_sku_info = $this->getFenxiaoGoodsSkuInfo([ [ 'level_id', '=', $level_id ], [ 'sku_id', '=', $sku_id ] ])[ 'data' ];
  159. if (!empty($fenxiao_sku_info)) {
  160. $commission = $fenxiao_sku_info[ 'one_money' ];
  161. if ($fenxiao_sku_info[ 'one_rate' ] > 0) {
  162. $commission = number_format($discount_price * $fenxiao_sku_info[ 'one_rate' ] / 100, 2, '.', '');
  163. }
  164. }
  165. }
  166. }
  167. return $this->success($commission);
  168. }
  169. }