You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
121 lines
4.2 KiB
121 lines
4.2 KiB
<?php
|
|
|
|
namespace App\Admin\Repositories\v3;
|
|
|
|
use App\Models\LanzuOrderGoods as Model;
|
|
use Dcat\Admin\Grid\Model as GridModel;
|
|
use Dcat\Admin\Repositories\EloquentRepository;
|
|
use Illuminate\Support\Facades\DB;
|
|
use App\Models\ImsCjdcOrderMain as OrderMainModel;
|
|
use App\Models\ImsCjdcOrder as OrderModel;
|
|
|
|
class GoodsReport extends EloquentRepository
|
|
{
|
|
public $params = [];
|
|
/**
|
|
* Model.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $eloquentClass = Model::class;
|
|
|
|
public function __construct($params = [])
|
|
{
|
|
$this->params = $params;
|
|
}
|
|
|
|
/**
|
|
* 获取统计列表数据
|
|
*/
|
|
public function get(GridModel $model)
|
|
{
|
|
// 获取当前页数
|
|
$currentPage = $model->getCurrentPage();
|
|
// 获取每页显示行数
|
|
$perPage = $model->getPerPage();
|
|
|
|
$where = [];
|
|
if(!empty($this->params) && isset($this->params['market_id']) && !empty($this->params['market_id'])){
|
|
$where = ['market_id'=>$this->params['market_id']];
|
|
}
|
|
|
|
$selects = Model::$tableName.'.goods_id,'.Model::$tableName.'.name,price,original_price,'.Model::$tableName.'.cover_img,'.OrderMainModel::$tableName.'.market_id,'.OrderModel::$tableName.'.store_id,number,'.OrderMainModel::$tableName.'.created_at,global_order_id';
|
|
$orderGoods = $this->getDataModel($selects,$where);
|
|
$list = $orderGoods->orderBy(OrderMainModel::$tableName.'.id','desc')->paginate($perPage);
|
|
$list = $list->toArray();
|
|
|
|
return $model->makePaginator(
|
|
$list['total'] ?? 0,$list['data'] ?? []
|
|
);
|
|
|
|
}
|
|
|
|
public function getDataModel($selects,$params = [])
|
|
{
|
|
// 获取筛选参数
|
|
$goodsId = $params['goods_id'] ?? request()->input('goods_id',0);
|
|
$name = $params['name'] ?? request()->input('name', '');
|
|
$marketId = $params['market_id'] ?? request()->input('market_id',0);
|
|
$storeId = $params['store_id'] ?? request()->input('store_id',0);
|
|
|
|
$startTime = $params['start_time'] ?? request()->input('start_time','');
|
|
$endTime = $params['end_time'] ?? request()->input('end_time','');
|
|
|
|
$orderGoods = Model::select(DB::raw($selects))
|
|
->join(OrderModel::$tableName,Model::$tableName.'.order_id','=',OrderModel::$tableName.'.id')
|
|
->join(OrderMainModel::$tableName,OrderModel::$tableName.'.order_main_id','=',OrderMainModel::$tableName.'.global_order_id')
|
|
->where(Model::$tableName.'.activity_type',1)
|
|
->where(Model::$tableName.'.status',1)
|
|
->whereIn(OrderMainModel::$tableName.'.state',[4,5,10,11]);
|
|
|
|
if($goodsId){
|
|
$goodsIds = explode(',',$goodsId);
|
|
$orderGoods->whereIn(Model::$tableName.'.goods_id',$goodsIds);
|
|
}
|
|
if($name){
|
|
$orderGoods->where(Model::$tableName.'.name','like',"%$name%");
|
|
}
|
|
if($marketId){
|
|
$orderGoods->where('market_id',$marketId);
|
|
}
|
|
if($storeId){
|
|
$orderGoods->where('store_id',$storeId);
|
|
}
|
|
if($startTime){
|
|
$startTime = $startTime.' 00:00:00';
|
|
|
|
$orderGoods->where(Model::$tableName.'.created_at','>=',strtotime($startTime));
|
|
}
|
|
if($endTime){
|
|
$endTime = $endTime.' 23:59:59';
|
|
|
|
$orderGoods->where(Model::$tableName.'.created_at','<=',strtotime($endTime));
|
|
}
|
|
|
|
return $orderGoods;
|
|
}
|
|
|
|
/**
|
|
* 获取总数
|
|
*/
|
|
public function getCountData($params = [])
|
|
{
|
|
$selects = "SUM(lanzu_order_goods.number) as total,SUM((original_price-price)*number) as subsidy_total,FROM_UNIXTIME(lanzu_order_goods.created_at,'%Y-%m-%d') as dtime";
|
|
$orderGoods = $this->getDataModel($selects,$params);
|
|
$total = $orderGoods->orderBy('dtime','asc')->groupBy('dtime')->get()->toArray();
|
|
|
|
return $total ?? [];
|
|
}
|
|
|
|
/**
|
|
* 分市场获取
|
|
*/
|
|
public function getMarketData($params = [])
|
|
{
|
|
$selects = "SUM(lanzu_order_goods.number) as total,SUM((original_price-price)*number) as subsidy_total,market_id";
|
|
$orderGoods = $this->getDataModel($selects,$params);
|
|
$total = $orderGoods->groupBy('market_id')->get()->toArray();
|
|
|
|
return $total ?? [];
|
|
}
|
|
}
|