add sequencing tab
This commit is contained in:
@@ -155,19 +155,49 @@ class DashboardController extends Controller
|
||||
// return response()->json(['error' => 'Missing epiweek range'], 400);
|
||||
// }
|
||||
|
||||
return response()->json($data);
|
||||
}
|
||||
// return response()->json($data);
|
||||
// }
|
||||
|
||||
public function fetchSourceData(){
|
||||
try{
|
||||
public function fetchSourceData()
|
||||
{
|
||||
try {
|
||||
$this->dataRetrievalService->getSurveillanceData();
|
||||
return response()->json(['message' => 'Data loaded successfully!'], 200);
|
||||
}
|
||||
catch (\Exception $e)
|
||||
{
|
||||
} catch (\Exception $e) {
|
||||
return response()->json(['error' => 'Data loaded unsuccessfully!'], 400);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Sequencing Dashboard
|
||||
|--------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
public function sequencing(Request $request)
|
||||
{
|
||||
$surveillanceId = (int) $request->query('surveillance_id');
|
||||
$range = $this->getEpiRange($request);
|
||||
|
||||
if (!$surveillanceId || !$range) {
|
||||
return response()->json(['error' => 'Missing parameters'], 400);
|
||||
}
|
||||
|
||||
return response()->json([
|
||||
'trend' => $this->service->sequencingTrend(
|
||||
$surveillanceId,
|
||||
$range['startYear'],
|
||||
$range['startWeek'],
|
||||
$range['endYear'],
|
||||
$range['endWeek']
|
||||
),'distribution' => $this->service->subtypeDistribution(
|
||||
$surveillanceId,
|
||||
$range['startYear'],
|
||||
$range['startWeek'],
|
||||
$range['endYear'],
|
||||
$range['endWeek']
|
||||
)
|
||||
]);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -727,28 +727,20 @@ class DashboardService
|
||||
$q->select('lab_code')
|
||||
->from('surveillance_cases')
|
||||
->where('surveillance_id', $surveillanceId)
|
||||
->whereRaw(
|
||||
"(year_data > ? OR (year_data = ? AND week_data >= ?))",
|
||||
[$startYear, $startYear, $startWeek]
|
||||
)
|
||||
->whereRaw(
|
||||
"(year_data < ? OR (year_data = ? AND week_data <= ?))",
|
||||
[$endYear, $endYear, $endWeek]
|
||||
);
|
||||
->whereRaw("(year_data > ? OR (year_data = ? AND week_data >= ?))", [$startYear, $startYear, $startWeek])
|
||||
->whereRaw("(year_data < ? OR (year_data = ? AND week_data <= ?))", [$endYear, $endYear, $endWeek]);
|
||||
})
|
||||
|
||||
->where('case_lab_results.is_positive', 1)
|
||||
|
||||
->selectRaw("
|
||||
case_lab_results.subtype,
|
||||
COALESCE(NULLIF(case_lab_results.subtype, ''), 'Unsubtyped') as subtype,
|
||||
COUNT(DISTINCT case_lab_results.lab_code) as total
|
||||
")
|
||||
|
||||
->whereNotNull('case_lab_results.subtype')
|
||||
->where('case_lab_results.subtype', '!=', '')
|
||||
->where('case_lab_results.subtype', '!=', 'Positive')
|
||||
|
||||
->groupBy('case_lab_results.subtype')
|
||||
->groupBy('subtype')
|
||||
->orderByDesc('total')
|
||||
->get();
|
||||
|
||||
@@ -846,5 +838,40 @@ class DashboardService
|
||||
->get();
|
||||
|
||||
}
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| sequencing trend
|
||||
|--------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
|
||||
public function sequencingTrend($surveillanceId, $startYear, $startWeek, $endYear, $endWeek)
|
||||
{
|
||||
return CaseLabResult::join(
|
||||
'surveillance_cases',
|
||||
'case_lab_results.lab_code',
|
||||
'=',
|
||||
'surveillance_cases.lab_code'
|
||||
)
|
||||
->where('surveillance_cases.surveillance_id', $surveillanceId)
|
||||
|
||||
->where('case_lab_results.is_positive', 1)
|
||||
|
||||
->whereNotNull('subtype')
|
||||
|
||||
->where(function ($q) use ($startYear, $startWeek, $endYear, $endWeek) {
|
||||
$q->whereRaw("(year_data > ? OR (year_data = ? AND week_data >= ?))", [$startYear, $startYear, $startWeek])
|
||||
->whereRaw("(year_data < ? OR (year_data = ? AND week_data <= ?))", [$endYear, $endYear, $endWeek]);
|
||||
})
|
||||
|
||||
->selectRaw("
|
||||
surveillance_cases.week_data as period,
|
||||
subtype,
|
||||
COUNT(DISTINCT surveillance_cases.lab_code) as total
|
||||
")
|
||||
|
||||
->groupBy('period', 'subtype')
|
||||
->orderBy('period')
|
||||
->get();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user