| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 |
- <?php
- /**
- * Niushop商城系统 - 团队十年电商经验汇集巨献!
- * =========================================================
- * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
- * ----------------------------------------------
- * 官方网址: https://www.niushop.com
- * =========================================================
- */
- namespace addon\fenxiao\model;
- use app\model\BaseModel;
- /**
- * 分销
- */
- class FenxiaoGoodsSku extends BaseModel
- {
- /**
- * 添加分销商品
- * @param $data
- * @return array
- */
- public function addSku($data)
- {
- $res = model('fenxiao_goods_sku')->add($data);
- return $this->success($res);
- }
- /**
- * 编辑分销商品
- * @param $data
- * @param array $condition
- * @return array
- */
- public function editSku($data, $condition = [])
- {
- $data[ 'update_time' ] = time();
- $res = model('fenxiao_goods_sku')->update($data, $condition);
- return $this->success($res);
- }
- /**
- * 删除分销商品
- * @param array $condition
- * @return array
- */
- public function deleteSku($condition = [])
- {
- $res = model('fenxiao_goods_sku')->delete($condition);
- return $this->success($res);
- }
- /**
- * 获取分销商品详情
- * @param array $condition
- * @param string $field
- */
- 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')
- {
- $alias = 'fgs';
- $join = [
- [ 'goods_sku gs', 'fgs.sku_id = gs.sku_id', 'inner' ],
- [ 'goods g', 'g.goods_id = gs.goods_id', 'inner' ]
- ];
- $list = model('fenxiao_goods_sku')->getInfo($condition, $field, $alias, $join);
- return $this->success($list);
- }
- /**
- * 获取分销sku列表
- * @param array $condition
- * @param string $field
- * @param string $order
- * @param string $limit
- */
- public function getSkuList($condition = [], $field = '*', $order = '', $limit = null)
- {
- $list = model('fenxiao_goods_sku')->getList($condition, $field, $order, '', '', '', $limit);
- return $this->success($list);
- }
- /**
- * 获取分销商品分页列表
- * @param array $condition
- * @param int $page
- * @param int $page_size
- * @param string $order
- * @param string $field
- * @param string $order
- * @return array
- */
- 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')
- {
- $alias = 'g';
- $join = [
- [ 'goods_sku gs', 'g.sku_id = gs.sku_id', 'inner' ],
- ];
- $res = model('goods')->pageList($condition, $field, $order, $page, $page_size, $alias, $join);
- foreach ($res[ 'list' ] as $k => $v) {
- if (isset($v[ 'goods_stock' ])) {
- $res[ 'list' ][ $k ][ 'goods_stock' ] = numberFormat($res[ 'list' ][ $k ][ 'goods_stock' ]);
- }
- if (isset($v[ 'sale_num' ])) {
- $res[ 'list' ][ $k ][ 'sale_num' ] = numberFormat($res[ 'list' ][ $k ][ 'sale_num' ]);
- }
- if (isset($v[ 'virtual_sale' ])) {
- $res[ 'list' ][ $k ][ 'virtual_sale' ] = numberFormat($res[ 'list' ][ $k ][ 'virtual_sale' ]);
- }
- if (isset($v[ 'real_stock' ])) {
- $res[ 'list' ][ $k ][ 'real_stock' ] = numberFormat($res[ 'list' ][ $k ][ 'real_stock' ]);
- }
- if (isset($v[ 'stock' ])) {
- $res[ 'list' ][ $k ][ 'stock' ] = numberFormat($res[ 'list' ][ $k ][ 'stock' ]);
- }
- if (isset($v[ 'sale_sort' ])) {
- $res[ 'list' ][ $k ][ 'sale_sort' ] = numberFormat($res[ 'list' ][ $k ][ 'sale_sort' ]);
- }
- }
- return $this->success($res);
- }
- /**
- * 批量添加分销商品
- * @param $data
- */
- public function addSkuList($data)
- {
- $re = model('fenxiao_goods_sku')->addList($data);
- return $this->success($re);
- }
- /**
- * 获取分销商品信息
- * @param array $condition
- * @param string $field
- * @return array
- */
- public function getFenxiaoGoodsSkuInfo($condition = [], $field = "*")
- {
- $res = model('fenxiao_goods_sku')->getInfo($condition, $field);
- return $this->success($res);
- }
- /**
- * 获取商品一级分销佣金
- * @param $sku_id
- * @param $member_id
- */
- public function getSkuFenxiaoCommission($sku_id, $level_id)
- {
- $commission = 0.00;
- $condition = [ [ 'gs.sku_id', '=', $sku_id ], [ 'g.is_fenxiao', '=', 1 ] ];
- $join = [
- [ 'goods g', 'g.goods_id = gs.goods_id', 'inner' ]
- ];
- $sku_info = model('goods_sku')->getInfo($condition, 'g.fenxiao_type,gs.fenxiao_price,gs.discount_price', 'gs', $join);
- if (!empty($sku_info)) {
- $discount_price = $sku_info[ 'fenxiao_price' ] > 0 ? $sku_info[ 'fenxiao_price' ] : $sku_info[ 'discount_price' ];
- // 默认规则
- if ($sku_info[ 'fenxiao_type' ] == 1) {
- $fenxiao_level = new FenxiaoLevel();
- $level_info = $fenxiao_level->getLevelInfo([ [ 'level_id', '=', $level_id ] ], 'one_rate')[ 'data' ];
- if (!empty($level_info)) {
- $commission = number_format($discount_price * $level_info[ 'one_rate' ] / 100, 2, '.', '');
- }
- } else {
- $fenxiao_sku_info = $this->getFenxiaoGoodsSkuInfo([ [ 'level_id', '=', $level_id ], [ 'sku_id', '=', $sku_id ] ])[ 'data' ];
- if (!empty($fenxiao_sku_info)) {
- $commission = $fenxiao_sku_info[ 'one_money' ];
- if ($fenxiao_sku_info[ 'one_rate' ] > 0) {
- $commission = number_format($discount_price * $fenxiao_sku_info[ 'one_rate' ] / 100, 2, '.', '');
- }
- }
- }
- }
- return $this->success($commission);
- }
- }
|