restore composer.json, add mysqli extension
This commit is contained in:
90
app/Http/Resources/OrderCount.php
Executable file
90
app/Http/Resources/OrderCount.php
Executable file
@@ -0,0 +1,90 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Resources;
|
||||
|
||||
use App\Models\Order;
|
||||
use Carbon\CarbonPeriod;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
class OrderCount extends JsonResource
|
||||
{
|
||||
protected $date_from;
|
||||
|
||||
protected $date_to;
|
||||
|
||||
public function __construct($date_from,$date_to)
|
||||
{
|
||||
$this->date_from = $date_from;
|
||||
$this->date_to = $date_to;
|
||||
}
|
||||
|
||||
/**
|
||||
* Transform the resource into an array.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function toArray($request)
|
||||
{
|
||||
return [
|
||||
'labels' => $this->labels(),
|
||||
'datasets' => [
|
||||
[
|
||||
'label' => Order::status(0),
|
||||
'data' => $this->counts(0),
|
||||
'borderColor' => Order::color(0),
|
||||
'fill' => false
|
||||
],
|
||||
[
|
||||
'label' => Order::status(1),
|
||||
'data' => $this->counts(1),
|
||||
'borderColor' => Order::color(1),
|
||||
'fill' => false
|
||||
],
|
||||
[
|
||||
'label' => Order::status(2),
|
||||
'data' => $this->counts(2),
|
||||
'borderColor' => Order::color(2),
|
||||
'fill' => false
|
||||
],
|
||||
[
|
||||
'label' => Order::status(3),
|
||||
'data' => $this->counts(3),
|
||||
'borderColor' => Order::color(3),
|
||||
'fill' => false
|
||||
],
|
||||
[
|
||||
'label' => Order::status(4),
|
||||
'data' => $this->counts(4),
|
||||
'borderColor' => Order::color(4),
|
||||
'fill' => false
|
||||
],
|
||||
|
||||
]
|
||||
];
|
||||
}
|
||||
|
||||
public function labels(){
|
||||
$period = CarbonPeriod::create($this->date_from,$this->date_to);
|
||||
$dates =[];
|
||||
foreach ($period as $date) {
|
||||
$dates[] = $date->format('Y-m-d');
|
||||
}
|
||||
return $dates;
|
||||
}
|
||||
|
||||
public function counts($status){
|
||||
$count = Order::select(DB::raw('count(id) as count'),DB::raw('DATE(created_at) as date'))
|
||||
->where('status',$status)
|
||||
->groupBy('date')
|
||||
->whereBetween('created_at',[$this->date_from,$this->date_to])
|
||||
->pluck('count','date');
|
||||
$chart = [];
|
||||
$period = $this->labels();
|
||||
foreach ($period as $date) {
|
||||
$chart[] = (!empty($count[$date])) ? $count[$date]:0;
|
||||
}
|
||||
return $chart;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user