ConsultancyProject_2_ETL/dashboard/routes/web.php

73 lines
2.2 KiB
PHP
Raw Normal View History

2024-12-18 10:14:56 +01:00
<?php
use Illuminate\Support\Facades\Route;
2024-12-18 15:14:13 +01:00
use App\Api;
2024-12-18 10:14:56 +01:00
Route::get('/', function () {
2024-12-18 15:14:13 +01:00
2024-12-20 21:46:54 +01:00
$regionHeat = Api::regionCapacities(1);
2024-12-18 19:52:06 +01:00
$propertiesGrowth = Api::propertiesGrowth();
2024-12-18 15:14:13 +01:00
$propsPerRegion = Api::propertiesPerRegion();
$propsPerRegionName = [];
$propsPerRegionCounts = [];
foreach ($propsPerRegion as $el) {
$propsPerRegionName[] = $el['name'];
$propsPerRegionCounts[] = $el['count_properties'];
}
2024-12-18 19:52:06 +01:00
$propertiesGeo = Api::propertiesGeo();
2024-12-20 21:46:54 +01:00
return view('overview', ["heat" => $regionHeat, "geo" => $propertiesGeo, "growth" => $propertiesGrowth, "propsPerRegion" => [json_encode($propsPerRegionName), json_encode($propsPerRegionCounts)]]);
2024-12-18 15:14:13 +01:00
});
Route::get('/prop/{id}', function (int $id) {
2024-12-18 19:52:06 +01:00
$propertyBase = Api::propertyBase($id);
2024-12-18 15:14:13 +01:00
$extractions = Api::propertyExtractions($id);
$propertyCapacities = Api::propertyCapacities($id);
2025-01-09 18:34:20 +01:00
$propertyNeighbours = Api::propertyNeighbours($id);
//$regionCapacities = Api::regionCapacities(-1);
$regionCapacities = [];
$propertyCapacitiesMonthly = [];
$propertyCapacitiesDaily = [];
foreach ($extractions as $extraction) {
$propertyCapacitiesMonthly[] = Api::propertyCapacitiesMonthly($id, $extraction['created_at']);
2025-01-09 18:34:20 +01:00
$propertyCapacitiesDaily[] = Api::propertyCapacitiesDaily($id, $extraction['created_at']);
}
2024-12-18 15:14:13 +01:00
$data = [];
$dates = [];
foreach ($extractions as $ext) {
$series = [];
$dates[] = $ext['created_at'];
2024-12-18 19:52:06 +01:00
2024-12-18 15:14:13 +01:00
$extCalendar = json_decode($ext['calendar'], 1);
foreach ($extCalendar as $date => $status) {
$series[] = [$date, $status];
}
$data[] = $series;
}
2025-01-09 18:34:20 +01:00
return view('property', ['base' => $propertyBase[0], "extractiondates" => json_encode($dates), "calendar" => $data, 'capacities' => $propertyCapacities, 'capacitiesMonthly' => $propertyCapacitiesMonthly, 'capacitiesDaily' => $propertyCapacitiesDaily, 'regionCapacities' => $regionCapacities, 'neighbours' => $propertyNeighbours]);
});
Route::get('/region/{id}', function (int $id) {
$regionCapacities = Api::regionCapacities($id);
dump($regionCapacities);
return view('region', ['capacities' => $regionCapacities]);
2024-12-18 10:14:56 +01:00
});