123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- <?php
- namespace app\admin\service\statistics;
- use app\model\Order;
- use app\model\OrderReturn;
- use app\model\PayDetail;
- use support\Db;
- class OrderService
- {
- public static function getOrder()
- {
- // 今日订单
- $todayTimeUnix = strtotime(date('Y-m-d'));
- // 今日订单
- $data['todayOrder'] = Order::where('order_addtimes', '>', $todayTimeUnix)->where('order_category', '<>', 'RECHARGE')->count();
- // 今日收入
- // $couponDetails = Db::select("select * from app_coupon_detail where coupon_detail_deadline_datetime != '' AND CAST(UNIX_TIMESTAMP(coupon_detail_deadline_datetime) as SIGNED) < " . time());
- $data['todayRevenue'] = PayDetail::whereRaw('CAST(UNIX_TIMESTAMP(pay_paytimes) as SIGNED) > ? ' , [$todayTimeUnix])
- ->where('join_pay_order_id','<>','')
- ->where('pay_status', 'SUCCESS')
- ->where('pay_category', '<>', 'RETURN')
- ->where('pay_category', '<>', 'REFUND')
- ->where('pay_category', '<>', 'RECHARGE')
- ->where('pay_category', '<>', 'CLEAR')
- ->sum('pay_amount');
- $refundAmount = PayDetail::whereRaw('CAST(UNIX_TIMESTAMP(pay_paytimes) as SIGNED) > ? ' , [$todayTimeUnix])
- ->where('pay_status', 'SUCCESS')
- ->where('pay_category', 'REFUND')
- ->sum('pay_amount');
- // $data['todayRevenue'] = $data['todayRevenue'] - $refundAmount;
- $data['todayRevenue'] = round($data['todayRevenue'],2);
- // 今日充值额
- $data['todayRecharge'] = Order::where('order_status_payment', 'SUCCESS')
- ->where('order_addtimes', '>', $todayTimeUnix)
- ->where('order_category', 'RECHARGE')
- ->where('order_status_payment','SUCCESS')
- ->sum('order_amount_pay');
- // 今日退单
- $data['todayRefund'] = OrderReturn::where('order_return_addtimes', '>', $todayTimeUnix)
- ->count();
- // 柱状图
- // 产品订单
- $newAddition = Db::select("SELECT DATE_FORMAT(FROM_UNIXTIME(order_addtimes), '%Y/%m') AS `month`,count(*) as `num` FROM app_order group by month");
- // $newAddition = Db::select("
- // SELECT DATE_FORMAT(FROM_UNIXTIME(order_sheet_addtimes), '%Y/%m') AS `month`,count(*) as `num` FROM app_order_sheet as s
- // left join app_goods as g on s.join_sheet_goods_id = g.goods_id
- // where g.goods_classify = 'GOODS'
- // group by month
- // ");
- $category = [];
- $newAdditionData = [];
- foreach ($newAddition as $item) {
- if (!in_array($item->month, $category)) {
- $category[] = $item->month;
- }
- // $newAdditionData['category'][] = $item->month;
- // $newAdditionData['data'][] = $item->num;
- }
- // 服务订单
- $newAdditionService = Db::select("
- SELECT DATE_FORMAT(FROM_UNIXTIME(order_sheet_addtimes), '%Y/%m') AS `month`,count(*) as `num` FROM app_order_sheet as s
- left join app_goods as g on s.join_sheet_goods_id = g.goods_id
- where g.goods_classify = 'SERVICE'
- group by month
- ");
- $newAdditionServiceData = [];
- foreach ($newAdditionService as $item) {
- if (!in_array($item->month, $category)) {
- $category[] = $item->month;
- }
- // $newAdditionServiceData['category'][] = $item->month;
- // $newAdditionServiceData['data'][] = $item->num;
- }
- sort($category);
- foreach ($category as $item2){
- $isHaveService = false;
- $isHaveGoods = false;
- foreach ($newAdditionService as $item){
- if ($item2 == $item->month){
- $isHaveService = true;
- $newAdditionServiceData['category'][] = $item->month;
- $newAdditionServiceData['data'][] = $item->num;
- }
- }
- foreach ($newAddition as $item3){
- if ($item2 == $item3->month){
- $isHaveGoods = true;
- $newAdditionData['category'][] = $item3->month;
- $newAdditionData['data'][] = $item3->num;
- }
- }
- if (!$isHaveService){
- $newAdditionServiceData['category'][] = $item2;//['month'=>$item2,'num'=>0];
- $newAdditionServiceData['data'][] = 0;
- }
- if (!$isHaveGoods){
- $newAdditionData['category'][] = $item2;//['month'=>$item2,'num'=>0];
- $newAdditionData['data'][] = 0;
- }
- }
- $data['addition']['goods'] = $newAdditionData;
- $data['addition']['service'] = $newAdditionServiceData;
- return $data;
- }
- }
|