1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- <?php
-
- namespace App\Utils;
-
- use DB;
- use Illuminate\Support\Carbon;
- use App\Model\Master\ItemKantongs;
- use Auth;
-
- class DashboardUtil
- {
- public function getDataLast30Days($param, $petugas_udd_id, $date_at)
- {
- $query = ItemKantongs::where('status_id', $param)
- ->where('unit_donor_darah_id', $petugas_udd_id)
- ->whereBetween(DB::raw('date(kantong_items.'.$date_at.')'), [\Carbon::now()->subDays(30), \Carbon::now()])
- ->orderBy($date_at, 'ASC');
- $query->select(
- DB::raw("DATE_FORMAT(kantong_items.".$date_at.", '%Y-%m-%d') as date, count(*) as total"),
- )
- ->groupBy(DB::raw('Date(kantong_items.'.$date_at.')'));
- $data = $query->get();
-
- $arr= [];
- for ($i = 29; $i >= 0; $i--) {
- $date = \Carbon::now()->subDays($i)->format('Y-m-d');
- $arr[$date] = 0;
- }
-
- for ($i = 29; $i >= 0; $i--) {
- $date = \Carbon::now()->subDays($i)->format('Y-m-d');
-
- if(!empty($data[$i])){
- $tanggal = $data[$i]->date;
- $arr[$tanggal] = $data[$i]->total;
- }
- }
-
- ksort($arr);
- return $arr;
- }
-
- public function getDataLast1Years($param, $petugas_udd_id)
- {
- $now = Carbon::now();
- $year = $now->year;
-
- $query = DB::select("SELECT COUNT(*) as jumlah, MONTH(updated_at) as bulan FROM kantong_items WHERE YEAR(updated_at) = $year and status_id = $param and unit_donor_darah_id = $petugas_udd_id GROUP BY MONTH(updated_at)");
-
- $data = array();
- for($i=0; $i<=12; $i++)
- {
- if(!empty($query[$i])){
- if($query[$i]->bulan != $i+1){
- $data[$i] = 0;
- }
- $bulan = $query[$i]->bulan;
- $data[$bulan] = $query[$i]->jumlah;
- }else{
- if(empty($data[$i])){
- $data[$i] = 0;
- }
- }
- }
- ksort($data);
- return $data;
- }
- }
|