commit
f9ad591330
File diff suppressed because it is too large
Load Diff
@ -1,282 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace app\admin\controller\system_store;
|
||||
|
||||
|
||||
use app\admin\controller\BaseAdminController;
|
||||
use app\admin\lists\system_store\SystemStoreLists;
|
||||
use app\admin\lists\system_store\SystemStoreSourceLists;
|
||||
use app\admin\logic\store_product\StoreProductLogic;
|
||||
use app\admin\logic\system_store\SystemStoreLogic;
|
||||
use app\admin\validate\system_store\SystemStoreValidate;
|
||||
|
||||
|
||||
/**
|
||||
* 门店统计
|
||||
* Class SystemStoreController
|
||||
* @package app\admin\controller\system_store
|
||||
*/
|
||||
class SystemStoreStatisticsController extends BaseAdminController
|
||||
{
|
||||
|
||||
|
||||
/**
|
||||
* @notes 获取门店统计头部
|
||||
* @return \think\response\Json
|
||||
* @author admin
|
||||
* @date 2024/05/31 17=>45
|
||||
*/
|
||||
public function header()
|
||||
{
|
||||
|
||||
$data = [
|
||||
'card_count' => 0,
|
||||
'cashier_order_price' => 28762.69,
|
||||
'recharge_price' => 2004402.08,
|
||||
'store_income' => 34974.53,
|
||||
'store_order_price' => 1681.30,
|
||||
'store_pay_user_count' => 48,
|
||||
'store_use_yue' => 6734.52,
|
||||
'store_user_count' => 76,
|
||||
'store_writeoff_order_price' => 4530.54,
|
||||
'vip_price' => 1000.00,
|
||||
];
|
||||
return $this->data($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* 交易/类型数据
|
||||
*/
|
||||
public function orderChart()
|
||||
{
|
||||
$order_list = [
|
||||
[
|
||||
"id" => 11127,
|
||||
"order_id" => "wx529263627312562176",
|
||||
"uid" => 0,
|
||||
"pay_price" => "257.20",
|
||||
"pay_time" => 1717472682,
|
||||
"avatar" => null,
|
||||
"nickname" => null,
|
||||
"phone" => null,
|
||||
"now_money" => null,
|
||||
"integral" => null,
|
||||
"delete_time" => null,
|
||||
"refund" => []
|
||||
],
|
||||
[
|
||||
"id" => 11120,
|
||||
"order_id" => "wx529242351697133568",
|
||||
"uid" => 0,
|
||||
"pay_price" => "4.48",
|
||||
"pay_time" => 1717467609,
|
||||
"avatar" => null,
|
||||
"nickname" => null,
|
||||
"phone" => null,
|
||||
"now_money" => null,
|
||||
"integral" => null,
|
||||
"delete_time" => null,
|
||||
"refund" => []
|
||||
]
|
||||
];
|
||||
$bing_xdata = [
|
||||
"收银订单",
|
||||
"充值订单",
|
||||
"分配订单",
|
||||
"核销订单",
|
||||
"付费会员订单"
|
||||
];
|
||||
$bing_data = [
|
||||
[
|
||||
"name" => "收银订单",
|
||||
"value" => 29019.89,
|
||||
"itemStyle" => [
|
||||
"color" => "#2EC479"
|
||||
]
|
||||
],
|
||||
[
|
||||
"name" => "充值订单",
|
||||
"value" => 2004402.08,
|
||||
"itemStyle" => [
|
||||
"color" => "#7F7AE5"
|
||||
]
|
||||
],
|
||||
[
|
||||
"name" => "分配订单",
|
||||
"value" => 1681.3,
|
||||
"itemStyle" => [
|
||||
"color" => "#FFA21B"
|
||||
]
|
||||
],
|
||||
|
||||
[
|
||||
"name" => "核销订单",
|
||||
"value" => 4530.54,
|
||||
"itemStyle" => [
|
||||
"color" => "#46A3FF"
|
||||
]
|
||||
],
|
||||
[
|
||||
"name" => "付费会员订单",
|
||||
"value" => 1000,
|
||||
"itemStyle" => [
|
||||
"color" => "#FF6046"
|
||||
]
|
||||
]
|
||||
];
|
||||
$data = [
|
||||
'order_list' => $order_list,
|
||||
'bing_xdata' => $bing_xdata,
|
||||
'bing_data' => $bing_data,
|
||||
];
|
||||
return $this->data($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* 营业趋势
|
||||
*/
|
||||
public function operate(){
|
||||
$xAxis=[
|
||||
"05-06",
|
||||
"05-07",
|
||||
"05-08",
|
||||
"05-09",
|
||||
"05-10",
|
||||
"05-11",
|
||||
"05-12",
|
||||
"05-13",
|
||||
"05-14",
|
||||
"05-15",
|
||||
"05-16",
|
||||
"05-17",
|
||||
"05-18",
|
||||
"05-19",
|
||||
"05-20",
|
||||
"05-21",
|
||||
"05-22",
|
||||
"05-23",
|
||||
"05-24",
|
||||
"05-25",
|
||||
"05-26",
|
||||
"05-27",
|
||||
"05-28",
|
||||
"05-29",
|
||||
"05-30",
|
||||
"05-31",
|
||||
"06-01",
|
||||
"06-02",
|
||||
"06-03",
|
||||
"06-04"
|
||||
];
|
||||
$series=[
|
||||
[
|
||||
"name"=> "门店收款",
|
||||
"data"=> [
|
||||
171.29,
|
||||
167.46,
|
||||
1455.65,
|
||||
45.47,
|
||||
542.69,
|
||||
216.58,
|
||||
228.82,
|
||||
34.24,
|
||||
8249.85,
|
||||
664.23,
|
||||
8586.24,
|
||||
10.19,
|
||||
90.19,
|
||||
105.4,
|
||||
62.59,
|
||||
1051.34,
|
||||
160.84,
|
||||
2437.68,
|
||||
111374.41,
|
||||
12161.05,
|
||||
189,
|
||||
4831.65,
|
||||
1276.31,
|
||||
582.4,
|
||||
906.02,
|
||||
597,
|
||||
0.08,
|
||||
771.16,
|
||||
10262.64,
|
||||
261.68
|
||||
],
|
||||
"type"=> "line",
|
||||
"smooth"=> "true",
|
||||
"yAxisIndex"=> 1
|
||||
],
|
||||
[
|
||||
"name"=> "新增用户数",
|
||||
"data"=> [
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0
|
||||
],
|
||||
"type"=> "line",
|
||||
"smooth"=> "true",
|
||||
"yAxisIndex"=> 1
|
||||
]
|
||||
];
|
||||
$data = [
|
||||
'xAxis' => $xAxis,
|
||||
'series' => $series,
|
||||
];
|
||||
return $this->data($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* 门店业绩
|
||||
*/
|
||||
public function store(){
|
||||
$data=[
|
||||
[
|
||||
"id"=> 46,
|
||||
"name"=> "王多鱼的商超",
|
||||
"image"=> "https:multi-store.crmeb.net/uploads/attach/2024/05/20240527/f9b8b3c3cd5f1113bd7d374dc55d320a.jpg",
|
||||
"store_price"=> 797.88,
|
||||
"store_product_count"=> 18,
|
||||
"store_order_price"=> 1275.16,
|
||||
"store_user_count"=> 6
|
||||
],
|
||||
[
|
||||
"id"=> 43,
|
||||
"name"=> "这是直营店",
|
||||
"image"=> "https:multi-store.crmeb.net/uploads/attach/2024/05/20240524/9066528e73e2db60d31a704d321ba4a5.jpeg",
|
||||
"store_price"=> 203.11,
|
||||
"store_product_count"=> 10,
|
||||
"store_order_price"=> 579.01,
|
||||
"store_user_count"=> 8
|
||||
],
|
||||
];
|
||||
return $this->data($data);
|
||||
}
|
||||
}
|
@ -65,4 +65,21 @@ class UserController extends BaseAdminController
|
||||
}
|
||||
return $this->fail(UserLogic::getError());
|
||||
}
|
||||
|
||||
//采购款明细、余额明细、礼品券明细、返还金明细
|
||||
public function fundList()
|
||||
{
|
||||
(new UserValidate())->get()->goCheck('fund');
|
||||
$page_no = (int)$this->request->get('page_no', 1);
|
||||
$page_size = (int)$this->request->get('page_size', 15);
|
||||
$params = $this->request->get();
|
||||
$params['page_no'] = $page_no > 0 ? $page_no : 1;
|
||||
$params['page_size'] = $page_size > 0 ? $page_size : 15;
|
||||
$res = UserLogic::dealDetails($params);
|
||||
$res['page_no'] = $params['page_no'];
|
||||
$res['page_size'] = $params['page_size'];
|
||||
return $this->success('ok', $res);
|
||||
|
||||
}
|
||||
|
||||
}
|
@ -63,7 +63,7 @@ class StoreBranchProductLists extends BaseAdminDataLists implements ListsSearchI
|
||||
}
|
||||
|
||||
return StoreBranchProduct::where($this->searchWhere)->where($where)
|
||||
->field(['id','store_id','product_id', 'image', 'store_name', 'cate_id', 'price', 'sales', 'stock', 'unit', 'cost','purchase', 'status'])
|
||||
->field(['id','store_id','product_id', 'image', 'store_name', 'cate_id', 'price', 'sales', 'stock', 'unit', 'cost','purchase', 'status','batch','vip_price'])
|
||||
->when(!empty($this->adminInfo['store_id']), function ($query) {
|
||||
$query->where('store_id', $this->adminInfo['store_id']);
|
||||
})
|
||||
|
@ -11,6 +11,7 @@ use app\common\lists\ListsSearchInterface;
|
||||
use app\common\model\system_store\SystemStore;
|
||||
use app\common\model\system_store\SystemStoreStaff;
|
||||
use app\common\model\user\User;
|
||||
use app\common\model\user_sign\UserSign;
|
||||
use think\db\Query;
|
||||
|
||||
/**
|
||||
@ -32,8 +33,8 @@ class StoreFinanceFlowLists extends BaseAdminDataLists implements ListsSearchInt
|
||||
{
|
||||
return [
|
||||
'=' => ['store_id', 'user_id', 'create_time', 'staff_id'],
|
||||
'between_time'=>'create_time',
|
||||
'%pipe_like%' => ['keyword'=>'order_sn'],
|
||||
'between_time' => 'create_time',
|
||||
'%pipe_like%' => ['keyword' => 'order_sn'],
|
||||
];
|
||||
}
|
||||
|
||||
@ -49,7 +50,13 @@ class StoreFinanceFlowLists extends BaseAdminDataLists implements ListsSearchInt
|
||||
*/
|
||||
public function lists(): array
|
||||
{
|
||||
return StoreFinanceFlow::where($this->searchWhere)
|
||||
$field = [
|
||||
'id','order_id', 'order_sn', 'create_time', 'other_uid', 'user_id', 'store_id', 'staff_id', 'financial_type', 'financial_pm', 'pay_type', 'type', 'number', 'status'
|
||||
];
|
||||
$this->searchWhere[] = ['financial_type', '=', 1];
|
||||
$this->searchWhere[] = ['financial_pm', '=', 1];
|
||||
$data = StoreFinanceFlow::where($this->searchWhere)
|
||||
->field($field)
|
||||
->limit($this->limitOffset, $this->limitLength)
|
||||
->order(['id' => 'desc'])
|
||||
->select()->each(function ($item) {
|
||||
@ -64,16 +71,53 @@ class StoreFinanceFlowLists extends BaseAdminDataLists implements ListsSearchInt
|
||||
}
|
||||
if ($item['financial_pm'] == 0) {
|
||||
$item['number'] = '-' . $item['number'];
|
||||
$item['financial_type_name'] = '订单支出:'.OrderEnum::getFinancialType($item['financial_type']);
|
||||
$item['financial_type_name'] = '订单支出:' . OrderEnum::getFinancialType($item['financial_type']);
|
||||
} else {
|
||||
$item['financial_type_name'] = OrderEnum::getFinancialType($item['financial_type']).'获得';
|
||||
$item['financial_type_name'] = OrderEnum::getFinancialType($item['financial_type']) . '获得';
|
||||
$item['number'] = '+' . $item['number'];
|
||||
}
|
||||
$item['staff_name'] = SystemStoreStaff::where('id', $item['staff_id'])->value('staff_name');
|
||||
$item['store_name'] = $item['store_id'] > 0 ? SystemStore::where('id', $item['store_id'])->value('name') : '';
|
||||
$item['pay_type_name'] = PayEnum::getPaySceneDesc($item['pay_type']);
|
||||
})
|
||||
->toArray();
|
||||
})->toArray();
|
||||
|
||||
foreach ($data as $key => $item) {
|
||||
$list1= StoreFinanceFlow::where('order_id' ,$item['order_id'])->where('financial_type','>', 1)->field($field)->order('financial_pm','desc')->select()->each(function ($item) {
|
||||
if ($item['user_id'] <= 0) {
|
||||
$item['nickname'] = '游客';
|
||||
} else {
|
||||
$id = $item['user_id'];
|
||||
$item['nickname'] = User::where('id', $item['user_id'])->value('nickname') . "|$id";
|
||||
}
|
||||
if (!empty($this->request->adminInfo['store_id'])) {
|
||||
$item['financial_pm'] = $item['financial_pm'] == 0 ? 1 : 0;
|
||||
}
|
||||
if ($item['financial_pm'] == 0) {
|
||||
$item['number'] = '-' . $item['number'];
|
||||
$item['financial_type_name'] = '订单支出:' . OrderEnum::getFinancialType($item['financial_type']);
|
||||
} else {
|
||||
$item['financial_type_name'] = OrderEnum::getFinancialType($item['financial_type']) . '获得';
|
||||
$item['number'] = '+' . $item['number'];
|
||||
}
|
||||
$item['staff_name'] = SystemStoreStaff::where('id', $item['staff_id'])->value('staff_name');
|
||||
$item['store_name'] = $item['store_id'] > 0 ? SystemStore::where('id', $item['store_id'])->value('name') : '';
|
||||
$item['pay_type_name'] = PayEnum::getPaySceneDesc($item['pay_type']);
|
||||
});
|
||||
$list2=UserSign::where('order_id',$item['order_sn'])->whereIn('user_ship',[2,3])->select();
|
||||
foreach($list2 as $k=>$v){
|
||||
$list2[$k]['id']='jf'.$v['id'];
|
||||
$list2[$k]['order_sn']=$item['order_sn'];
|
||||
$list2[$k]['store_name']=$item['store_name'];
|
||||
$list2[$k]['financial_pm']=0;
|
||||
$list2[$k]['nickname']=$v['uid']>0?User::where('id', $v['uid'])->value('nickname') . '|'.$v['uid']:'游客';
|
||||
$list2[$k]['number']='+'.$v['number'];
|
||||
$list2[$k]['financial_type_name']=$v['title'];
|
||||
$list2[$k]['pay_type_name'] = PayEnum::getPaySceneDesc($item['pay_type']);
|
||||
|
||||
}
|
||||
$data[$key]['list']=array_merge($list1->toArray(),$list2->toArray());
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
|
||||
@ -87,5 +131,4 @@ class StoreFinanceFlowLists extends BaseAdminDataLists implements ListsSearchInt
|
||||
{
|
||||
return StoreFinanceFlow::where($this->searchWhere)->count();
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -45,7 +45,7 @@ class SystemStoreLists extends BaseAdminDataLists implements ListsSearchInterfac
|
||||
{
|
||||
return SystemStore::where($this->searchWhere)
|
||||
->field(['id', 'name', 'phone', 'detailed_address', 'image', 'is_show','day_start','day_end'
|
||||
,'bank','bank_code','bank_address','realname'
|
||||
,'bank','bank_code','bank_address','realname,paid_deposit,security_deposit'
|
||||
])
|
||||
->limit($this->limitOffset, $this->limitLength)
|
||||
->order(['id' => 'desc'])
|
||||
|
@ -6,8 +6,11 @@ namespace app\admin\lists\user;
|
||||
|
||||
use app\admin\lists\BaseAdminDataLists;
|
||||
use app\common\enum\user\UserTerminalEnum;
|
||||
use app\common\enum\YesNoEnum;
|
||||
use app\common\lists\ListsExcelInterface;
|
||||
use app\common\model\user\User;
|
||||
use app\common\model\user\UserAddress;
|
||||
use app\common\model\vip_flow\VipFlow;
|
||||
|
||||
class UserLists extends BaseAdminDataLists implements ListsExcelInterface
|
||||
{
|
||||
@ -49,8 +52,10 @@ class UserLists extends BaseAdminDataLists implements ListsExcelInterface
|
||||
if(isset($params['is_disable']) && $params['is_disable'] != ''){
|
||||
$where[] = ['is_disable','=', $params['is_disable']];
|
||||
}
|
||||
$field = "id,nickname,real_name,sex,avatar,account,mobile,channel,create_time";
|
||||
$field = "id,nickname,real_name,sex,avatar,account,mobile,channel,create_time,purchase_funds,user_ship,
|
||||
label_id,integral";
|
||||
$lists = User::withSearch($this->setSearch(), $this->params)->where($where)
|
||||
->with(['user_ship','user_label'])
|
||||
->limit($this->limitOffset, $this->limitLength)
|
||||
->field($field)
|
||||
->order('id desc')
|
||||
@ -59,6 +64,18 @@ class UserLists extends BaseAdminDataLists implements ListsExcelInterface
|
||||
})->toArray();
|
||||
foreach ($lists as &$item) {
|
||||
$item['channel'] = UserTerminalEnum::getTermInalDesc($item['channel']);
|
||||
$item['user_address'] = UserAddress::where([
|
||||
'uid'=>$item['id'],'is_default'=>YesNoEnum::YES
|
||||
])->value('detail');
|
||||
if($item['vip_name']== null){
|
||||
$item['vip_name'] = '普通会员';
|
||||
}
|
||||
if($item['label_name']== null){
|
||||
$item['label_name'] = '无';
|
||||
}
|
||||
$item['return_money'] = VipFlow::
|
||||
where(['user_id'=>$item['id'],'status'=>0])
|
||||
->sum('number')??0;
|
||||
}
|
||||
|
||||
return $lists;
|
||||
|
@ -14,11 +14,13 @@
|
||||
|
||||
namespace app\admin\logic;
|
||||
|
||||
|
||||
use app\admin\logic\statistic\TradeStatisticLogic;
|
||||
use app\common\logic\BaseLogic;
|
||||
use app\common\model\order\Cart;
|
||||
use app\common\model\store_order\StoreOrder;
|
||||
use app\common\model\store_visit\StoreVisit;
|
||||
use app\common\model\user\User;
|
||||
use app\common\model\user\UserVisit;
|
||||
use app\common\service\ConfigService;
|
||||
use app\common\service\FileService;
|
||||
|
||||
@ -34,15 +36,31 @@ class WorkbenchLogic extends BaseLogic
|
||||
* @notes 工作套
|
||||
* @param $adminInfo
|
||||
* @return array
|
||||
* @author 乔峰
|
||||
* @date 2021/12/29 15:58
|
||||
*/
|
||||
public static function index()
|
||||
{
|
||||
{
|
||||
$logic=(new TradeStatisticLogic());
|
||||
$storeOrder=(new StoreOrder());
|
||||
$user=(new User());
|
||||
$userVisit=(new UserVisit());
|
||||
$today = $logic->tradeTotalMoney(['create_time' => 'today'], 'sum');
|
||||
$month = $logic->tradeTotalMoney(['create_time'=>'month'], 'sum');
|
||||
$todayOrder = $storeOrder->where(['paid'=>1])->whereDay('create_time')->count();
|
||||
$MonthOrder = $storeOrder->where(['paid'=>1])->whereMonth('create_time')->count();
|
||||
$todayUser = $user->whereDay('create_time')->count();
|
||||
$MonthUser = $user->whereMonth('create_time')->count();
|
||||
$todayUserVisit = $userVisit->whereDay('create_time')->group('uid')->count();
|
||||
$MonthUserVisit = $userVisit->whereMonth('create_time')->group('uid')->count();
|
||||
return [
|
||||
|
||||
// 常用功能
|
||||
|
||||
'today' => $today, //今日销售额
|
||||
'month' => $month, //本月销售额
|
||||
'todayOrder' => $todayOrder, //今日订单量
|
||||
'MonthOrder' => $MonthOrder, //本月订单量
|
||||
'todayUser' => $todayUser, //今日新增用户量
|
||||
'MonthUser' => $MonthUser, //本月新增用户量
|
||||
'todayUserVisit' => $todayUserVisit, //今日活跃用户量
|
||||
'MonthUserVisit' => $MonthUserVisit, //本月活跃用户量
|
||||
];
|
||||
}
|
||||
|
||||
|
47
app/admin/logic/statistic/ProductStatisticLogic.php
Normal file
47
app/admin/logic/statistic/ProductStatisticLogic.php
Normal file
@ -0,0 +1,47 @@
|
||||
<?php
|
||||
|
||||
namespace app\admin\logic\statistic;
|
||||
|
||||
use app\common\logic\BaseLogic;
|
||||
use app\common\model\store_product_log\StoreProductLog;
|
||||
|
||||
/**
|
||||
* Class 商品统计
|
||||
* @package app\services\statistic
|
||||
*/
|
||||
class ProductStatisticLogic extends BaseLogic
|
||||
{
|
||||
|
||||
public function get_product_ranking($where)
|
||||
{
|
||||
$list = StoreProductLog::where($where)->with('store')
|
||||
->field([
|
||||
'store_id',
|
||||
'product_id',
|
||||
'SUM(visit_num) as visit',
|
||||
'COUNT(distinct(uid)) as user',
|
||||
'SUM(cart_num) as cart',
|
||||
'SUM(order_num) as orders',
|
||||
'SUM(pay_num) as pay',
|
||||
'SUM(pay_price * pay_num) as price',
|
||||
'SUM(cost_price) as cost',
|
||||
'ROUND((SUM(pay_price)-SUM(cost_price))/SUM(pay_price),2) as profit',
|
||||
'SUM(collect_num) as collect',
|
||||
'ROUND((COUNT(distinct(pay_uid))-1)/COUNT(distinct(uid)),2) as changes',
|
||||
'COUNT(distinct(pay_uid))-1 as repeats'
|
||||
])->group('product_id')->order('pay' . ' desc')->limit(20)->select()->toArray();
|
||||
foreach ($list as $key => &$item) {
|
||||
if (!$item['store_name']) {
|
||||
unset($list[$key]);
|
||||
}
|
||||
if ($item['profit'] == null) $item['profit'] = 0;
|
||||
if ($item['changes'] == null) $item['changes'] = 0;
|
||||
if ($item['repeats'] == null) {
|
||||
$item['repeats'] = 0;
|
||||
} else {
|
||||
$item['repeats'] = bcdiv(count(StoreProductLog::where($where)->where('type', 'pay')->where('product_id', $item['product_id'])->field('count(pay_uid) as p')->group('pay_uid')->having('p>1')->select()), $item['repeats'], 2);
|
||||
}
|
||||
}
|
||||
return array_merge($list);
|
||||
}
|
||||
}
|
923
app/admin/logic/statistic/TradeStatisticLogic.php
Normal file
923
app/admin/logic/statistic/TradeStatisticLogic.php
Normal file
@ -0,0 +1,923 @@
|
||||
<?php
|
||||
|
||||
namespace app\admin\logic\statistic;
|
||||
|
||||
use app\common\logic\BaseLogic;
|
||||
use app\common\model\store_order\StoreOrder;
|
||||
use app\common\model\user_recharge\UserRecharge;
|
||||
|
||||
/**
|
||||
* Class 交易数据
|
||||
* @package app\services\statistic
|
||||
*/
|
||||
class TradeStatisticLogic extends BaseLogic
|
||||
{
|
||||
public $_day = ['00时', '01时', '02时', '03时', '04时', '05时', '06时', '07时', '08时', '09时', '10时', '11时', '12时', '13时', '14时', '15时', '16时', '17时', '18时', '19时', '20时', '21时', '22时', '23时', '24时'];
|
||||
|
||||
/**
|
||||
* 基本概况
|
||||
* @param $where
|
||||
* @return mixed
|
||||
*/
|
||||
public function getTopLeftTrade($where)
|
||||
{
|
||||
//总交易额
|
||||
$selectType = "sum";
|
||||
$tradeTotalMoney = $this->tradeTotalMoney($where, $selectType);
|
||||
|
||||
//交易曲线
|
||||
$selectType = "group";
|
||||
$hourTotalMoney = $this->tradeGroupMoney($where, $selectType);
|
||||
return ['total_money' => $tradeTotalMoney, 'curve' => $hourTotalMoney];
|
||||
}
|
||||
|
||||
public function getTopRightOneTrade()
|
||||
{
|
||||
$storeOrder = new StoreOrder();
|
||||
/** day订单数 */
|
||||
//今日订单数
|
||||
$orderCountWhere['paid'] = 1;
|
||||
$timeKey = $this->TimeConvert("today");
|
||||
$todayOrderCount = $storeOrder->where($orderCountWhere)->whereDay('create_time')->count();
|
||||
$where['timeKey'] = [
|
||||
"start_time" => strtotime($timeKey['start_time']),
|
||||
"end_time" => strtotime($timeKey['end_time']),
|
||||
"days" => $timeKey['days']
|
||||
];
|
||||
|
||||
//今日订单数曲线
|
||||
$todayHourOrderCount = $storeOrder->getCurveData($orderCountWhere, $where, 'count(*)');
|
||||
$todayHourOrderCount = $this->trendYdata((array)$todayHourOrderCount, $timeKey);
|
||||
|
||||
//昨日订单数
|
||||
$yesTodayOrderCount = $storeOrder->where($orderCountWhere)->whereDay('create_time', 'yesterday')->count();
|
||||
|
||||
//昨日订单曲线
|
||||
// $yestodayHourOrderCount = $orderService->getOrderGroupCountByWhere($yestodayWhere);
|
||||
// $yestodayHourOrderCount = $this->trendYdata((array)$yestodayHourOrderCount, 'day');
|
||||
//订单数环比增长率
|
||||
|
||||
$orderCountDayChain = countRate($todayOrderCount, $yesTodayOrderCount);
|
||||
$data[] = [
|
||||
'name' => "今日订单数",
|
||||
'now_value' => $todayOrderCount,
|
||||
'last_value' => $yesTodayOrderCount,
|
||||
'rate' => $orderCountDayChain,
|
||||
'curve' => $todayHourOrderCount
|
||||
];
|
||||
/** day支付人数 */
|
||||
//今日支付人数
|
||||
$todayPayOrderPeople = $storeOrder->where($orderCountWhere)->whereDay('create_time')->group('uid')->count();
|
||||
|
||||
//今日支付人数曲线
|
||||
$todayHourOrderPeople = $storeOrder->getCurveData($orderCountWhere, $where, 'count(distinct uid)');
|
||||
|
||||
$todayHourOrderPeople = $this->trendYdata((array)$todayHourOrderPeople, $where['timeKey']);
|
||||
//昨日支付人数
|
||||
$yestodayPayOrderPeople = $storeOrder->where($orderCountWhere)->whereDay('create_time', 'yesterday')->group('uid')->count();
|
||||
//昨日支付曲线
|
||||
// $yestodayHourOrderPeople = $orderService->getPayOrderGroupPeopleByWhere($yestodayOrderPeopleWhere);
|
||||
// $yestodayHourOrderPeople = $this->trendYdata((array)$yestodayHourOrderPeople, 'day');
|
||||
//订单支付人数环比
|
||||
$orderPeopleDayChain = countRate($todayPayOrderPeople, $yestodayPayOrderPeople);
|
||||
$data[] = [
|
||||
'name' => "今日支付人数",
|
||||
'now_value' => $todayPayOrderPeople,
|
||||
'last_value' => $yestodayPayOrderPeople,
|
||||
'rate' => $orderPeopleDayChain,
|
||||
'curve' => $todayHourOrderPeople
|
||||
];
|
||||
$new_data = [];
|
||||
foreach ($data as $k => $v) {
|
||||
$new_data['x'] = $v['curve']['x'];
|
||||
$new_data['series'][$k]['name'] = $v['name'];
|
||||
$new_data['series'][$k]['now_money'] = $v['now_value'];
|
||||
$new_data['series'][$k]['last_money'] = $v['last_value'];
|
||||
$new_data['series'][$k]['rate'] = $v['rate'];
|
||||
$new_data['series'][$k]['value'] = array_values($v['curve']['y']);
|
||||
}
|
||||
|
||||
return $new_data;
|
||||
}
|
||||
|
||||
public function getTopRightTwoTrade()
|
||||
{
|
||||
$storeOrder = new StoreOrder();
|
||||
/** month订单数 */
|
||||
$monthOrderCountWhere['paid'] = 1;
|
||||
$timeKey = $this->TimeConvert("month");
|
||||
$where['timeKey'] = [
|
||||
"start_time" => strtotime($timeKey['start_time']),
|
||||
"end_time" => strtotime($timeKey['end_time']),
|
||||
"days" => $timeKey['days']
|
||||
];
|
||||
$monthOrderCount = $storeOrder->where($monthOrderCountWhere)->whereBetweenTime('create_time', $where['timeKey']['start_time'], $where['timeKey']['end_time'])->count();
|
||||
//本月订单数曲线
|
||||
$monthCurveOrderCount = $storeOrder->getCurveData($monthOrderCountWhere, $where, 'count(*)');
|
||||
|
||||
$monthCurveOrderCount = $this->trendYdata((array)$monthCurveOrderCount, $timeKey);
|
||||
//上月订单数
|
||||
$lastOrderCountWhere['timeKey'] = $this->TimeConvert("last_month");
|
||||
$where['timeKey'] = [
|
||||
"start_time" => strtotime($timeKey['start_time']),
|
||||
"end_time" => strtotime($timeKey['end_time']),
|
||||
"days" => $timeKey['days']
|
||||
];
|
||||
$lastOrderCount = $storeOrder->where($monthOrderCountWhere)->whereBetweenTime('create_time', $where['timeKey']['start_time'], $where['timeKey']['end_time'])->count();
|
||||
|
||||
//上月订单曲线
|
||||
// $lastCurveOrderCount = $orderService->getOrderGroupCountByWhere($lastOrderCountWhere);
|
||||
// $lastCurveOrderCount = $this->trendYdata((array)$lastCurveOrderCount, 'month');
|
||||
//订单数环比增长率
|
||||
// $orderCountMonthChain = (($monthOrderCount - $lastOrderCount) / $lastOrderCount) * 100;
|
||||
$orderCountMonthChain = countRate($monthOrderCount, $lastOrderCount);
|
||||
$data[] = [
|
||||
'name' => "本月订单数",
|
||||
'now_value' => $monthOrderCount,
|
||||
'last_value' => $lastOrderCount,
|
||||
'rate' => $orderCountMonthChain,
|
||||
'curve' => $monthCurveOrderCount
|
||||
];
|
||||
/** month下单人数 */
|
||||
//本月支付人数
|
||||
$timeKey = $this->TimeConvert("month");
|
||||
$monthOrderPeopleWhere['paid'] = 1;
|
||||
$where['timeKey'] = [
|
||||
"start_time" => strtotime($timeKey['start_time']),
|
||||
"end_time" => strtotime($timeKey['end_time']),
|
||||
"days" => $timeKey['days']
|
||||
];
|
||||
$monthPayOrderPeople = $storeOrder->where($monthOrderPeopleWhere)->whereMonth('create_time')->group('uid')->count();
|
||||
|
||||
//本月支付人数曲线
|
||||
$monthCurveOrderPeople = $storeOrder->getCurveData($monthOrderPeopleWhere, $where, 'count(distinct uid)');
|
||||
$monthCurveOrderPeople = $this->trendYdata((array)$monthCurveOrderPeople, $timeKey);
|
||||
//上月支付人数
|
||||
// $timeKey = $this->TimeConvert("last_month");
|
||||
|
||||
$lastPayOrderPeople = $storeOrder->where($monthOrderPeopleWhere)->whereMonth('create_time')->group('uid')->count();
|
||||
|
||||
//上月支付曲线
|
||||
// $lastCurveOrderPeople = $orderService->getPayOrderGroupPeopleByWhere($lastOrderPeopleWhere);
|
||||
// $lastCurveOrderPeople = $this->trendYdata((array)$lastCurveOrderPeople, 'month');
|
||||
//订单支付人数环比
|
||||
$orderPeopleDayChain = countRate($monthPayOrderPeople, $lastPayOrderPeople);
|
||||
$data[] = [
|
||||
'name' => "本月支付人数",
|
||||
'now_value' => $monthPayOrderPeople,
|
||||
'last_value' => $lastPayOrderPeople,
|
||||
'rate' => $orderPeopleDayChain,
|
||||
'curve' => $monthCurveOrderPeople
|
||||
];
|
||||
$new_data = [];
|
||||
foreach ($data as $k => $v) {
|
||||
$new_data[$k]['name'] = $v['name'];
|
||||
$new_data[$k]['now_money'] = $v['now_value'];
|
||||
$new_data[$k]['last_money'] = $v['last_value'];
|
||||
$new_data[$k]['rate'] = $v['rate'];
|
||||
$new_data[$k]['value'] = $v['curve']['y'];
|
||||
}
|
||||
|
||||
return $new_data;
|
||||
}
|
||||
/**
|
||||
* 底部数据
|
||||
* @param $where
|
||||
* @return array
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function getBottomTrade($where)
|
||||
{
|
||||
|
||||
if (!$where['data']) {
|
||||
$where['create_time'] = ['start_time' => date('Y-m-d 00:00:00', time()), "end_time" => date('Y-m-d 23:59:59', time())];
|
||||
} else {
|
||||
$time = explode("-", $where['data']);
|
||||
$where['create_time'] = ['start_time' => date('Y-m-d 00:00:00', strtotime($time[0])), "end_time" => date('Y-m-d 23:59:59', strtotime($time[1]))];
|
||||
}
|
||||
unset($where['data']);
|
||||
// /** @var ExportServices $exportService */
|
||||
// $exportService = app()->make(ExportServices::class);
|
||||
$chainTime = $this->chainTime($where['create_time']);
|
||||
$isNum = false;
|
||||
if ($chainTime == "other") $isNum = true;
|
||||
$dateWhere['create_time'] = $isNum ? $where['create_time'] : $chainTime;
|
||||
$topData = array();
|
||||
$Chain = array();
|
||||
|
||||
/** 商品支付金额 */
|
||||
$OrderMoney = $this->getOrderTotalMoney($where, "sum");
|
||||
$lastOrderMoney = $this->getOrderTotalMoney($dateWhere, "sum", "", $isNum);
|
||||
$OrderCurve = $this->getOrderTotalMoney($where, "group", "create_time");
|
||||
$OrderChain = countRate($OrderMoney, $lastOrderMoney);
|
||||
$topData[2] = [
|
||||
'title' => '商品支付金额',
|
||||
'desc' => '选定条件下,用户购买商品的实际支付金额,包括微信支付、余额支付、支付宝支付、线下支付金额(拼团商品在成团之后计入,线下支付订单在后台确认支付后计入)',
|
||||
'total_money' => $OrderMoney,
|
||||
'rate' => $OrderChain,
|
||||
'value' => $OrderCurve['y'],
|
||||
'type' => 1,
|
||||
'sign' => 'goods',
|
||||
];
|
||||
|
||||
$Chain['goods'] = $OrderCurve;
|
||||
|
||||
/** 购买会员金额 */
|
||||
// $memberMoney = $this->getMemberTotalMoney($where, 'sum');
|
||||
// $lastMemberMoney = $this->getMemberTotalMoney($dateWhere, 'sum', "", $isNum);
|
||||
// $memberCurve = $this->getMemberTotalMoney($where, 'group', "create_time");
|
||||
// $MemberChain = countRate($memberMoney, $lastMemberMoney);
|
||||
// $topData[3] = [
|
||||
// 'title' => '购买会员金额',
|
||||
// 'desc' => '选定条件下,用户成功购买付费会员的金额',
|
||||
// 'total_money' => $memberMoney,
|
||||
// 'rate' => $MemberChain,
|
||||
// 'value' => $memberCurve['y'],
|
||||
// 'type' => 1,
|
||||
// 'sign' => 'member',
|
||||
// ];
|
||||
// $Chain['member'] = $memberCurve;
|
||||
|
||||
/** 充值金额 */
|
||||
$rechgeMoneyHome = $this->getRechargeTotalMoney($where, 'sum');
|
||||
$rechgeMoneyAdmin = $this->getBillYeTotalMoney($where, 'sum');
|
||||
$rechgeMoneyTotal = bcadd($rechgeMoneyHome, $rechgeMoneyAdmin, 2);
|
||||
$lastRechgeMoneyHome = $this->getRechargeTotalMoney($dateWhere, 'sum', "", $isNum);
|
||||
$lastRechgeMoneyAdmin = $this->getBillYeTotalMoney($dateWhere, 'sum', "", $isNum);
|
||||
$lastRechgeMoneyTotal = bcadd($lastRechgeMoneyHome, $lastRechgeMoneyAdmin, 2);
|
||||
$RechgeHomeCurve = $this->getRechargeTotalMoney($where, 'group', "create_time");
|
||||
$RechgeAdminCurve = $this->getBillYeTotalMoney($where, 'group', "create_time");
|
||||
$RechgeTotalCurve = $this->totalArrData([$RechgeHomeCurve, $RechgeAdminCurve]);
|
||||
$RechgeChain = countRate($rechgeMoneyTotal, $lastRechgeMoneyTotal);
|
||||
$topData[4] = [
|
||||
'title' => '充值金额',
|
||||
'desc' => '选定条件下,用户成功充值的金额',
|
||||
'total_money' => $rechgeMoneyTotal,
|
||||
'rate' => $RechgeChain,
|
||||
'value' => $RechgeTotalCurve['y'],
|
||||
'type' => 1,
|
||||
'sign' => 'rechge',
|
||||
];
|
||||
$Chain['rechage'] = $RechgeTotalCurve;
|
||||
|
||||
/** 线下收银 */
|
||||
$offlineMoney = $this->getOfflineTotalMoney($where, 'sum');
|
||||
$lastOfflineMoney = $this->getOfflineTotalMoney($dateWhere, 'sum', "", $isNum);
|
||||
$offlineCurve = $this->getOfflineTotalMoney($where, 'group', "create_time");
|
||||
$offlineChain = countRate($offlineMoney, $lastOfflineMoney);
|
||||
$topData[5] = [
|
||||
'title' => '线下收银金额',
|
||||
'desc' => '选定条件下,用户在线下扫码支付的金额',
|
||||
'total_money' => $offlineMoney,
|
||||
'rate' => $offlineChain,
|
||||
'value' => $offlineCurve['y'],
|
||||
'type' => 0,
|
||||
'sign' => 'offline',
|
||||
];
|
||||
$Chain['offline'] = $offlineCurve;
|
||||
|
||||
/** 支出*/
|
||||
//余额支付商品
|
||||
$outYeOrderMoney = $this->getOrderTotalMoney(['pay_type' => 3, 'create_time' => $where['create_time']], 'sum');
|
||||
$lastOutYeOrderMoney = $this->getOrderTotalMoney(['pay_type' => 3, 'create_time' => $dateWhere['create_time']], 'sum', "", $isNum);
|
||||
$outYeOrderCurve = $this->getOrderTotalMoney(['pay_type' => 3, 'create_time' => $where['create_time']], 'group', 'create_time');
|
||||
$outYeOrderChain = countRate($outYeOrderMoney, $lastOutYeOrderMoney);
|
||||
//余额购买会员
|
||||
// $outYeMemberMoney = $this->getMemberTotalMoney(['pay_type' => "yue", 'time' => $where['time']], 'sum');
|
||||
// $lastOutYeMemberMoney = $this->getMemberTotalMoney(['pay_type' => "yue", 'time' => $dateWhere['time']], 'sum', "", $isNum);
|
||||
// $outYeMemberCurve = $this->getMemberTotalMoney(['pay_type' => "yue", 'time' => $where['time']], 'group', "pay_time");
|
||||
// $outYeMemberChain = countRate($outYeMemberMoney, $lastOutYeMemberMoney);
|
||||
//余额支付
|
||||
// $outYeMoney = bcadd($outYeOrderMoney, $outYeMemberMoney, 2);
|
||||
// $lastOutYeMoney = bcadd($lastOutYeOrderMoney, $lastOutYeMemberMoney, 2);
|
||||
// $outYeCurve = $this->totalArrData([$outYeOrderCurve, $outYeMemberCurve]);
|
||||
// $outYeChain = countRate($outYeOrderChain, $outYeMemberChain);
|
||||
$outYeMoney = $outYeOrderMoney;
|
||||
$lastOutYeMoney = $lastOutYeOrderMoney;
|
||||
$outYeCurve = $this->totalArrData([$outYeOrderCurve, 0]);
|
||||
$outYeChain = countRate($outYeOrderChain, 0);
|
||||
$topData[7] = [
|
||||
'title' => '余额支付金额',
|
||||
'desc' => '用户下单时使用余额实际支付的金额',
|
||||
'total_money' => $outYeMoney,
|
||||
'rate' => $outYeChain,
|
||||
'value' => $outYeCurve['y'],
|
||||
'type' => 0,
|
||||
'sign' => 'yue',
|
||||
];
|
||||
$Chain['out_ye'] = $outYeCurve;
|
||||
|
||||
|
||||
//支付佣金金额
|
||||
// $outExtractMoney = $this->getExtractTotalMoney($where, 'sum');
|
||||
// $lastOutExtractMoney = $this->getExtractTotalMoney($dateWhere, 'sum', "", $isNum);
|
||||
// $OutExtractCurve = $this->getExtractTotalMoney($where, 'group', "add_time");
|
||||
// $OutExtractChain = countRate($outExtractMoney, $lastOutExtractMoney);
|
||||
// $topData[8] = [
|
||||
// 'title' => '支付佣金金额',
|
||||
// 'desc' => '后台给推广员支付的推广佣金,以实际支付为准',
|
||||
// 'total_money' => $outExtractMoney,
|
||||
// 'rate' => $OutExtractChain,
|
||||
// 'value' => $OutExtractCurve['y'],
|
||||
// 'type' => 0,
|
||||
// 'sign' => 'yong',
|
||||
// ];
|
||||
// $Chain['extract'] = $OutExtractCurve;
|
||||
|
||||
//商品退款金额
|
||||
$outOrderRefund = $this->getOrderRefundTotalMoney(['refund_type' => 6, 'create_time' => $where['create_time']], 'sum');
|
||||
$lastOutOrderRefund = $this->getOrderRefundTotalMoney(['refund_type' => 6, 'create_time' => $dateWhere['create_time']], 'sum', "", $isNum);
|
||||
$outOrderRefundCurve = $this->getOrderRefundTotalMoney(['refund_type' => 6, 'create_time' => $where['create_time']], 'group', 'create_time');
|
||||
$orderRefundChain = countRate($outOrderRefund, $lastOutOrderRefund);
|
||||
$topData[9] = [
|
||||
'title' => '商品退款金额',
|
||||
'desc' => '用户成功退款的商品金额',
|
||||
'total_money' => $outOrderRefund,
|
||||
'rate' => $orderRefundChain,
|
||||
'value' => $outOrderRefundCurve['y'],
|
||||
'type' => 0,
|
||||
'sign' => 'refund',
|
||||
];
|
||||
$Chain['refund'] = $outOrderRefundCurve;
|
||||
|
||||
//支出金额
|
||||
// $outTotalMoney = bcadd($outYeMoney, $outExtractMoney, 2);
|
||||
// $lastOutTotalMoney = bcadd($lastOutYeMoney, $lastOutExtractMoney, 2);
|
||||
// $outTotalCurve = $this->totalArrData([$outYeCurve, $OutExtractCurve]);
|
||||
$outTotalMoney = bcadd($outYeMoney, 0, 2);
|
||||
$lastOutTotalMoney = bcadd($lastOutYeMoney, 0, 2);
|
||||
$outTotalCurve = $this->totalArrData([$outYeCurve, 0]);
|
||||
$outTotalChain = countRate($outTotalMoney, $lastOutTotalMoney);
|
||||
$topData[6] = [
|
||||
'title' => '支出金额',
|
||||
'desc' => '余额支付金额、支付佣金金额',
|
||||
'total_money' => $outTotalMoney,
|
||||
'rate' => $outTotalChain,
|
||||
'value' => $outTotalCurve['y'],
|
||||
'type' => 1,
|
||||
'sign' => 'out',
|
||||
];
|
||||
$Chain['out'] = $outTotalCurve;
|
||||
|
||||
/** 交易毛利金额*/
|
||||
// $jiaoyiMoney = $this->tradeTotalMoney($where, "sum");
|
||||
|
||||
// $jiaoyiMoney = bcsub($jiaoyiMoney, $outTotalMoney, 2);
|
||||
// $lastJiaoyiMoney = $this->tradeTotalMoney($dateWhere, "sum", $isNum);
|
||||
// $lastJiaoyiMoney = bcsub($lastJiaoyiMoney, $lastOutTotalMoney, 2);
|
||||
// $jiaoyiCurve = $this->tradeGroupMoney($where, "group");
|
||||
// $jiaoyiCurve = $this->subdutionArrData($jiaoyiCurve, $outTotalCurve);
|
||||
// $jiaoyiChain = countRate($jiaoyiMoney, $lastJiaoyiMoney);
|
||||
// $topData[1] = [
|
||||
// 'title' => '交易毛利金额',
|
||||
// 'desc' => '交易毛利金额 = 营业额 - 支出金额',
|
||||
// 'total_money' => $jiaoyiMoney,
|
||||
// 'rate' => $jiaoyiChain,
|
||||
// 'value' => $jiaoyiCurve['y'],
|
||||
// 'type' => 1,
|
||||
// 'sign' => 'jiaoyi',
|
||||
// ];
|
||||
// $Chain['jiaoyi'] = $jiaoyiCurve;
|
||||
|
||||
/** @var 营业额 $inTotalMoney */
|
||||
$inTotalMoney = $this->tradeTotalMoney($where, "sum");
|
||||
$lastInTotalMoney = $this->tradeTotalMoney($dateWhere, "sum", $isNum);
|
||||
$inTotalCurve = $this->tradeGroupMoney($where, "group");
|
||||
$inTotalChain = countRate($inTotalMoney, $lastInTotalMoney);
|
||||
$topData[0] = [
|
||||
'title' => '营业额',
|
||||
'desc' => '商品支付金额、充值金额、购买付费会员金额、线下收银金额',
|
||||
'total_money' => $inTotalMoney,
|
||||
'rate' => $inTotalChain,
|
||||
'value' => $inTotalCurve['y'],
|
||||
'type' => 1,
|
||||
'sign' => 'in',
|
||||
];
|
||||
ksort($topData);
|
||||
$data = [];
|
||||
foreach ($topData as $k => $v) {
|
||||
$data['x'] = $Chain['out']['x'];
|
||||
$data['series'][$k]['name'] = $v['title'];
|
||||
$data['series'][$k]['desc'] = $v['desc'];
|
||||
$data['series'][$k]['money'] = $v['total_money'];
|
||||
$data['series'][$k]['type'] = $v['type'];
|
||||
$data['series'][$k]['rate'] = $v['rate'];
|
||||
$data['series'][$k]['value'] = array_values($v['value']);
|
||||
}
|
||||
// $export = $exportService->tradeData($data, '交易统计', 2);
|
||||
// $data['export'] = $export[0];
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* 交易总额
|
||||
* @param $where
|
||||
* @param $selectType
|
||||
* @return array|float|int|mixed
|
||||
*/
|
||||
public function tradeTotalMoney($where, $selectType, $isNum = false)
|
||||
{
|
||||
/** 收入营业额 */
|
||||
//商品订单收入
|
||||
$inOrderMoney = $this->getOrderTotalMoney($where, $selectType, "", $isNum);
|
||||
|
||||
//用户充值收入
|
||||
$inRechargeMoneyHome = $this->getRechargeTotalMoney($where, $selectType, "", $isNum);
|
||||
|
||||
$inrechgeMoneyAdmin = $this->getBillYeTotalMoney($where, $selectType, '', $isNum);
|
||||
$inRechargeMoney = bcadd($inRechargeMoneyHome, $inrechgeMoneyAdmin, 2);
|
||||
|
||||
//购买会员收入
|
||||
$inMemberMoney = $this->getMemberTotalMoney($where, $selectType, "", $isNum);
|
||||
//线下收款收入
|
||||
$inOfflineMoney = $this->getOfflineTotalMoney($where, $selectType, "", $isNum);
|
||||
//总交易额
|
||||
$inTotalMoney = bcadd(bcadd($inOrderMoney, $inRechargeMoney, 2), bcadd($inMemberMoney, $inOfflineMoney, 2), 2);/* - $outExtractUserMoney*/
|
||||
return $inTotalMoney;
|
||||
}
|
||||
|
||||
/**
|
||||
* 交易额曲线图
|
||||
* @param $where
|
||||
* @param $selectType
|
||||
* @return array
|
||||
*/
|
||||
public function tradeGroupMoney($where, $selectType)
|
||||
{
|
||||
|
||||
//商品订单收入
|
||||
$orderGroup = "create_time";
|
||||
$OrderMoney = $this->getOrderTotalMoney($where, $selectType, $orderGroup);
|
||||
//用户充值收入
|
||||
$rechargeGroup = "create_time";
|
||||
$RechargeMoneyHome = $this->getRechargeTotalMoney($where, $selectType, $rechargeGroup);
|
||||
$RechargeMoneyAdmin = $this->getBillYeTotalMoney($where, $selectType, $rechargeGroup);
|
||||
$RechargeMoney = $this->totalArrData([$RechargeMoneyHome, $RechargeMoneyAdmin]);
|
||||
//购买会员收入
|
||||
$memberGroup = "create_time";
|
||||
$MemberMoney = $this->getMemberTotalMoney($where, $selectType, $memberGroup);
|
||||
//线下收款收入
|
||||
$offlineGroup = "create_time";
|
||||
$OfflineMoney = $this->getOfflineTotalMoney($where, $selectType, $offlineGroup);
|
||||
return $this->totalArrData([$OrderMoney, $RechargeMoney, $MemberMoney, $OfflineMoney]);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 获取订单退款
|
||||
* @param $where
|
||||
* @param string $selectType
|
||||
* @param string $group
|
||||
* @param bool $isNum
|
||||
* @return array|float|int
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function getOrderRefundTotalMoney($where, string $selectType, string $group = '', bool $isNum = false)
|
||||
{
|
||||
$storeOrder = new StoreOrder();
|
||||
$orderSumField = "pay_price";
|
||||
$where[] = ['refund_status', '>', 0];
|
||||
// $where['is_cancel'] = 0;
|
||||
switch ($selectType) {
|
||||
case "sum":
|
||||
$totalMoney = $storeOrder->where($where)->when(isset($where['timeKey']), function ($query) use ($where) {
|
||||
$query->whereBetweenTime('create_time', strtotime($where['timeKey']['start_time']), strtotime($where['timeKey']['end_time']));
|
||||
})->sum($orderSumField);
|
||||
break;
|
||||
case "group":
|
||||
$totalMoney = $storeOrder->where($where)->when(isset($where['timeKey']), function ($query) use ($where) {
|
||||
$query->whereBetweenTime('create_time', strtotime($where['timeKey']['start_time']), strtotime($where['timeKey']['end_time']));
|
||||
})->count($orderSumField);
|
||||
break;
|
||||
default:
|
||||
throw new \Exception('getOrderTotalMoney:selectType参数错误');
|
||||
}
|
||||
if ($group) {
|
||||
$totalMoney = $this->trendYdata((array)$totalMoney, $this->TimeConvert($where['create_time'], $isNum));
|
||||
}
|
||||
return $totalMoney;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取商品营收
|
||||
* @param $where
|
||||
* @param string $selectType
|
||||
* @param string $group
|
||||
* @param bool $isNum
|
||||
* @return array|float|int
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function getOrderTotalMoney($where, string $selectType, string $group = "", bool $isNum = false)
|
||||
{
|
||||
/** 普通商品订单支付金额 */
|
||||
$storeOrder = new StoreOrder();
|
||||
$whereOrderMoner['refund_status'] = isset($where['refund_status']) ? $where['refund_status'] : [0, 3];
|
||||
$whereOrderMoner['paid'] = 1;
|
||||
|
||||
$timeKey = $this->TimeConvert($where['create_time'], $isNum);
|
||||
$where['timeKey'] = $timeKey;
|
||||
switch ($selectType) {
|
||||
case "sum":
|
||||
$totalMoney = $storeOrder->where($whereOrderMoner)->when(isset($where['timeKey']), function ($query) use ($where) {
|
||||
$query->whereBetweenTime('create_time', strtotime($where['timeKey']['start_time']), strtotime($where['timeKey']['end_time']));
|
||||
})->sum('pay_price');
|
||||
break;
|
||||
case "group":
|
||||
$totalMoney = $storeOrder->where($whereOrderMoner)->when(isset($where['timeKey']), function ($query) use ($where, $group) {
|
||||
$query->whereBetweenTime('create_time', $where['timeKey']['start_time'], $where['timeKey']['end_time']);
|
||||
if ($where['timeKey']['days'] == 1) {
|
||||
$timeUinx = "%H";
|
||||
} elseif ($where['timeKey']['days'] == 30) {
|
||||
$timeUinx = "%Y-%m-%d";
|
||||
} elseif ($where['timeKey']['days'] == 365) {
|
||||
$timeUinx = "%Y-%m";
|
||||
} elseif ($where['timeKey']['days'] > 1 && $where['timeKey']['days'] < 30) {
|
||||
$timeUinx = "%Y-%m-%d";
|
||||
} elseif ($where['timeKey']['days'] > 30 && $where['timeKey']['days'] < 365) {
|
||||
$timeUinx = "%Y-%m";
|
||||
} else {
|
||||
$timeUinx = "%Y-%m";
|
||||
}
|
||||
$query->field("sum(pay_price) as number,FROM_UNIXTIME($group, '$timeUinx') as time");
|
||||
$query->group("FROM_UNIXTIME($group, '$timeUinx')");
|
||||
})
|
||||
->order('create_time ASC')->select()->toArray();
|
||||
break;
|
||||
default:
|
||||
throw new \Exception('getOrderTotalMoney:selectType参数错误');
|
||||
}
|
||||
|
||||
if ($group) {
|
||||
$totalMoney = $this->trendYdata((array)$totalMoney, $timeKey);
|
||||
}
|
||||
return $totalMoney;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 获取用户充值营收
|
||||
* @param array $where
|
||||
* @param string $selectType
|
||||
* @param string $group
|
||||
* @param bool $isNum
|
||||
* @return array|float|int
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function getRechargeTotalMoney(array $where, string $selectType, string $group = "", bool $isNum = false)
|
||||
{
|
||||
/** 用户充值金额 */
|
||||
$userRechage = new UserRecharge();
|
||||
$rechargeSumField = "price";
|
||||
$timeKey = $this->TimeConvert($where['create_time'], $isNum);
|
||||
$where['timeKey'] = $timeKey;
|
||||
|
||||
switch ($selectType) {
|
||||
case "sum":
|
||||
$totalMoney = $userRechage->where(['paid' => 1])
|
||||
->when(isset($where['create_time']), function ($query) use ($where) {
|
||||
$query->whereBetweenTime('create_time', strtotime($where['timeKey']['start_time']), strtotime($where['timeKey']['end_time']));
|
||||
})
|
||||
->sum($rechargeSumField);
|
||||
break;
|
||||
case "group":
|
||||
$totalMoney = $userRechage->where(['paid' => 1])
|
||||
->when(isset($where['create_time']), function ($query) use ($where, $rechargeSumField, $group) {
|
||||
$query->whereBetweenTime('create_time', strtotime($where['timeKey']['start_time']), strtotime($where['timeKey']['end_time']));
|
||||
if ($where['timeKey']['days'] == 1) {
|
||||
$timeUinx = "%H";
|
||||
} elseif ($where['timeKey']['days'] == 30) {
|
||||
$timeUinx = "%Y-%m-%d";
|
||||
} elseif ($where['timeKey']['days'] == 365) {
|
||||
$timeUinx = "%Y-%m";
|
||||
} elseif ($where['timeKey']['days'] > 1 && $where['timeKey']['days'] < 30) {
|
||||
$timeUinx = "%Y-%m-%d";
|
||||
} elseif ($where['timeKey']['days'] > 30 && $where['timeKey']['days'] < 365) {
|
||||
$timeUinx = "%Y-%m";
|
||||
} else {
|
||||
$timeUinx = "%Y-%m";
|
||||
}
|
||||
$query->field("sum($rechargeSumField) as number,FROM_UNIXTIME($group, '$timeUinx') as time");
|
||||
$query->group("FROM_UNIXTIME($group, '$timeUinx')");
|
||||
})
|
||||
->order('time ASC')->select()->toArray();
|
||||
break;
|
||||
default:
|
||||
$totalMoney = 0.00;
|
||||
break;
|
||||
}
|
||||
if ($group) {
|
||||
$totalMoney = $this->trendYdata((array)$totalMoney, $timeKey);
|
||||
}
|
||||
return $totalMoney;
|
||||
}
|
||||
|
||||
/**
|
||||
* 购买会员总额
|
||||
* @param array $where
|
||||
* @param string $selectType
|
||||
* @param string $group
|
||||
* @param bool $isNum
|
||||
* @return array|mixed
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function getMemberTotalMoney(array $where, string $selectType, string $group = "", bool $isNum = false)
|
||||
{
|
||||
|
||||
/** 购买会员 */
|
||||
// /** @var OtherOrderServices $otherOrderService */
|
||||
// $otherOrderService = app()->make(OtherOrderServices::class);
|
||||
// $memberSumField = "pay_price";
|
||||
// $whereInMember['type'] = 1;
|
||||
// $whereInMember['paid'] = 1;
|
||||
// $whereInMember['store_id'] = 0;
|
||||
|
||||
// $whereInMember['timeKey'] = $this->TimeConvert($where['time'], $isNum);
|
||||
// $totalMoney = $otherOrderService->getMemberMoneyByWhere($whereInMember, $memberSumField, $selectType, $group);
|
||||
// if ($group) {
|
||||
// $totalMoney = $this->trendYdata((array)$totalMoney, $whereInMember['timeKey']);
|
||||
// }
|
||||
return 0;
|
||||
}
|
||||
/**
|
||||
* 后台手动充值
|
||||
* @param array $where
|
||||
* @param string $selectType
|
||||
* @param string $group
|
||||
* @param bool $isNum
|
||||
* @return array|float|int
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function getBillYeTotalMoney(array $where, string $selectType, string $group = "", bool $isNum = false)
|
||||
{
|
||||
/** 后台用户充值金额 */
|
||||
// $rechargeSumField = "number";
|
||||
// $whereInRecharge['pm'] = 1;
|
||||
// $whereInRecharge['type'] = 'system_add';
|
||||
// $whereInRecharge['timeKey'] = $this->TimeConvert($where['time'], $isNum);
|
||||
// $whereInRecharge['store_id'] = 0;
|
||||
// /** @var UserMoneyServices $userMoneyServices */
|
||||
// $userMoneyServices = app()->make(UserMoneyServices::class);
|
||||
// $totalMoney = $userMoneyServices->getRechargeMoneyByWhere($whereInRecharge, $rechargeSumField, $selectType, $group);
|
||||
// if ($group) {
|
||||
// $totalMoney = $this->trendYdata((array)$totalMoney, $whereInRecharge['timeKey']);
|
||||
// }
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 线下付款总额
|
||||
* @param array $where
|
||||
* @param string $selectType
|
||||
* @param string $group
|
||||
* @param bool $isNum
|
||||
* @return array|mixed
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function getOfflineTotalMoney(array $where, string $selectType, string $group = "", bool $isNum = false)
|
||||
{
|
||||
/** 线下付款总额 */
|
||||
$storeOrder = new StoreOrder();
|
||||
$offlineSumField = "pay_price";
|
||||
// $whereOffline['type'] = 3;
|
||||
// $whereOffline['paid'] = 1;
|
||||
// $whereOffline['store_id'] = 0;
|
||||
// // $whereOffline['pay_type_no'] = 'yue';
|
||||
$where['timeKey'] = $this->TimeConvert($where['create_time'], $isNum);
|
||||
// $totalMoney = $otherOrderService->getMemberMoneyByWhere($whereOffline, $offlineSumField, $selectType, $group);
|
||||
// if ($group) {
|
||||
// $totalMoney = $this->trendYdata((array)$totalMoney, $whereOffline['timeKey']);
|
||||
// }
|
||||
switch ($selectType) {
|
||||
case "sum":
|
||||
$totalMoney = $storeOrder->where('pay_type', 'in', [9, 13, 17])->when(isset($where['timeKey']), function ($query) use ($where) {
|
||||
$query->whereBetweenTime('create_time', strtotime($where['timeKey']['start_time']), strtotime($where['timeKey']['end_time']));
|
||||
})->sum($offlineSumField);
|
||||
break;
|
||||
case "group":
|
||||
$totalMoney = $storeOrder->where('pay_type', 'in', [9, 13, 17])->when(isset($where['timeKey']), function ($query) use ($where, $group) {
|
||||
$query->whereBetweenTime('create_time', $where['timeKey']['start_time'], $where['timeKey']['end_time']);
|
||||
if ($where['timeKey']['days'] == 1) {
|
||||
$timeUinx = "%H";
|
||||
} elseif ($where['timeKey']['days'] == 30) {
|
||||
$timeUinx = "%Y-%m-%d";
|
||||
} elseif ($where['timeKey']['days'] == 365) {
|
||||
$timeUinx = "%Y-%m";
|
||||
} elseif ($where['timeKey']['days'] > 1 && $where['timeKey']['days'] < 30) {
|
||||
$timeUinx = "%Y-%m-%d";
|
||||
} elseif ($where['timeKey']['days'] > 30 && $where['timeKey']['days'] < 365) {
|
||||
$timeUinx = "%Y-%m";
|
||||
} else {
|
||||
$timeUinx = "%Y-%m";
|
||||
}
|
||||
$query->field("sum(pay_price) as number,FROM_UNIXTIME($group, '$timeUinx') as time");
|
||||
$query->group("FROM_UNIXTIME($group, '$timeUinx')");
|
||||
})
|
||||
->order('time ASC')->select()->toArray();
|
||||
break;
|
||||
default:
|
||||
throw new \Exception('getOrderTotalMoney:selectType参数错误');
|
||||
}
|
||||
if ($group) {
|
||||
$totalMoney = $this->trendYdata((array)$totalMoney, $this->TimeConvert($where['create_time'], $isNum));
|
||||
}
|
||||
return $totalMoney;
|
||||
}
|
||||
|
||||
/**
|
||||
* 处理Y坐标数据
|
||||
* @param array $data
|
||||
* @param array $timeKey
|
||||
* @return array
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function trendYdata(array $data, array $timeKey)
|
||||
{
|
||||
$hourMoney = array();
|
||||
$timeData = array();
|
||||
//获取日期之间的天数
|
||||
$getDayRange = function ($date, $timeKey) {
|
||||
$datearr = [];
|
||||
$stime = strtotime($timeKey['start_time']);
|
||||
$etime = strtotime($timeKey['end_time']);
|
||||
while ($stime <= $etime) {
|
||||
$datearr['x'][] = date($date, $stime);
|
||||
$datearr['y'][] = date($date, $stime);
|
||||
$stime = $stime + 86400;
|
||||
}
|
||||
return $datearr;
|
||||
};
|
||||
//获取日期之间的月份
|
||||
$getMonthRange = function ($date, $timeKey) {
|
||||
$datearr = [];
|
||||
$stime = date('Y-m-d', strtotime($timeKey['start_time']));
|
||||
$etime = date('Y-m-d', strtotime($timeKey['end_time']));
|
||||
$start = new \DateTime($stime);
|
||||
$end = new \DateTime($etime);
|
||||
$interval = \DateInterval::createFromDateString('1 month');
|
||||
$period = new \DatePeriod($start, $interval, $end);
|
||||
foreach ($period as $dt) {
|
||||
$datearr['x'][] = $dt->format($date);
|
||||
$datearr['y'][] = $dt->format($date);
|
||||
}
|
||||
return $datearr;
|
||||
};
|
||||
if ($timeKey['days'] == 1) {
|
||||
for ($i = 0; $i <= 24; $i++) {
|
||||
$timeData['x'][] = (string)($i < 10 ? ('0' . $i) : $i);
|
||||
$timeData['y'][] = $i < 10 ? ('0' . $i) : $i;
|
||||
//$timeData['y'][] = $i < 10 ? ('0' . $i . ":00") : $i . ":00";
|
||||
//$timeData['x'][] = $i < 10 ? ('0' . $i . ":00") : $i . ":00";
|
||||
}
|
||||
} elseif ($timeKey['days'] == 30) {
|
||||
$timeData = $getDayRange('Y-m-d', $timeKey);
|
||||
} elseif ($timeKey['days'] == 365) {
|
||||
$timeData = $getMonthRange('Y-m', $timeKey);
|
||||
} elseif ($timeKey['days'] > 1 && $timeKey['days'] < 30) {
|
||||
$timeData = $getDayRange('Y-m-d', $timeKey);
|
||||
} elseif ($timeKey['days'] > 30 && $timeKey['days'] < 365) {
|
||||
$timeData = $getMonthRange('Y-m', $timeKey);
|
||||
}
|
||||
if ($data) {
|
||||
$hourMoney = array_column($data, 'number', 'time');
|
||||
}
|
||||
$y = array();
|
||||
foreach ($timeData['y'] as $k => $v) {
|
||||
if (array_key_exists($v, $hourMoney)) {
|
||||
$y[$v] = $hourMoney[$v];
|
||||
} else {
|
||||
$y[$v] = 0;
|
||||
}
|
||||
}
|
||||
return ['x' => $timeData['x'], 'y' => $y];
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 获取环比时间类型
|
||||
* @param $timeKey
|
||||
* @return string
|
||||
*/
|
||||
public function chainTime($timeKey)
|
||||
{
|
||||
switch ($timeKey) {
|
||||
case "today":
|
||||
return "yestoday";
|
||||
case "month":
|
||||
return "last_month";
|
||||
case "year":
|
||||
return "last_year";
|
||||
default:
|
||||
return "other";
|
||||
}
|
||||
}
|
||||
/**
|
||||
* 多个数组相加
|
||||
* @param array $arr
|
||||
* @return array|false
|
||||
*/
|
||||
public function totalArrData(array $arr)
|
||||
{
|
||||
if (!$arr || !is_array($arr)) return false;
|
||||
$item = array();
|
||||
$y = array_column($arr, "y");
|
||||
$x = array_column($arr, "x")[0];
|
||||
foreach ($y as $key => $value) {
|
||||
foreach ($value as $k => $v) {
|
||||
if (isset($item[$k])) {
|
||||
$item[$k] = bcadd($item[$k], $v, 2);
|
||||
} else {
|
||||
$item[$k] = $v;
|
||||
}
|
||||
}
|
||||
}
|
||||
return ['x' => $x, 'y' => $item];
|
||||
}
|
||||
|
||||
/**
|
||||
* 数组相减
|
||||
* @param array $arr1
|
||||
* @param array $arr2
|
||||
* @return array
|
||||
*/
|
||||
public function subdutionArrData(array $arr1, array $arr2)
|
||||
{
|
||||
$item = array();
|
||||
foreach ($arr1['y'] as $key => $value) {
|
||||
$item['y'][$key] = bcsub($value, $arr2['y'][$key], 2);
|
||||
}
|
||||
$item['x'] = $arr1['x'];
|
||||
return $item;
|
||||
}
|
||||
|
||||
/**
|
||||
* 搜索时间转换
|
||||
* @param $timeKey
|
||||
* @param false $isNum
|
||||
* @return array
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function TimeConvert($timeKey, $isNum = false)
|
||||
{
|
||||
switch ($timeKey) {
|
||||
case "today":
|
||||
$data['start_time'] = date('Y-m-d 00:00:00', time());
|
||||
$data['end_time'] = date('Y-m-d 23:59:59', time());
|
||||
$data['days'] = 1;
|
||||
break;
|
||||
case "yestoday":
|
||||
$data['start_time'] = date('Y-m-d 00:00:00', strtotime('-1 day'));
|
||||
$data['end_time'] = date('Y-m-d 23:59:59', strtotime('-1 day'));
|
||||
$data['days'] = 1;
|
||||
break;
|
||||
case "last_month":
|
||||
$data['start_time'] = date('Y-m-01 00:00:00', strtotime('-1 month'));
|
||||
$data['end_time'] = date('Y-m-t 23:59:59', strtotime('-1 month'));
|
||||
$data['days'] = 30;
|
||||
break;
|
||||
case "month":
|
||||
$data['start_time'] = $month_start_time = date('Y-m-01 00:00:00', strtotime(date("Y-m-d")));
|
||||
$data['end_time'] = date('Y-m-d 23:59:59', strtotime("$month_start_time +1 month -1 day"));
|
||||
$data['days'] = 30;
|
||||
break;
|
||||
case "year":
|
||||
$data['start_time'] = date('Y-01-01 00:00:00', time());
|
||||
$data['end_time'] = date('Y-12-t 23:59:59', time());
|
||||
$data['days'] = 365;
|
||||
break;
|
||||
case "last_year":
|
||||
$data['start_time'] = date('Y-01-01 00:00:00', strtotime('-1 year'));
|
||||
$data['end_time'] = date('Y-12-t 23:59:59', strtotime('-1 year'));
|
||||
$data['days'] = 365;
|
||||
break;
|
||||
case 30:
|
||||
case 15:
|
||||
case 7:
|
||||
if (!$isNum) {
|
||||
$data['start_time'] = date("Y-m-d 00:00:00", strtotime("-$timeKey day"));
|
||||
$data['end_time'] = date('Y-m-d 23:59:59', time());
|
||||
$data['days'] = $timeKey;
|
||||
} else {
|
||||
$day = $timeKey * 2;
|
||||
$data['start_time'] = date("Y-m-d 00:00:00", strtotime("-$day day"));
|
||||
$data['end_time'] = date("Y-m-d 23:59:59", strtotime("-$timeKey day"));
|
||||
$data['days'] = $timeKey;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
$datetime_start = new \DateTime($timeKey['start_time']);
|
||||
$datetime_end = new \DateTime($timeKey['end_time']);
|
||||
$days = $datetime_start->diff($datetime_end)->days;
|
||||
$days = $days > 0 ? $days : 1;
|
||||
if (!$isNum) {
|
||||
$data['start_time'] = $timeKey['start_time'];
|
||||
$data['end_time'] = $timeKey['end_time'];
|
||||
$data['days'] = $days;
|
||||
} else {
|
||||
$data['start_time'] = date("Y-m-d 00:00:00", strtotime("-$days day"));
|
||||
$data['end_time'] = $timeKey['start_time'];
|
||||
$data['days'] = $days;
|
||||
}
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
}
|
171
app/admin/logic/statistic/UserStatisticLogic.php
Normal file
171
app/admin/logic/statistic/UserStatisticLogic.php
Normal file
@ -0,0 +1,171 @@
|
||||
<?php
|
||||
|
||||
namespace app\admin\logic\statistic;
|
||||
|
||||
use app\common\logic\BaseLogic;
|
||||
use app\common\model\store_order\StoreOrder;
|
||||
use app\common\model\user\User;
|
||||
use app\common\model\user\UserVisit;
|
||||
use app\common\model\user_recharge\UserRecharge;
|
||||
use Exception;
|
||||
|
||||
/**
|
||||
* Class 用户统计
|
||||
* @package app\services\statistic
|
||||
*/
|
||||
class UserStatisticLogic extends BaseLogic
|
||||
{
|
||||
/**
|
||||
* 基本概况
|
||||
* @param $where
|
||||
* @return mixed
|
||||
*/
|
||||
public function getBasic($where)
|
||||
{
|
||||
$time = explode('-', $where['create_time']);
|
||||
$time = [strtotime($time[0]), strtotime($time[1])];
|
||||
|
||||
if (count($time) != 2) throw new Exception('参数错误');
|
||||
$userVisit = new UserVisit();
|
||||
/** @var UserServices $user */
|
||||
$user = new User();
|
||||
$order = new StoreOrder();
|
||||
$user_recharge = new UserRecharge();
|
||||
// /** @var UserRechargeServices $recharge */
|
||||
// $recharge = app()->make(UserRechargeServices::class);
|
||||
// /** @var OtherOrderServices $otherOrder */
|
||||
// $otherOrder = app()->make(OtherOrderServices::class);
|
||||
|
||||
$now['people'] = $userVisit->where('create_time', 'between', $time)->group('uid')->count(); //访客数
|
||||
$now['browse'] = $userVisit->where('create_time', 'between', $time)->sum('id'); //访问量
|
||||
$now['newUser'] = $user->where('create_time', 'between', $time)->count(); //新增用户数
|
||||
$now['payPeople'] = $order->where('create_time', 'between', $time)->group('uid')->count(); //成交用户数
|
||||
$now['payPercent'] = bcmul((string)($now['people'] > 0 ? bcdiv($now['payPeople'], $now['people'], 4) : 0), '100', 2); //访问-付款转化率
|
||||
$now['payUser'] = $user->where('create_time', 'between', $time)->where('user_ship', 1)->count(); //激活付费会员数
|
||||
$now['rechargePeople'] = $user_recharge->where('create_time', 'between', $time)->where('paid', 1)->group('uid')->count(); //充值用户数
|
||||
$totalPayPrice = $order->where('create_time', 'between', $time)->where('paid', 1)->sum('pay_price');
|
||||
$now['payPrice'] = floatval($now['payPeople'] > 0 ? bcdiv($totalPayPrice, $now['payPeople'], 2) : 0); //客单价
|
||||
$now['cumulativeUser'] = $user->count(); //累计用户数
|
||||
$now['cumulativePayUser'] = 0; //count($otherOrder->getPayUserCount(strtotime($time[1]), $where['channel_type']));//到截至日期有付费会员状态的会员数
|
||||
$now['cumulativeRechargePeople'] = $user_recharge->where('paid', 1)->group('uid')->count(); //累计充值用户数
|
||||
$now['cumulativePayPeople'] = $order->where('paid', 1)->group('uid')->count(); //累计成交用户数
|
||||
|
||||
|
||||
$dayNum = ($time[1] - $time[0]) / 86400 + 1;
|
||||
$time = [
|
||||
strtotime("-$dayNum days", $time[0]),
|
||||
strtotime("-1 days", $time[0])
|
||||
];
|
||||
// $where['time'] = implode('-', $lastTime);
|
||||
// $toEndtime = implode('-', [0, $lastTime[1]]);
|
||||
$last['people'] = $userVisit->where('create_time', 'between', $time)->group('uid')->count(); //访客数
|
||||
$last['browse'] = $userVisit->where('create_time', 'between', $time)->sum('id'); //访问量
|
||||
$last['newUser'] = $user->where('create_time', 'between', $time)->count(); //新增用户数
|
||||
$last['payPeople'] = $order->where('create_time', 'between', $time)->group('uid')->count(); //成交用户数
|
||||
$last['payPercent'] = bcmul((string)($last['people'] > 0 ? bcdiv($last['payPeople'], $last['people'], 4) : 0), '100', 2); //访问-付款转化率
|
||||
$last['payUser'] = $user->where('create_time', 'between', $time)->where('user_ship', 1)->count(); //激活付费会员数
|
||||
$last['rechargePeople'] = $user_recharge->where('create_time', 'between', $time)->where('paid', 1)->group('uid')->count(); //充值用户数
|
||||
$totalPayPrice = $order->where('create_time', 'between', $time)->where('paid', 1)->sum('pay_price');
|
||||
$last['payPrice'] = floatval($last['payPeople'] > 0 ? bcdiv($totalPayPrice, $last['payPeople'], 2) : 0); //客单价
|
||||
$last['cumulativeUser'] = $user->count(); //累计用户数
|
||||
$last['cumulativePayUser'] = 0; //count($otherOrder->getPayUserCount(strtotime($lastTime[1]) + 86400, $where['channel_type']));//到截至日期有付费会员状态的会员数
|
||||
$last['cumulativeRechargePeople'] = $user_recharge->where('paid', 1)->group('uid')->count(); //累计充值用户数
|
||||
$last['cumulativePayPeople'] = $order->where('paid', 1)->group('uid')->count(); //累计成交用户数
|
||||
|
||||
//组合数据,计算环比
|
||||
$data = [];
|
||||
foreach ($now as $key => $item) {
|
||||
$data[$key]['num'] = $item;
|
||||
$data[$key]['last_num'] = $last[$key];
|
||||
$num = $last[$key] > 0 ? $last[$key] : 1;
|
||||
$data[$key]['percent'] = bcmul((string)bcdiv((string)($item - $last[$key]), (string)$num, 4), 100, 2);
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* 用户趋势
|
||||
* @param $where
|
||||
* @param $excel
|
||||
* @return mixed
|
||||
*/
|
||||
public function getTrend($where, $excel = false)
|
||||
{
|
||||
$time = explode('-', $where['create_time']);
|
||||
$time = [strtotime($time[0]), strtotime($time[1])];
|
||||
|
||||
$channelType = ''; //$where['channel_type'];
|
||||
if (count($time) != 2) throw new Exception('参数错误');
|
||||
$dayCount = ($time[1] - $time[0]) / 86400 + 1;
|
||||
$data = [];
|
||||
if ($dayCount == 1) {
|
||||
$data = $this->trend($time, $channelType, 0, $excel);
|
||||
} elseif ($dayCount > 1 && $dayCount <= 31) {
|
||||
$data = $this->trend($time, $channelType, 1, $excel);
|
||||
} elseif ($dayCount > 31 && $dayCount <= 92) {
|
||||
$data = $this->trend($time, $channelType, 3, $excel);
|
||||
} elseif ($dayCount > 92) {
|
||||
$data = $this->trend($time, $channelType, 30, $excel);
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* 用户趋势
|
||||
* @param $time
|
||||
* @param $channelType
|
||||
* @param $num
|
||||
* @param $excel
|
||||
* @return array
|
||||
*/
|
||||
public function trend($time, $channelType, $num, $excel)
|
||||
{
|
||||
$user = new User();
|
||||
$userVisit = new UserVisit();
|
||||
$order = new StoreOrder();
|
||||
$recharge = new UserRecharge();
|
||||
|
||||
$newPeople = $visitPeople = $paidPeople = $rechargePeople = $vipPeople = [];
|
||||
$newPeople['name'] = '新增用户数';
|
||||
$visitPeople['name'] = '访客数';
|
||||
$paidPeople['name'] = '成交用户数';
|
||||
$rechargePeople['name'] = '充值用户';
|
||||
$vipPeople['name'] = '新增付费用户数';
|
||||
if ($num == 0) {
|
||||
$xAxis = ['00', '01', '02', '03', '04', '05', '06', '07', '08', '09', '10', '11', '12', '13', '14', '15', '16', '17', '18', '19', '20', '21', '22', '23'];
|
||||
$timeType = '%H';
|
||||
} elseif ($num != 0) {
|
||||
$dt_start = $time[0];
|
||||
$dt_end = $time[1];
|
||||
while ($dt_start <= $dt_end) {
|
||||
if ($num == 30) {
|
||||
$xAxis[] = date('Y-m', $dt_start);
|
||||
$dt_start = strtotime("+1 month", $dt_start);
|
||||
$timeType = '%Y-%m';
|
||||
} else {
|
||||
$xAxis[] = date('Y-m-d', $dt_start);
|
||||
$dt_start = strtotime("+$num day", $dt_start);
|
||||
$timeType = '%Y-%m-%d';
|
||||
}
|
||||
}
|
||||
}
|
||||
$visitPeople = array_column($userVisit->getTrendData($time, $channelType, $timeType, 'count(distinct(uid))'), 'num', 'days');
|
||||
$newPeople = array_column($user->getTrendData($time, $channelType, $timeType), 'num', 'days');
|
||||
$paidPeople = array_column($order->getTrendData($time, $channelType, $timeType, 'count(distinct(uid))'), 'num', 'days');
|
||||
$rechargePeople = array_column($recharge->getTrendData(['paid'=>1],$time, $channelType, $timeType, 'count(distinct(uid))'), 'num', 'days');
|
||||
$vipPeople = array_column($recharge->getTrendData(['paid'=>1,'price'=>1000],$time, $channelType, $timeType, 'count(distinct(uid))'), 'num', 'days');
|
||||
|
||||
$data = $series = [];
|
||||
foreach ($xAxis as $item) {
|
||||
$data['新增用户数'][] = isset($newPeople[$item]) ? intval($newPeople[$item]) : 0;
|
||||
$data['访客数'][] = isset($visitPeople[$item]) ? intval($visitPeople[$item]) : 0;
|
||||
$data['成交用户数'][] = isset($paidPeople[$item]) ? intval($paidPeople[$item]) : 0;
|
||||
$data['充值用户'][] = isset($rechargePeople[$item]) ? intval($rechargePeople[$item]) : 0;
|
||||
$data['新增付费用户数'][] = isset($vipPeople[$item]) ? intval($vipPeople[$item]) : 0;
|
||||
}
|
||||
foreach ($data as $key => $item) {
|
||||
$series[] = ['name' => $key, 'value' => $item];
|
||||
}
|
||||
return compact('xAxis', 'series');
|
||||
}
|
||||
}
|
@ -52,6 +52,7 @@ class SystemStoreLogic extends BaseLogic
|
||||
'street' => $params['street_code'],
|
||||
'is_store' => $params['is_store'] ?? 0,
|
||||
'is_send' => $params['is_send'] ?? 0,
|
||||
'security_deposit' => $params['security_deposit'] ?? 0,
|
||||
]);
|
||||
$taff = [
|
||||
'store_id' => $store['id'],
|
||||
@ -111,6 +112,8 @@ class SystemStoreLogic extends BaseLogic
|
||||
'bank_address' => $params['bank_address']??'',
|
||||
'realname' => $params['realname']??'',
|
||||
'default_delivery' => $params['default_delivery'] ?? 2,
|
||||
'security_deposit' => $params['security_deposit'] ?? 0,
|
||||
|
||||
]);
|
||||
$res=SystemStoreStaff::where('store_id', $params['id'])->where('is_admin', 1)->where('account', $params['phone'])->find();
|
||||
if($params['password']!=''&&$res){
|
||||
|
@ -13,13 +13,19 @@
|
||||
// +----------------------------------------------------------------------
|
||||
namespace app\admin\logic\user;
|
||||
|
||||
use app\common\enum\OrderEnum;
|
||||
use app\common\enum\user\UserTerminalEnum;
|
||||
use app\common\enum\YesNoEnum;
|
||||
use app\common\logic\BaseLogic;
|
||||
use app\common\model\finance\CapitalFlow;
|
||||
use app\common\model\store_finance_flow\StoreFinanceFlow;
|
||||
use app\common\model\store_order\StoreOrder;
|
||||
use app\common\model\user\User;
|
||||
use app\common\model\user\UserAddress;
|
||||
use app\common\model\user\UserRecharge;
|
||||
use app\common\model\user_label\UserLabel;
|
||||
use app\common\model\user_sign\UserSign;
|
||||
use app\common\model\vip_flow\VipFlow;
|
||||
use think\facade\Db;
|
||||
use app\common\service\FileService;
|
||||
use Webman\Config;
|
||||
@ -178,4 +184,65 @@ class UserLogic extends BaseLogic
|
||||
$params['field'] => $params['value']
|
||||
]);
|
||||
}
|
||||
|
||||
public static function dealDetails($params)
|
||||
{
|
||||
switch ($params['type']){
|
||||
case 1:
|
||||
//采购款明细
|
||||
$categories = ['user_balance_recharge', 'user_order_purchase_pay'];
|
||||
$query = CapitalFlow::where('uid', $params['id'])
|
||||
->whereIn('category', $categories);
|
||||
$count = $query->count();
|
||||
$data = $query
|
||||
->page($params['page_no'],$params['page_size'])
|
||||
->select()->toArray();
|
||||
foreach ($data as &$value){
|
||||
if($value['category'] == 'user_order_purchase_pay'){
|
||||
$value['order_sn'] = StoreOrder::where('id',$value['link_id'])->value('order_id');
|
||||
}elseif($value['category'] == 'user_balance_recharge'){
|
||||
$value['order_sn'] = UserRecharge::where('id',$value['link_id'])->value('order_id');
|
||||
}
|
||||
}
|
||||
break;
|
||||
case 2:
|
||||
//余额明细
|
||||
$query = CapitalFlow::where('uid', $params['id'])
|
||||
->where('category', 'user_order_balance_pay');
|
||||
$count = $query->count();
|
||||
$data = $query
|
||||
->page($params['page_no'],$params['page_size'])
|
||||
->select()->toArray();
|
||||
foreach ($data as &$value){
|
||||
$value['order_sn'] = StoreOrder::where('id',$value['link_id'])->value('order_id');
|
||||
}
|
||||
|
||||
break;
|
||||
case 3:
|
||||
//礼品券明细
|
||||
$query = UserSign::where(['uid'=>$params['id']]);
|
||||
$count = $query->count();
|
||||
$data =$query
|
||||
->page($params['page_no'],$params['page_size'])
|
||||
->select()->toArray();
|
||||
break;
|
||||
case 4:
|
||||
//返还金明细 -todo back
|
||||
$query = VipFlow::with('store')->where(['user_id'=>$params['id']]);
|
||||
$count = $query->count();
|
||||
$data = $query
|
||||
->page($params['page_no'],$params['page_size'])
|
||||
->select()->toArray();
|
||||
break;
|
||||
default:
|
||||
$data = [];
|
||||
$count = 0;
|
||||
}
|
||||
return [
|
||||
'lists' => $data,
|
||||
'count' => $count
|
||||
];
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -34,6 +34,7 @@ class UserValidate extends BaseValidate
|
||||
'village' => 'require',
|
||||
'brigade' => 'require',
|
||||
'user_ship' => 'require',
|
||||
'type' => 'require|number',
|
||||
];
|
||||
|
||||
|
||||
@ -57,9 +58,14 @@ class UserValidate extends BaseValidate
|
||||
'village' => '村',
|
||||
'brigade' => ' 队',
|
||||
'user_ship' => ' 会员类型',
|
||||
'type' => '查询类型',
|
||||
];
|
||||
|
||||
public function sceneFund()
|
||||
{
|
||||
return $this->only(['type','id']);
|
||||
|
||||
}
|
||||
/**
|
||||
* @notes 添加场景
|
||||
* @return UserValidate
|
||||
|
@ -25,6 +25,16 @@ class CartController extends BaseApiController
|
||||
$params = (new CartValidate())->post()->goCheck('add');
|
||||
$params['uid'] = $this->request->userId;
|
||||
$result = Cart::where(['uid' => $params['uid'], 'store_id' => $params['store_id'], 'product_id' => $params['product_id'], 'is_fail' => 0, 'is_pay' => 0,'delete_time' => null])->find();
|
||||
|
||||
//判断起批发价
|
||||
$batch = StoreBranchProduct::where(
|
||||
['product_id'=>$params['product_id'],
|
||||
'store_id' => $params['store_id']
|
||||
]
|
||||
)->value('batch');
|
||||
if($params['cart_num'] < $batch){
|
||||
return $this->fail('起批发量低于最低值'.$batch);
|
||||
}
|
||||
$count = Cart::where(['uid' => $params['uid'], 'delete_time' => null, 'is_pay' => 0])->count();
|
||||
if ($count > 100) {
|
||||
return $this->fail('购物车商品不能大于100个,请先结算');
|
||||
|
@ -63,7 +63,7 @@ class ProductLists extends BaseAdminDataLists implements ListsSearchInterface, L
|
||||
*/
|
||||
public function setDefaultOrder(): array
|
||||
{
|
||||
return ['sales' => 'desc', 'price' => 'asc'];
|
||||
return [ 'price' => 'asc','id' => 'desc'];
|
||||
}
|
||||
|
||||
/**
|
||||
@ -105,25 +105,14 @@ class ProductLists extends BaseAdminDataLists implements ListsSearchInterface, L
|
||||
|
||||
$this->searchWhere[] = ['status', '=', 1];
|
||||
$this->searchWhere[] = ['stock', '>', 0];
|
||||
$data = StoreBranchProduct::where($this->searchWhere)
|
||||
->field(['id', 'product_id', 'cate_id', 'store_name', 'cost', 'store_id', 'price', 'bar_code', 'image', 'sales', 'store_info', 'delete_time', 'unit', 'batch'])
|
||||
->limit($this->limitOffset, $this->limitLength)
|
||||
return StoreBranchProduct::where($this->searchWhere)
|
||||
->field(['id', 'product_id', 'cate_id', 'store_name', 'cost', 'store_id','vip_price','purchase', 'price', 'bar_code', 'image', 'sales', 'store_info', 'delete_time', 'unit', 'batch'])
|
||||
->with(['className', 'unitName'])
|
||||
->limit($this->limitOffset, $this->limitLength)
|
||||
->order($this->sortOrder)
|
||||
->select()?->toArray();
|
||||
// $check = DictType::where('type','activities')->find();
|
||||
// foreach ($data as &$value){
|
||||
// if(isset($check) && $check['status'] == 1){
|
||||
// // $value['price'] = StoreProduct::where('id',$value['product_id'])->value('ot_price');
|
||||
// $value['ot_price'] = $value['price'];
|
||||
// $value['price'] = $value['cost'];
|
||||
// }
|
||||
// $value['is_default'] = 0;
|
||||
// if($store_id == 2){
|
||||
// $value['is_default'] = 1;
|
||||
// }
|
||||
// }
|
||||
return $data;
|
||||
// ->page($this->limitOffset +1,$this->limitLength)
|
||||
->select()->toArray();
|
||||
|
||||
}
|
||||
|
||||
|
||||
@ -149,29 +138,20 @@ class ProductLists extends BaseAdminDataLists implements ListsSearchInterface, L
|
||||
$this->searchWhere[] = ['store_id', '=', $store_id];
|
||||
}
|
||||
$class_all = $this->request->get('class_all');
|
||||
$where = [];
|
||||
if ($class_all) {
|
||||
//查3级别的
|
||||
$arr = Cate::where('pid', $class_all)->column('id');
|
||||
if ($arr) {
|
||||
$arr2 = Cate::where('pid', 'in', $arr)->column('id');
|
||||
$where[] = ['cate_id', 'in', array_merge($arr, $arr2)];
|
||||
$this->searchWhere[] = ['cate_id', 'in', array_merge($arr, $arr2)];
|
||||
}else{
|
||||
$this->searchWhere[] = ['cate_id','=',$class_all];
|
||||
}
|
||||
}
|
||||
if (empty($where) && $class_all) {
|
||||
//2或者1
|
||||
$where[] = ['cate_id', '=', $class_all];
|
||||
}
|
||||
$M_store_id = $this->request->__get('store_id');
|
||||
|
||||
$this->searchWhere[] = ['status', '=', 1];
|
||||
$this->searchWhere[] = ['stock', '>', 0];
|
||||
if ($M_store_id) {
|
||||
$where[] = ['store_id', '=', $M_store_id];
|
||||
$data = StoreBranchProduct::where($this->searchWhere)->where($where)
|
||||
->count();
|
||||
} else {
|
||||
$data = StoreBranchProduct::where($this->searchWhere)->where($where)
|
||||
->count();
|
||||
}
|
||||
return $data;
|
||||
return StoreBranchProduct::where($this->searchWhere)
|
||||
->count();
|
||||
}
|
||||
}
|
||||
|
@ -5,6 +5,7 @@ namespace app\api\logic\order;
|
||||
|
||||
use app\common\model\order\Cart;
|
||||
use app\common\logic\BaseLogic;
|
||||
use app\common\model\store_product_log\StoreProductLog;
|
||||
use think\facade\Db;
|
||||
|
||||
|
||||
@ -32,7 +33,7 @@ class CartLogic extends BaseLogic
|
||||
}
|
||||
Db::startTrans();
|
||||
try {
|
||||
Cart::create([
|
||||
$cart = Cart::create([
|
||||
'uid' => $params['uid'],
|
||||
'type' => $params['type']??'',
|
||||
'product_id' => $params['product_id'],
|
||||
@ -42,6 +43,15 @@ class CartLogic extends BaseLogic
|
||||
'cart_num' => $params['cart_num'],
|
||||
'is_new' => $params['is_new']??0,
|
||||
]);
|
||||
StoreProductLog::create([
|
||||
'type'=>'cart',
|
||||
'uid' => $params['uid'],
|
||||
'cart_id' => $cart['id'],
|
||||
'store_id' => $params['store_id']??0,
|
||||
'visit_num' => 1,
|
||||
'product_id' => $params['product_id'],
|
||||
'cart_num' => $params['cart_num'],
|
||||
]);
|
||||
Db::commit();
|
||||
return true;
|
||||
} catch (\Exception $e) {
|
||||
|
@ -134,6 +134,9 @@ class OrderLogic extends BaseLogic
|
||||
}else{
|
||||
$pay_price =bcsub(self::$pay_price, self::$activity_price, 2); //减去活动优惠金额
|
||||
}
|
||||
if($pay_price < 500){
|
||||
throw new Exception('金额低于500');
|
||||
}
|
||||
|
||||
$vipPrice = 0;
|
||||
//成本价 收益
|
||||
@ -189,7 +192,7 @@ class OrderLogic extends BaseLogic
|
||||
}
|
||||
$_order = $orderInfo['order'];
|
||||
$_order['uid'] = $user['id'];
|
||||
$_order['spread_uid'] =$params['spread_uid']??0;// UserSpreadLog::where('uid',request()->userId)->value('old_spread_uid')??0;//预留分享关系
|
||||
$_order['spread_uid'] =$params['spread_uid']??0;
|
||||
$_order['real_name'] = $user['real_name'];
|
||||
$_order['mobile'] = $user['mobile'];
|
||||
$_order['pay_type'] = $orderInfo['order']['pay_type'];
|
||||
|
@ -19,7 +19,7 @@ class CartValidate extends BaseValidate
|
||||
* @var string[]
|
||||
*/
|
||||
protected $rule = [
|
||||
'cart_num' => 'require|number',
|
||||
'cart_num' => 'require',
|
||||
'product_attr_unique' => 'require',
|
||||
'store_id' => 'require|number',
|
||||
'staff_id' => 'require|number',
|
||||
|
@ -146,13 +146,13 @@ class OrderEnum
|
||||
public static function getFinancialType($value = true)
|
||||
{
|
||||
$data = [
|
||||
self::USER_ORDER_PAY => '用户订单支付',
|
||||
self::USER_ORDER_PAY => '订单支付',
|
||||
self::MERCHANT_ORDER_PAY => '商户订单支付',
|
||||
self::PLATFORM_ORDER_PAY => '平台订单支付',
|
||||
self::MERCHANT_ORDER_OBTAINS => '商户',
|
||||
self::ORDER_HANDLING_FEES => '手续费',
|
||||
self::PLATFORM_ORDER_OBTAINS => '平台',
|
||||
self::SUPPLIER_ORDER_OBTAINS => '供应商',
|
||||
self::SUPPLIER_ORDER_OBTAINS => '成本',
|
||||
self::SYSTEM_SET => '平台设置',
|
||||
self::VILLAGE_ORDER_OBTAINS => '村长',
|
||||
self::BRIGADE_ORDER_OBTAINS=>'队长',
|
||||
|
@ -12,6 +12,7 @@ use app\common\model\pay\PayNotify;
|
||||
use app\common\model\store_finance_flow\StoreFinanceFlow;
|
||||
use app\common\model\store_order\StoreOrder;
|
||||
use app\common\model\store_order_cart_info\StoreOrderCartInfo;
|
||||
use app\common\model\store_product_log\StoreProductLog;
|
||||
use app\common\model\system_store\SystemStore;
|
||||
use app\common\model\user\User;
|
||||
use app\common\model\user\UserAddress;
|
||||
@ -86,7 +87,8 @@ class PayNotifyLogic extends BaseLogic
|
||||
}
|
||||
}
|
||||
$capitalFlowDao = new CapitalFlowLogic($user);
|
||||
$capitalFlowDao->userExpense('user_order_pay', 'order', $order['id'], $order['pay_price'],'',0,$order['store_id']);
|
||||
$capitalFlowDao->userExpense('user_order_balance_pay', 'order', $order['id'], $order['pay_price'],'',0,$order['store_id']);
|
||||
self::dealProductLog($order);
|
||||
// self::afterPay($order);
|
||||
// Redis::send('push-platform-print', ['id' => $order['id']], 60);
|
||||
// PushService::push('store_merchant_' . $order['store_id'], $order['store_id'], ['type' => 'store_merchant', 'msg' => '您有一笔新的订单']);
|
||||
@ -133,6 +135,7 @@ class PayNotifyLogic extends BaseLogic
|
||||
];
|
||||
OrderLogic::writeOff($params);
|
||||
}
|
||||
self::dealProductLog($order);
|
||||
|
||||
// self::afterPay($order);
|
||||
// Redis::send('push-platform-print', ['id' => $order['id']], 60);
|
||||
@ -171,6 +174,7 @@ class PayNotifyLogic extends BaseLogic
|
||||
$capitalFlowDao->userExpense('user_order_pay', 'order', $order['id'], $order->pay_price, '', 1,$order['store_id']);
|
||||
}
|
||||
|
||||
self::dealProductLog($order);
|
||||
|
||||
// if ($order->pay_type == 9) {
|
||||
// $extra['create_time'] = $order['create_time'];
|
||||
@ -268,6 +272,7 @@ class PayNotifyLogic extends BaseLogic
|
||||
self::afterPay($order);
|
||||
$cashFlowLogic = new CashFlowLogic();
|
||||
$cashFlowLogic->insert($order['store_id'], $order['pay_price']);
|
||||
self::dealProductLog($order);
|
||||
// Redis::send('push-platform-print', ['id' => $order['id']]);
|
||||
}
|
||||
|
||||
@ -298,6 +303,7 @@ class PayNotifyLogic extends BaseLogic
|
||||
$order->status = 2;
|
||||
self::afterPay($order);
|
||||
}
|
||||
self::dealProductLog($order);
|
||||
|
||||
// if ($order->pay_type == 9) {
|
||||
// $extra['create_time'] = $order['create_time'];
|
||||
@ -378,6 +384,7 @@ class PayNotifyLogic extends BaseLogic
|
||||
if ($deposit > $store_profit) {
|
||||
if ($store_profit > 0) {
|
||||
$financeLogic->out($transaction_id, $store_profit, OrderEnum::ORDER_MARGIN, $order['store_id'], $order['staff_id'], 0, $order['pay_type']);
|
||||
$financeLogic->in($transaction_id, 0, OrderEnum::MERCHANT_ORDER_OBTAINS, $order['store_id'], 0, 0, $order['pay_type']); //平台手续费
|
||||
}
|
||||
} else {
|
||||
$money = bcsub($store_profit, $deposit, 2);
|
||||
@ -446,6 +453,8 @@ class PayNotifyLogic extends BaseLogic
|
||||
'title' => '村长订单获得兑换券',
|
||||
'store_id' => $order['store_id'],
|
||||
'number' => $fees,
|
||||
'financial_pm' => 1,
|
||||
'user_ship' => 2,
|
||||
];
|
||||
$sing[] = [
|
||||
'uid' => $brigade_uid,
|
||||
@ -453,6 +462,26 @@ class PayNotifyLogic extends BaseLogic
|
||||
'title' => '队长订单获得兑换券',
|
||||
'store_id' => $order['store_id'],
|
||||
'number' => $fees,
|
||||
'financial_pm' => 1,
|
||||
'user_ship' => 3,
|
||||
];
|
||||
$sing[] = [
|
||||
'uid' => $village_uid,
|
||||
'order_id' => $order['order_id'],
|
||||
'title' => '订单扣除兑换券',
|
||||
'store_id' => $order['store_id'],
|
||||
'number' => $fees,
|
||||
'financial_pm' => 0,
|
||||
'user_ship' => 2,
|
||||
];
|
||||
$sing[] = [
|
||||
'uid' => $brigade_uid,
|
||||
'order_id' => $order['order_id'],
|
||||
'title' => '订单扣除兑换券',
|
||||
'store_id' => $order['store_id'],
|
||||
'number' => $fees,
|
||||
'financial_pm' => 0,
|
||||
'user_ship' => 3,
|
||||
];
|
||||
// if ($village_uid > 0) {
|
||||
// $financeLogic->other_arr['vip_uid'] = $village_uid;
|
||||
@ -552,4 +581,44 @@ class PayNotifyLogic extends BaseLogic
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* 商品统计逻辑
|
||||
* @param $order
|
||||
* @return true
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\DbException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
*/
|
||||
public static function dealProductLog($order)
|
||||
{
|
||||
$store_id = $order['store_id'];
|
||||
$cart_id = $order['cart_id'];
|
||||
$uid = $order['uid'];
|
||||
if($uid && $cart_id && $store_id){
|
||||
$cart_id = explode(',',$cart_id);
|
||||
$productLog = StoreProductLog::where([
|
||||
'uid'=>$uid
|
||||
])->whereIn('cart_id',$cart_id)
|
||||
->select()->toArray();
|
||||
|
||||
foreach ($productLog as &$value){
|
||||
$value['pay_uid'] = $uid;
|
||||
$value['oid'] = $order['id'];
|
||||
$cart_info = StoreOrderCartInfo::where([
|
||||
'uid'=>$uid,'old_cart_id'=>$value['cart_id'],'store_id'=>$store_id
|
||||
])->find();
|
||||
$value['order_num'] = $cart_info['cart_num']??1;
|
||||
$value['pay_num'] = $cart_info['cart_num']??1;
|
||||
$value['pay_price'] = $cart_info['price']??0;
|
||||
$value['cost_price'] = $cart_info['cart_info']['cost']??0;
|
||||
$value['update_time'] = time();
|
||||
unset($value['create_time'],$value['delete_time']);
|
||||
}
|
||||
|
||||
(new StoreProductLog())->saveAll($productLog);
|
||||
}
|
||||
return true;
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -118,6 +118,10 @@ class StoreOrderLogic extends BaseLogic
|
||||
$pay_price =bcsub(self::$pay_price, self::$activity_price, 2); //减去活动优惠金额
|
||||
$activity_string = '减免';
|
||||
}
|
||||
|
||||
if($pay_price < 500){
|
||||
throw new \think\Exception('金额低于500');
|
||||
}
|
||||
|
||||
$vipPrice = 0;
|
||||
//成本价 收益
|
||||
|
@ -4,6 +4,7 @@ namespace app\common\model\store_finance_flow;
|
||||
|
||||
|
||||
use app\common\model\BaseModel;
|
||||
use app\common\model\system_store\SystemStore;
|
||||
use app\common\model\system_store\SystemStoreStaff;
|
||||
use app\common\model\user\User;
|
||||
use think\model\concern\SoftDelete;
|
||||
@ -20,6 +21,11 @@ class StoreFinanceFlow extends BaseModel
|
||||
protected $name = 'store_finance_flow';
|
||||
protected $deleteTime = 'delete_time';
|
||||
|
||||
public function store()
|
||||
{
|
||||
return $this->hasOne(SystemStore::class, 'id','store_id')
|
||||
->bind(['store_name'=>'name', 'store_phone'=>'phone','store_detailed_address'=>'detailed_address','store_simple_address'=>'address']);
|
||||
}
|
||||
public function user()
|
||||
{
|
||||
return $this->hasOne(User::class, 'id', 'user_id')->bind(['nickname']);
|
||||
|
@ -25,19 +25,19 @@ class StoreOrder extends BaseModel
|
||||
|
||||
public function store()
|
||||
{
|
||||
return $this->hasOne(SystemStore::class, 'id','store_id')
|
||||
->bind(['store_name'=>'name', 'store_phone'=>'phone','store_detailed_address'=>'detailed_address','store_simple_address'=>'address']);
|
||||
return $this->hasOne(SystemStore::class, 'id', 'store_id')
|
||||
->bind(['store_name' => 'name', 'store_phone' => 'phone', 'store_detailed_address' => 'detailed_address', 'store_simple_address' => 'address']);
|
||||
}
|
||||
|
||||
public function getPayTypeNameTextAttr($value, $data)
|
||||
{
|
||||
$status = PayEnum::getPaySceneDesc($value)??'';
|
||||
$status = PayEnum::getPaySceneDesc($value) ?? '';
|
||||
return $status;
|
||||
}
|
||||
|
||||
public function getStatusNameTextAttr($value, $data)
|
||||
{
|
||||
$status = OrderEnum::getOrderType($data['status'])??'';
|
||||
$status = OrderEnum::getOrderType($data['status']) ?? '';
|
||||
return $status;
|
||||
}
|
||||
|
||||
@ -55,5 +55,64 @@ class StoreOrder extends BaseModel
|
||||
{
|
||||
return $this->hasOne(SystemStoreStaff::class, 'id', 'staff_id')->bind(['staff_name']);
|
||||
}
|
||||
|
||||
/**
|
||||
* 总销售额
|
||||
* @param $time
|
||||
* @return float
|
||||
*/
|
||||
public function totalSales($where)
|
||||
{
|
||||
return $this->where($where)->sum('pay_price');
|
||||
}
|
||||
/**
|
||||
* 用户趋势数据
|
||||
* @param $time
|
||||
* @param $type
|
||||
* @param $timeType
|
||||
* @return mixed
|
||||
*/
|
||||
public function getTrendData($time, $type, $timeType, $str)
|
||||
{
|
||||
return $this->when($type != '', function ($query) use ($type) {
|
||||
$query->where('channel_type', $type);
|
||||
})->where('paid', 1)->where('paid', '>=', 0)->where(function ($query) use ($time) {
|
||||
if ($time[0] == $time[1]) {
|
||||
$query->whereDay('create_time', $time[0]);
|
||||
} else {
|
||||
$time[1] = $time[1] + 86400;
|
||||
$query->whereTime('create_time', 'between', $time);
|
||||
}
|
||||
})->field("FROM_UNIXTIME(create_time,'$timeType') as days,$str as num")
|
||||
->group('days')->select()->toArray();
|
||||
}
|
||||
/**
|
||||
* 曲线统计
|
||||
* @param $time
|
||||
* @param $type
|
||||
* @param $timeType
|
||||
* @return mixed
|
||||
*/
|
||||
public function getCurveData($where,$time,$str)
|
||||
{
|
||||
return $this->where($where)
|
||||
->when(isset($time['timeKey']), function ($query) use ($time,$str) {
|
||||
$query->whereBetweenTime('create_time', $time['timeKey']['start_time'], $time['timeKey']['end_time']);
|
||||
if ($time['timeKey']['days'] == 1) {
|
||||
$timeUinx = "%H";
|
||||
} elseif ($time['timeKey']['days'] == 30) {
|
||||
$timeUinx = "%Y-%m-%d";
|
||||
} elseif ($time['timeKey']['days'] == 365) {
|
||||
$timeUinx = "%Y-%m";
|
||||
} elseif ($time['timeKey']['days'] > 1 && $time['timeKey']['days'] < 30) {
|
||||
$timeUinx = "%Y-%m-%d";
|
||||
} elseif ($time['timeKey']['days'] > 30 && $time['timeKey']['days'] < 365) {
|
||||
$timeUinx = "%Y-%m";
|
||||
} else {
|
||||
$timeUinx = "%Y-%m";
|
||||
}
|
||||
$query->field("$str as number,FROM_UNIXTIME(create_time, '$timeUinx') as time");
|
||||
$query->group("FROM_UNIXTIME(create_time, '$timeUinx')");
|
||||
})
|
||||
->order('create_time ASC')->select()->toArray();
|
||||
}
|
||||
}
|
||||
|
29
app/common/model/store_product_log/StoreProductLog.php
Normal file
29
app/common/model/store_product_log/StoreProductLog.php
Normal file
@ -0,0 +1,29 @@
|
||||
<?php
|
||||
|
||||
namespace app\common\model\store_product_log;
|
||||
|
||||
|
||||
use app\common\model\BaseModel;
|
||||
use app\common\model\system_store\SystemStore;
|
||||
use think\model\concern\SoftDelete;
|
||||
|
||||
|
||||
/**
|
||||
* 商品统计模型
|
||||
* Class StoreProductLog
|
||||
* @package app\common\model\store_product_log
|
||||
*/
|
||||
class StoreProductLog extends BaseModel
|
||||
{
|
||||
use SoftDelete;
|
||||
protected $name = 'store_product_log';
|
||||
protected $deleteTime = 'delete_time';
|
||||
|
||||
public function store()
|
||||
{
|
||||
return $this->hasOne(SystemStore::class, 'id', 'store_id')
|
||||
->bind(['store_name' => 'name', 'store_phone' => 'phone', 'store_detailed_address' => 'detailed_address', 'store_simple_address' => 'address']);
|
||||
}
|
||||
|
||||
|
||||
}
|
@ -6,6 +6,7 @@ namespace app\common\model\user;
|
||||
|
||||
use app\common\enum\user\UserEnum;
|
||||
use app\common\model\BaseModel;
|
||||
use app\common\model\user_label\UserLabel;
|
||||
use app\common\service\FileService;
|
||||
use think\model\concern\SoftDelete;
|
||||
|
||||
@ -20,14 +21,20 @@ class User extends BaseModel
|
||||
|
||||
protected $deleteTime = 'delete_time';
|
||||
|
||||
|
||||
//会员类型
|
||||
public function userShip()
|
||||
{
|
||||
return $this->hasOne(UserShip::class,'id','user_ship')
|
||||
// return $this->hasOne(UserShip::class,'user_ship','id')
|
||||
->bind(['vip_name'=>'title','discount','limit']);
|
||||
}
|
||||
|
||||
public function userLabel()
|
||||
{
|
||||
return $this->hasOne(UserLabel::class,'label_id','label_id')
|
||||
->bind(['label_name']);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* @notes 关联用户授权模型
|
||||
* @return \think\model\relation\HasOne
|
||||
@ -113,7 +120,7 @@ class User extends BaseModel
|
||||
*/
|
||||
public function getAvatarAttr($value)
|
||||
{
|
||||
if($value){
|
||||
if ($value) {
|
||||
return trim($value) ? FileService::getFileUrl($value) : '';
|
||||
}
|
||||
}
|
||||
@ -168,4 +175,25 @@ class User extends BaseModel
|
||||
// }
|
||||
return $sn;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取用户统计数据
|
||||
* @param $time
|
||||
* @param $type
|
||||
* @param $timeType
|
||||
* @return mixed
|
||||
*/
|
||||
public function getTrendData($time, $type, $timeType)
|
||||
{
|
||||
return $this->when($type != '', function ($query) use ($type) {
|
||||
$query->where('user_type', $type);
|
||||
})->where(function ($query) use ($time) {
|
||||
if ($time[0] == $time[1]) {
|
||||
$query->whereDay('create_time', $time[0]);
|
||||
} else {
|
||||
$time[1] = $time[1] + 86400;
|
||||
$query->whereTime('create_time', 'between', $time);
|
||||
}
|
||||
})->field("FROM_UNIXTIME(create_time,'$timeType') as days,count(id) as num")->group('days')->select()->toArray();
|
||||
}
|
||||
}
|
||||
|
@ -19,4 +19,25 @@ class UserVisit extends BaseModel
|
||||
|
||||
protected $deleteTime = 'delete_time';
|
||||
|
||||
/**
|
||||
* 用户趋势数据
|
||||
* @param $time
|
||||
* @param $type
|
||||
* @param $timeType
|
||||
* @param $str
|
||||
* @return mixed
|
||||
*/
|
||||
public function getTrendData($time, $type, $timeType, $str)
|
||||
{
|
||||
return $this->when($type != '', function ($query) use ($type) {
|
||||
$query->where('channel_type', $type);
|
||||
})->where(function ($query) use ($time) {
|
||||
if ($time[0] == $time[1]) {
|
||||
$query->whereDay('create_time', $time[0]);
|
||||
} else {
|
||||
$time[1] = $time[1] + 86400;
|
||||
$query->whereTime('create_time', 'between', $time);
|
||||
}
|
||||
})->field("FROM_UNIXTIME(create_time,'$timeType') as days,$str as num")->group('days')->select()->toArray();
|
||||
}
|
||||
}
|
@ -18,5 +18,26 @@ class UserRecharge extends BaseModel
|
||||
protected $name = 'user_recharge';
|
||||
protected $deleteTime = 'delete_time';
|
||||
|
||||
|
||||
}
|
||||
/**
|
||||
* 获取充值统计曲线
|
||||
* @param $time
|
||||
* @param $type
|
||||
* @param $timeType
|
||||
* @param string $str
|
||||
* @return mixed
|
||||
*/
|
||||
public function getTrendData($where,$time, $type, $timeType, $str = 'count(id)')
|
||||
{
|
||||
return $this->when($type != '', function ($query) use ($type) {
|
||||
$query->where('channel_type', $type);
|
||||
})->where($where)->where(function ($query) use ($time) {
|
||||
if ($time[0] == $time[1]) {
|
||||
$query->whereDay('create_time', $time[0]);
|
||||
} else {
|
||||
$time[1] = $time[1] + 86400;
|
||||
$query->whereTime('create_time', 'between', $time);
|
||||
}
|
||||
})->field("FROM_UNIXTIME(create_time,'$timeType') as days, " . $str . "as num")
|
||||
->group('days')->select()->toArray();
|
||||
}
|
||||
}
|
||||
|
@ -8,7 +8,7 @@ use think\model\concern\SoftDelete;
|
||||
|
||||
|
||||
/**
|
||||
* 计量单位
|
||||
* 积分记录
|
||||
* Class UserSign
|
||||
* @package app\common\model\user_sign
|
||||
*/
|
||||
|
20
app/common/model/vip_flow/VipFlow.php
Normal file
20
app/common/model/vip_flow/VipFlow.php
Normal file
@ -0,0 +1,20 @@
|
||||
<?php
|
||||
|
||||
namespace app\common\model\vip_flow;
|
||||
|
||||
use app\common\model\BaseModel;
|
||||
use app\common\model\system_store\SystemStore;
|
||||
use think\model\concern\SoftDelete;
|
||||
|
||||
class VipFlow extends BaseModel
|
||||
{
|
||||
use SoftDelete;
|
||||
protected $name = 'vip_flow';
|
||||
protected $deleteTime = 'delete_time';
|
||||
|
||||
public function store()
|
||||
{
|
||||
return $this->hasOne(SystemStore::class, 'id','store_id')
|
||||
->bind(['store_name'=>'name', 'store_phone'=>'phone','store_detailed_address'=>'detailed_address','store_simple_address'=>'address']);
|
||||
}
|
||||
}
|
@ -340,12 +340,12 @@ if (!function_exists('setUnique')) {
|
||||
{
|
||||
return substr(md5($sku . $id), 12, 11) . $type;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
if (!function_exists('generateUniqueVerificationCode')) {
|
||||
function generateUniqueVerificationCode() {
|
||||
function generateUniqueVerificationCode()
|
||||
{
|
||||
// 获取当前时间的毫秒部分
|
||||
list($msec, $sec) = explode(' ', microtime());
|
||||
$msectime = number_format((floatval($msec) + floatval($sec)) * 1000, 0, '', '');
|
||||
@ -355,20 +355,20 @@ if (!function_exists('generateUniqueVerificationCode')) {
|
||||
|
||||
// 将前缀、毫秒时间戳和随机数连接起来
|
||||
$type = rand(1, 10); // 生成一个1-10之间的随机数作为前缀
|
||||
return $type .'-'. $msectime . $randomNumber;
|
||||
return $type . '-' . $msectime . $randomNumber;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
if (!function_exists('verificationCode')) {
|
||||
function verificationCode() {
|
||||
function verificationCode()
|
||||
{
|
||||
$sec = time();
|
||||
// 将前缀、秒时间戳和随机数连接起来
|
||||
$type = rand(1, 10); // 生成一个1-10之间的随机数作为前缀
|
||||
$code = $type .'-'. $sec;
|
||||
$check = \app\common\model\store_order\StoreOrder::where('verify_code',$code)->count();
|
||||
if($check){
|
||||
$code = $type . '-' . $sec;
|
||||
$check = \app\common\model\store_order\StoreOrder::where('verify_code', $code)->count();
|
||||
if ($check) {
|
||||
verificationCode();
|
||||
}
|
||||
return $code;
|
||||
@ -376,10 +376,11 @@ if (!function_exists('verificationCode')) {
|
||||
}
|
||||
|
||||
if (!function_exists('createCode')) {
|
||||
function createCode($code) {
|
||||
$check = \app\common\model\store_order\StoreOrder::where('verify_code',$code)->count();
|
||||
if($check){
|
||||
$orderPickupCode = rand(1,10).'-'.str_pad(rand(0, 99999), 5, '0', STR_PAD_LEFT);
|
||||
function createCode($code)
|
||||
{
|
||||
$check = \app\common\model\store_order\StoreOrder::where('verify_code', $code)->count();
|
||||
if ($check) {
|
||||
$orderPickupCode = rand(1, 10) . '-' . str_pad(rand(0, 99999), 5, '0', STR_PAD_LEFT);
|
||||
return createCode($orderPickupCode);
|
||||
}
|
||||
return $code;
|
||||
@ -387,7 +388,8 @@ if (!function_exists('createCode')) {
|
||||
}
|
||||
|
||||
if (!function_exists('haversineDistance')) {
|
||||
function haversineDistance($latitude1, $longitude1, $latitude2, $longitude2) {
|
||||
function haversineDistance($latitude1, $longitude1, $latitude2, $longitude2)
|
||||
{
|
||||
$earthRadius = 6371; // 地球平均半径,单位是千米
|
||||
|
||||
// 将角度转换为弧度
|
||||
@ -400,7 +402,7 @@ if (!function_exists('haversineDistance')) {
|
||||
$lonDelta = $lonTo - $lonFrom;
|
||||
|
||||
$angle = 2 * asin(sqrt(pow(sin($latDelta / 2), 2) +
|
||||
cos($latFrom) * cos($latTo) * pow(sin($lonDelta / 2), 2)));
|
||||
cos($latFrom) * cos($latTo) * pow(sin($lonDelta / 2), 2)));
|
||||
return $angle * $earthRadius;
|
||||
}
|
||||
}
|
||||
@ -409,7 +411,8 @@ if (!function_exists('haversineDistance')) {
|
||||
* 随机验证码
|
||||
*/
|
||||
if (!function_exists('generateRandomCode')) {
|
||||
function generateRandomCode($length = 4) {
|
||||
function generateRandomCode($length = 4)
|
||||
{
|
||||
$code = '';
|
||||
for ($i = 0; $i < $length; $i++) {
|
||||
$code .= random_int(0, 9);
|
||||
@ -458,3 +461,18 @@ if (!function_exists('append_to_array')) {
|
||||
}
|
||||
}
|
||||
|
||||
if (!function_exists('countRate')) {
|
||||
/**
|
||||
* 计算环比增长率
|
||||
* @param $nowValue
|
||||
* @param $lastValue
|
||||
* @return float|int|string
|
||||
*/
|
||||
function countRate($nowValue, $lastValue)
|
||||
{
|
||||
if ($lastValue == 0 && $nowValue == 0) return 0;
|
||||
if ($lastValue == 0) return round(bcmul(bcdiv($nowValue, 1, 4), 100, 2), 2);
|
||||
if ($nowValue == 0) return -round(bcmul(bcdiv($lastValue, 1, 4), 100, 2), 2);
|
||||
return bcmul(bcdiv((bcsub($nowValue, $lastValue, 2)), $lastValue, 4), 100, 2);
|
||||
}
|
||||
}
|
||||
|
@ -102,9 +102,21 @@ class WorkbenchController extends BaseAdminController
|
||||
// ]
|
||||
public function get_basic(\app\admin\controller\WorkbenchController $workbench)
|
||||
{
|
||||
$params = $this->request->get();
|
||||
$params['store_id'] = $this->request->adminInfo['store_id'];
|
||||
return $workbench->get_basic();
|
||||
$dateRange = $this->request->get('date');
|
||||
// 拆分日期范围
|
||||
list($startDate, $endDate) = explode('-', $dateRange);
|
||||
$startTime = str_replace('/', '-', $startDate);
|
||||
$endTime = str_replace('/', '-', $endDate);
|
||||
if (empty($startTime)) { //如果没有传开始时间,则默认获取最近7天的数据
|
||||
$startTime = strtotime(date('Y-m-d'));
|
||||
$endTime = $startTime + 86400;
|
||||
}
|
||||
$where = [
|
||||
['create_time', 'between', [$startTime, $endTime]],
|
||||
['store_id','=',$this->request->adminInfo['store_id']]
|
||||
];
|
||||
$data = \app\admin\logic\WorkbenchLogic::get_basic($where);
|
||||
return $this->data($data);
|
||||
}
|
||||
|
||||
// #[
|
||||
@ -118,11 +130,12 @@ class WorkbenchController extends BaseAdminController
|
||||
// ApiDoc\Header(ref: [Definitions::class, "token"]),
|
||||
// ApiDoc\ResponseSuccess("data", type: "array"),
|
||||
// ]
|
||||
public function get_trend(\app\admin\controller\WorkbenchController $workbench)
|
||||
public function get_trend()
|
||||
{
|
||||
$params = $this->request->get();
|
||||
$params['store_id'] = $this->request->adminInfo['store_id'];
|
||||
return $workbench->get_trend();
|
||||
// $params = $this->request->get();
|
||||
$store_id = $this->request->adminInfo['store_id'];
|
||||
$workbench = WorkbenchLogic::get_trend($store_id);
|
||||
return $this->data($workbench);
|
||||
}
|
||||
|
||||
// #[
|
||||
@ -136,11 +149,25 @@ class WorkbenchController extends BaseAdminController
|
||||
// ApiDoc\Header(ref: [Definitions::class, "token"]),
|
||||
// ApiDoc\ResponseSuccess("data", type: "array"),
|
||||
// ]
|
||||
public function get_product_ranking(\app\admin\controller\WorkbenchController $workbench)
|
||||
public function get_product_ranking()
|
||||
{
|
||||
$params = $this->request->get();
|
||||
$params['store_id'] = $this->request->adminInfo['store_id'];
|
||||
return $workbench->get_product_ranking();
|
||||
// $params = $this->request->get();
|
||||
$dateRange = $this->request->get('date');
|
||||
// 拆分日期范围
|
||||
list($startDate, $endDate) = explode('-', $dateRange);
|
||||
$startTime = str_replace('/', '-', $startDate);
|
||||
$endTime = str_replace('/', '-', $endDate);
|
||||
if (empty($startTime)) {
|
||||
$startTime = strtotime(date('Y-m-d'));
|
||||
$endTime = $startTime + 86400;
|
||||
}
|
||||
$where = [
|
||||
['create_time', 'between', [$startTime, $endTime]],
|
||||
['store_id','=',$this->request->adminInfo['store_id']]
|
||||
];
|
||||
|
||||
$workbench = WorkbenchLogic::get_product_ranking($where);
|
||||
return $this->data($workbench);
|
||||
}
|
||||
|
||||
|
||||
|
@ -28,6 +28,15 @@ class CartController extends BaseAdminController
|
||||
$params['staff_id'] = $adminInfo['admin_id'];
|
||||
$params['store_id'] = $adminInfo['store_id'];
|
||||
$result = Cart::where(['uid' => 0,'staff_id'=>$adminInfo['admin_id'], 'store_id' => $adminInfo['store_id'], 'product_id' => $params['product_id'], 'is_fail' => 0, 'is_pay' => 0])->find();
|
||||
//判断起批发价
|
||||
$batch = StoreBranchProduct::where(
|
||||
['product_id'=>$params['product_id'],
|
||||
'store_id' => $adminInfo['store_id']
|
||||
]
|
||||
)->value('batch');
|
||||
if($params['cart_num'] < $batch){
|
||||
return $this->fail('起批发量低于最低值'.$batch);
|
||||
}
|
||||
$count = Cart::where(['uid' => $params['uid'], 'is_pay' => 0])->count();
|
||||
if ($count > 100) {
|
||||
return $this->fail('购物车商品不能大于100个,请先结算');
|
||||
|
@ -2,41 +2,18 @@
|
||||
|
||||
namespace app\store\controller\finance;
|
||||
|
||||
use app\admin\lists\store_finance_flow\StoreFinanceFlowLists;
|
||||
use app\common\controller\Definitions;
|
||||
|
||||
use app\common\logic\StoreFinanceFlowLogic;
|
||||
use app\store\controller\BaseAdminController;
|
||||
use app\store\lists\store_finance_flow\StoreFinanceFlowLists;
|
||||
|
||||
// #[ApiDoc\title('财务')]
|
||||
class FinanceController extends BaseAdminController
|
||||
{
|
||||
|
||||
// #[
|
||||
// ApiDoc\Title('财务流水'),
|
||||
// ApiDoc\url('/store/finance/finance/lists'),
|
||||
// ApiDoc\Method('GET'),
|
||||
// ApiDoc\NotHeaders(),
|
||||
// ApiDoc\Author('中国队长'),
|
||||
// ApiDoc\Query(name: 'keyword', type: 'string', require: false, desc: '订单编号'),
|
||||
// ApiDoc\Query(name: 'staff_id', type: 'int', require: false, desc: '店员id'),
|
||||
// ApiDoc\Query(name: 'start_time', type: 'string', require: false, desc: '开始时间'),
|
||||
// ApiDoc\Query(name: 'end_time', type: 'string', require: false, desc: '结束时间'),
|
||||
// ApiDoc\Header(ref: [Definitions::class, "token"]),
|
||||
// ApiDoc\Query(ref: [Definitions::class, "page"]),
|
||||
// ApiDoc\ResponseSuccess("data", type: "array", children: [
|
||||
// ['name' => 'id', 'desc' => 'ID', 'type' => 'int'],
|
||||
// ['name' => 'financial_record_sn', 'desc' => '流水号', 'type' => 'string'],
|
||||
// ['name' => 'order_sn', 'desc' => '订单号', 'type' => 'string'],
|
||||
// ['name' => 'number', 'desc' => '金额', 'type' => 'float'],
|
||||
// ['name' => 'create_time', 'desc' => '创建时间', 'type' => 'string'],
|
||||
// ['name' => 'nickname', 'desc' => '用户昵称', 'type' => 'string'],
|
||||
// ['name' => 'staff_name', 'desc' => '店员', 'type' => 'string'],
|
||||
// ['name' => 'store_name', 'desc' => '店铺名称', 'type' => 'string'],
|
||||
// ['name' => 'pay_type_name', 'desc' => '支付方式', 'type' => 'string'],
|
||||
// ['name' => 'financial_type_name', 'desc' => '流水类型', 'type' => 'string'],
|
||||
// ['name' => 'remark', 'desc' => '备注', 'type' => 'string'],
|
||||
// ]),
|
||||
// ]
|
||||
/**
|
||||
* 门店流水
|
||||
*/
|
||||
public function lists()
|
||||
{
|
||||
return $this->dataLists(new StoreFinanceFlowLists());
|
||||
|
@ -28,6 +28,7 @@ class SystemStoreStorageController extends BaseAdminController
|
||||
// ]
|
||||
public function lists()
|
||||
{
|
||||
$this->request->__set('status',-1);
|
||||
return $this->dataLists(new SystemStoreStorageLists());
|
||||
}
|
||||
|
||||
|
129
app/store/lists/store_finance_flow/StoreFinanceFlowLists.php
Normal file
129
app/store/lists/store_finance_flow/StoreFinanceFlowLists.php
Normal file
@ -0,0 +1,129 @@
|
||||
<?php
|
||||
|
||||
namespace app\store\lists\store_finance_flow;
|
||||
|
||||
|
||||
use app\admin\lists\BaseAdminDataLists;
|
||||
use app\common\enum\OrderEnum;
|
||||
use app\common\enum\PayEnum;
|
||||
use app\common\model\store_finance_flow\StoreFinanceFlow;
|
||||
use app\common\lists\ListsSearchInterface;
|
||||
use app\common\model\system_store\SystemStore;
|
||||
use app\common\model\system_store\SystemStoreStaff;
|
||||
use app\common\model\user\User;
|
||||
|
||||
/**
|
||||
* 门店流水列表
|
||||
* Class StoreFinanceFlowLists
|
||||
* @package app\admin\listsstore_finance_flow
|
||||
*/
|
||||
class StoreFinanceFlowLists extends BaseAdminDataLists implements ListsSearchInterface
|
||||
{
|
||||
|
||||
|
||||
/**
|
||||
* @notes 设置搜索条件
|
||||
* @return \string[][]
|
||||
* @author admin
|
||||
* @date 2024/05/31 16:56
|
||||
*/
|
||||
public function setSearch(): array
|
||||
{
|
||||
return [
|
||||
'=' => ['store_id', 'user_id', 'create_time', 'staff_id'],
|
||||
'between_time' => 'create_time',
|
||||
'%pipe_like%' => ['keyword' => 'order_sn'],
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @notes 获取门店流水列表
|
||||
* @return array
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\DbException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
* @author admin
|
||||
* @date 2024/05/31 16:56
|
||||
*/
|
||||
public function lists(): array
|
||||
{
|
||||
$field = [
|
||||
'id', 'order_id', 'order_sn', 'create_time', 'other_uid', 'user_id', 'store_id', 'staff_id', 'financial_type', 'financial_pm', 'pay_type', 'type', 'number', 'status'
|
||||
];
|
||||
$this->searchWhere[] = ['financial_type', '=', 1];
|
||||
$this->searchWhere[] = ['financial_pm', '=', 1];
|
||||
$data = StoreFinanceFlow::where($this->searchWhere)
|
||||
->field($field)
|
||||
->limit($this->limitOffset, $this->limitLength)
|
||||
->order(['id' => 'desc'])
|
||||
->select()->each(function ($item) {
|
||||
if ($item['user_id'] <= 0) {
|
||||
$item['nickname'] = '游客';
|
||||
} else {
|
||||
$id = $item['user_id'];
|
||||
$item['nickname'] = User::where('id', $item['user_id'])->value('nickname') . "|$id";
|
||||
}
|
||||
if (!empty($this->request->adminInfo['store_id'])) {
|
||||
$item['financial_pm'] = $item['financial_pm'] == 0 ? 1 : 0;
|
||||
}
|
||||
if ($item['financial_pm'] == 0) {
|
||||
$item['number'] = '-' . $item['number'];
|
||||
$item['financial_type_name'] = '订单支出:' . OrderEnum::getFinancialType($item['financial_type']);
|
||||
} else {
|
||||
$item['financial_type_name'] = OrderEnum::getFinancialType($item['financial_type']) . '获得';
|
||||
$item['number'] = '+' . $item['number'];
|
||||
}
|
||||
$item['staff_name'] = SystemStoreStaff::where('id', $item['staff_id'])->value('staff_name');
|
||||
$item['store_name'] = $item['store_id'] > 0 ? SystemStore::where('id', $item['store_id'])->value('name') : '';
|
||||
$item['pay_type_name'] = PayEnum::getPaySceneDesc($item['pay_type']);
|
||||
})->toArray();
|
||||
|
||||
foreach ($data as $key => $item) {
|
||||
$list1= StoreFinanceFlow::where('order_id', $item['order_id'])->where('financial_type', '>', 1)
|
||||
->where('financial_pm', 0)
|
||||
->field($field)->order('financial_pm', 'desc')->select()->each(function ($item) {
|
||||
if ($item['user_id'] <= 0) {
|
||||
$item['nickname'] = '游客';
|
||||
} else {
|
||||
$id = $item['user_id'];
|
||||
$item['nickname'] = User::where('id', $item['user_id'])->value('nickname') . "|$id";
|
||||
}
|
||||
$item['number'] = '-' . $item['number'];
|
||||
$item['financial_type_name'] = '订单支出:' . OrderEnum::getFinancialType($item['financial_type']);
|
||||
$item['staff_name'] = SystemStoreStaff::where('id', $item['staff_id'])->value('staff_name');
|
||||
$item['store_name'] = $item['store_id'] > 0 ? SystemStore::where('id', $item['store_id'])->value('name') : '';
|
||||
$item['pay_type_name'] = PayEnum::getPaySceneDesc($item['pay_type']);
|
||||
});
|
||||
$list2= StoreFinanceFlow::where('order_id', $item['order_id'])->where('financial_type' ,2)
|
||||
->where('financial_pm', 1)
|
||||
->field($field)->order('financial_pm', 'desc')->select()->each(function ($item) {
|
||||
if ($item['user_id'] <= 0) {
|
||||
$item['nickname'] = '游客';
|
||||
} else {
|
||||
$id = $item['user_id'];
|
||||
$item['nickname'] = User::where('id', $item['user_id'])->value('nickname') . "|$id";
|
||||
}
|
||||
$item['financial_type_name'] = OrderEnum::getFinancialType($item['financial_type']) . '获得';
|
||||
$item['number'] = '+' . $item['number'];
|
||||
$item['staff_name'] = SystemStoreStaff::where('id', $item['staff_id'])->value('staff_name');
|
||||
$item['store_name'] = $item['store_id'] > 0 ? SystemStore::where('id', $item['store_id'])->value('name') : '';
|
||||
$item['pay_type_name'] = PayEnum::getPaySceneDesc($item['pay_type']);
|
||||
});
|
||||
$data[$key]['list'] = array_merge($list1->toArray(), $list2->toArray());
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @notes 获取门店流水数量
|
||||
* @return int
|
||||
* @author admin
|
||||
* @date 2024/05/31 16:56
|
||||
*/
|
||||
public function count(): int
|
||||
{
|
||||
return StoreFinanceFlow::where($this->searchWhere)->count();
|
||||
}
|
||||
}
|
@ -46,10 +46,13 @@ class SystemStoreStorageLists extends BaseAdminDataLists implements ListsSearchI
|
||||
public function lists(): array
|
||||
{
|
||||
$this->searchWhere[] = ['store_id','=',$this->adminInfo['store_id']];//只显示当前门店的入库记录
|
||||
if($this->request->__get('status')==-1){
|
||||
$this->searchWhere[] = ['status','>',0];
|
||||
}
|
||||
return SystemStoreStorage::where($this->searchWhere)
|
||||
->field(['id', 'store_id', 'admin_id', 'staff_id', 'product_id', 'nums','mark', 'status'])
|
||||
->limit($this->limitOffset, $this->limitLength)
|
||||
->order(['id' => 'desc'])
|
||||
->order(['status' => 'aes'])
|
||||
->select()->each(function ($item) {
|
||||
$item['system_store_name'] = SystemStore::where('id', $item['store_id'])->value('name');
|
||||
$item['admin_name'] = Admin::where('id', $item['admin_id'])->value('name');
|
||||
|
@ -15,6 +15,7 @@
|
||||
namespace app\store\logic;
|
||||
|
||||
|
||||
use app\admin\logic\statistic\ProductStatisticLogic;
|
||||
use app\common\enum\OrderEnum;
|
||||
use app\common\enum\PayEnum;
|
||||
use app\common\enum\YesNoEnum;
|
||||
@ -45,21 +46,24 @@ class WorkbenchLogic extends BaseLogic
|
||||
public static function index($params)
|
||||
{
|
||||
$data = [];
|
||||
$startTimeDefault = date('Y-m-d',time());
|
||||
$endTimeDefault =date('Y-m-d', strtotime($startTimeDefault) + 86400);
|
||||
$startTime = $params['start_time'];
|
||||
$endTime = $params['end_time'];
|
||||
$endTime = date('Y-m-d', strtotime($endTime) + 86400);
|
||||
$dateDiff = (new \DateTime($endTime))->diff(new \DateTime($startTime));
|
||||
|
||||
$orderLogic = new StoreOrderLogic();
|
||||
//订单总金额
|
||||
$data['order_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTimeDefault, $endTimeDefault);
|
||||
$data['order_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTime, $endTime);
|
||||
//余额支付总金额
|
||||
$data['balance_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTimeDefault, $endTimeDefault, ['pay_type' => PayEnum::BALANCE_PAY]);
|
||||
$data['balance_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTime, $endTime, ['pay_type' => PayEnum::BALANCE_PAY]);
|
||||
//线下收银总金额
|
||||
$data['cashier_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTimeDefault, $endTimeDefault, ['shipping_type' => 3]);
|
||||
$data['cashier_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTime, $endTime, ['shipping_type' => 3]);
|
||||
//现金收银总金额
|
||||
$data['cash_amount'] = StoreCashFinanceFlow::where('store_id', $params['store_id'])->whereBetweenTime('create_time', $startTimeDefault, $endTimeDefault)->sum('cash_price');
|
||||
$data['cash_amount'] = StoreCashFinanceFlow::where('store_id', $params['store_id'])->whereBetweenTime('create_time', $startTime, $endTime)->sum('cash_price');
|
||||
//核销订单金额
|
||||
$data['verify_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTimeDefault, $endTimeDefault, ['shipping_type' => 2]);
|
||||
$data['verify_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTime, $endTime, ['shipping_type' => 2]);
|
||||
//门店收益金额
|
||||
$data['income_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTimeDefault, $endTimeDefault, [], 'profit');
|
||||
$data['income_amount'] = $orderLogic->storeOrderSumByDate($params['store_id'], $startTime, $endTime, [], 'profit');
|
||||
//门店收款金额
|
||||
$data['receipt_amount'] = UserRecharge::where([
|
||||
'store_id'=>$params['store_id'],
|
||||
@ -68,14 +72,10 @@ class WorkbenchLogic extends BaseLogic
|
||||
//门店成交用户数
|
||||
$data['user_number'] = StoreOrder::where('store_id', $params['store_id'])
|
||||
->where('paid', 1)
|
||||
->whereBetweenTime('pay_time', $startTimeDefault, $endTimeDefault)
|
||||
->whereBetweenTime('pay_time', $startTime, $endTime)
|
||||
->group('uid')
|
||||
->count();
|
||||
|
||||
$startTime = $params['start_time'];
|
||||
$endTime = $params['end_time'];
|
||||
$endTime = date('Y-m-d', strtotime($endTime) + 86400);
|
||||
$dateDiff = (new \DateTime($endTime))->diff(new \DateTime($startTime));
|
||||
if ($dateDiff->days == 1) {
|
||||
$group = 'HOUR(pay_time)';
|
||||
$i = 0;
|
||||
@ -726,6 +726,116 @@ class WorkbenchLogic extends BaseLogic
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 商品趋势
|
||||
*/
|
||||
public static function get_trend($store_id)
|
||||
{
|
||||
$dates = [];
|
||||
$today = new \DateTime();
|
||||
$thirtyDaysAgo = new \DateTime($today->format('Y-m-d'));
|
||||
$thirtyDaysAgo->modify('-30 days');
|
||||
|
||||
for ($i = 0; $i < 31; $i++) {
|
||||
$date = new \DateTime($thirtyDaysAgo->format('Y-m-d'));
|
||||
$date->modify('+' . $i . ' days');
|
||||
$dates[] = $date->format('Y-m-d');
|
||||
}
|
||||
$data = [
|
||||
"xAxis" => $dates,
|
||||
"series" => [
|
||||
[
|
||||
"name" => "商品浏览量",
|
||||
"data" => self::store_visit_count($dates,$store_id),
|
||||
"type" => "line",
|
||||
"smooth" => "true",
|
||||
"yAxisIndex" => 1
|
||||
],
|
||||
[
|
||||
"name" => "商品访客量",
|
||||
"data" => self::store_visit_user($dates,$store_id),
|
||||
"type" => "line",
|
||||
"smooth" => "true",
|
||||
"yAxisIndex" => 1
|
||||
],
|
||||
[
|
||||
"name" => "支付金额",
|
||||
"data" => self::payPrice($dates,$store_id),
|
||||
"type" => "bar"
|
||||
],
|
||||
[
|
||||
"name" => "退款金额",
|
||||
"data" => self::refundPrice($dates,$store_id),
|
||||
"type" => "bar"
|
||||
]
|
||||
]
|
||||
];
|
||||
return $data;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 商品浏览量
|
||||
*/
|
||||
public static function store_visit_count($dates,$store_id)
|
||||
{
|
||||
$data = [];
|
||||
foreach ($dates as $date) {
|
||||
$data[] = StoreVisit::whereDay('create_time', $date)->where('store_id',$store_id)->cache('store_visit_count_' . $date, 300)->sum('count');
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 商品浏览量
|
||||
*/
|
||||
public static function store_visit_user($dates,$store_id)
|
||||
{
|
||||
$data = [];
|
||||
foreach ($dates as $date) {
|
||||
$data[] = StoreVisit::whereDay('create_time', $date)->where('store_id',$store_id)->cache('store_visit_user_' . $date, 300)->count('uid');
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 支付金额
|
||||
*/
|
||||
public static function payPrice($dates,$store_id)
|
||||
{
|
||||
$data = [];
|
||||
foreach ($dates as $date) {
|
||||
$data[] = StoreOrder::whereDay('create_time', $date)->where('store_id',$store_id)->cache('payPrice_' . $date, 300)->where('paid', 1)->where('refund_status', 0)->sum('pay_price');
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 退款金额
|
||||
*/
|
||||
public static function refundPrice($dates,$store_id)
|
||||
{
|
||||
$data = [];
|
||||
foreach ($dates as $date) {
|
||||
$data[] = StoreOrder::whereDay('create_time', $date)->where('store_id',$store_id)->where('status', 'in', [-1, -2])->cache('refundPrice_' . $date, 300)->where('paid', 1)->sum('pay_price');
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 获取商品排名数据
|
||||
*/
|
||||
public static function get_product_ranking($where)
|
||||
{
|
||||
return (new ProductStatisticLogic())->get_product_ranking($where);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user