jh-admin/addon/fenxiao/model/FenxiaoGoodsSku.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);
}
}