186 lines
6.3 KiB
PHP
186 lines
6.3 KiB
PHP
<?php
|
|
/**
|
|
* SaaSMall商城系统 - 团队十年电商经验汇集巨献!
|
|
* =========================================================
|
|
* Copy right 2019-2029 成都SAAS云科技有限公司, 保留所有权利。
|
|
* ----------------------------------------------
|
|
* 官方网址: https://www.gobuysaas.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);
|
|
}
|
|
} |