fixed missing days and sorting in traffic widget

This commit is contained in:
Čarodej
2022-02-28 09:03:57 +01:00
parent 2e80da830a
commit c2e4b50df5
5 changed files with 69 additions and 39 deletions

View File

@@ -1,7 +1,7 @@
<template> <template>
<div <div
class="relative block cursor-pointer lg:mr-2 lg:w-2 2xl:w-3" class="relative block cursor-pointer lg:mr-2 lg:w-2 2xl:w-3"
:style="{ height: bar.percentage + '%' }" :style="{ height: bar.percentage > 0 ? bar.percentage + '%' : '10px' }"
@mouseover="isVisible = true" @mouseover="isVisible = true"
@mouseleave="isVisible = false" @mouseleave="isVisible = false"
> >
@@ -22,7 +22,10 @@
<div class="h-3 w-3 origin-top-left -rotate-45 transform bg-gray-800 dark:bg-white"></div> <div class="h-3 w-3 origin-top-left -rotate-45 transform bg-gray-800 dark:bg-white"></div>
</div> </div>
</div> </div>
<span class="bg-theme block h-full w-full rounded-lg"></span> <span
class="block h-full w-full rounded-lg"
:class="{'bg-theme': bar.percentage > 0, 'bg-gray-200': bar.percentage === 0}"
></span>
</div> </div>
</template> </template>
<script> <script>

View File

@@ -4,16 +4,6 @@
> >
<!--Data bar--> <!--Data bar-->
<Bar v-for="(item, i) in data" :key="i" :bar="item" /> <Bar v-for="(item, i) in data" :key="i" :bar="item" />
<!--Ghost bar-->
<span
v-if="ghostLength > 0"
class="relative block cursor-pointer bg-gray-100 dark:bg-gray-800 lg:mr-2 lg:w-2 2xl:w-3"
v-for="(ghost, i) in ghostLength"
:style="{ height: '7%' }"
:key="i"
>
</span>
</div> </div>
</template> </template>
<script> <script>
@@ -25,10 +15,5 @@ export default {
components: { components: {
Bar, Bar,
}, },
computed: {
ghostLength() {
return 45 - this.data.length
},
},
} }
</script> </script>

View File

@@ -1,7 +1,10 @@
<?php <?php
namespace App\Users\Resources; namespace App\Users\Resources;
use ByteUnits\Metric; use ByteUnits\Metric;
use Carbon\CarbonPeriod;
use Illuminate\Support\Collection;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
use Illuminate\Http\Resources\Json\JsonResource; use Illuminate\Http\Resources\Json\JsonResource;
@@ -20,18 +23,18 @@ class UserStorageResource extends JsonResource
$totalCapacity = match (get_settings('subscription_type')) { $totalCapacity = match (get_settings('subscription_type')) {
'metered' => $this->usedCapacity / 1000000000, 'metered' => $this->usedCapacity / 1000000000,
'fixed' => $this->limitations->max_storage_amount, 'fixed' => $this->limitations->max_storage_amount,
default => $this->limitations->max_storage_amount, default => $this->limitations->max_storage_amount,
}; };
return [ return [
'data' => [ 'data' => [
'id' => (string) $this->id, 'id' => (string)$this->id,
'type' => 'storage', 'type' => 'storage',
'attributes' => [ 'attributes' => [
'used' => Metric::bytes($this->usedCapacity)->format(), 'used' => Metric::bytes($this->usedCapacity)->format(),
'capacity' => format_gigabytes($totalCapacity), 'capacity' => format_gigabytes($totalCapacity),
'percentage' => (float) get_storage_percentage($this->usedCapacity, $totalCapacity), 'percentage' => (float)get_storage_percentage($this->usedCapacity, $totalCapacity),
], ],
'meta' => [ 'meta' => [
'traffic' => [ 'traffic' => [
@@ -44,23 +47,23 @@ class UserStorageResource extends JsonResource
], ],
'images' => [ 'images' => [
'used' => Metric::bytes($images)->format(), 'used' => Metric::bytes($images)->format(),
'percentage' => (float) get_storage_percentage($images, $totalCapacity), 'percentage' => (float)get_storage_percentage($images, $totalCapacity),
], ],
'audios' => [ 'audios' => [
'used' => Metric::bytes($audios)->format(), 'used' => Metric::bytes($audios)->format(),
'percentage' => (float) get_storage_percentage($audios, $totalCapacity), 'percentage' => (float)get_storage_percentage($audios, $totalCapacity),
], ],
'videos' => [ 'videos' => [
'used' => Metric::bytes($videos)->format(), 'used' => Metric::bytes($videos)->format(),
'percentage' => (float) get_storage_percentage($videos, $totalCapacity), 'percentage' => (float)get_storage_percentage($videos, $totalCapacity),
], ],
'documents' => [ 'documents' => [
'used' => Metric::bytes($documents)->format(), 'used' => Metric::bytes($documents)->format(),
'percentage' => (float) get_storage_percentage($documents, $totalCapacity), 'percentage' => (float)get_storage_percentage($documents, $totalCapacity),
], ],
'others' => [ 'others' => [
'used' => Metric::bytes($others)->format(), 'used' => Metric::bytes($others)->format(),
'percentage' => (float) get_storage_percentage($others, $totalCapacity), 'percentage' => (float)get_storage_percentage($others, $totalCapacity),
], ],
], ],
], ],
@@ -130,18 +133,26 @@ class UserStorageResource extends JsonResource
->where('user_id', $this->id) ->where('user_id', $this->id)
->where('created_at', '>', $period) ->where('created_at', '>', $period)
->orderBy('created_at') ->orderBy('created_at')
->get(); ->get(['upload', 'download', 'created_at'])
->each(fn($record) => $record->created_at = format_date($record->created_at, 'd. M. Y'))
->keyBy('created_at');
$upload = $trafficRecords->map(fn ($record) => [ $mappedTrafficRecords = mapTrafficRecords($trafficRecords);
'created_at' => format_date($record->created_at, 'd. M. '),
'percentage' => $uploadMax !== 0 ? round(($record->upload / $uploadMax) * 100, 2) : 0, $upload = $mappedTrafficRecords->map(fn($record) => [
'created_at' => $record->created_at,
'amount' => Metric::bytes($record->upload)->format(), 'amount' => Metric::bytes($record->upload)->format(),
'percentage' => $uploadMax !== 0
? round(($record->upload / $uploadMax) * 100, 2)
: 0,
]); ]);
$download = $trafficRecords->map(fn ($record) => [ $download = $mappedTrafficRecords->map(fn($record) => [
'created_at' => format_date($record->created_at, 'd. M. '), 'created_at' => $record->created_at,
'percentage' => $downloadMax !== 0 ? round(($record->download / $downloadMax) * 100, 2) : 0,
'amount' => Metric::bytes($record->download)->format(), 'amount' => Metric::bytes($record->download)->format(),
'percentage' => $downloadMax !== 0
? round(($record->download / $downloadMax) * 100, 2)
: 0,
]); ]);
return [$downloadTotal, $uploadTotal, $upload, $download]; return [$downloadTotal, $uploadTotal, $upload, $download];

View File

@@ -52,7 +52,7 @@ class GetDashboardDataController extends Controller
{ {
// Set period range for data retrieval // Set period range for data retrieval
$period = now() $period = now()
->subDays(44) ->subDays(45)
->endOfDay(); ->endOfDay();
// Get bandwidth data // Get bandwidth data
@@ -64,16 +64,20 @@ class GetDashboardDataController extends Controller
DB::raw('sum(upload) as upload') DB::raw('sum(upload) as upload')
) )
->groupBy('created_at') ->groupBy('created_at')
->get(); ->get(['upload', 'download', 'created_at'])
->each(fn($record) => $record->created_at = format_date($record->created_at, 'd. M. Y'))
->keyBy('created_at');
$upload = $trafficRecords->map(fn ($record) => [ $mappedTrafficRecords = mapTrafficRecords($trafficRecords);
'created_at' => format_date($record->created_at, 'd. M. '),
$upload = $mappedTrafficRecords->map(fn ($record) => [
'created_at' => $record->created_at,
'percentage' => intval($trafficRecords->max('upload')) !== 0 ? round(($record->upload / $trafficRecords->max('upload')) * 100, 2) : 0, 'percentage' => intval($trafficRecords->max('upload')) !== 0 ? round(($record->upload / $trafficRecords->max('upload')) * 100, 2) : 0,
'amount' => Metric::bytes($record->upload)->format(), 'amount' => Metric::bytes($record->upload)->format(),
]); ]);
$download = $trafficRecords->map(fn ($record) => [ $download = $mappedTrafficRecords->map(fn ($record) => [
'created_at' => format_date($record->created_at, 'd. M. '), 'created_at' => $record->created_at,
'percentage' => intval($trafficRecords->max('download')) !== 0 ? round(($record->download / $trafficRecords->max('download')) * 100, 2) : 0, 'percentage' => intval($trafficRecords->max('download')) !== 0 ? round(($record->download / $trafficRecords->max('download')) * 100, 2) : 0,
'amount' => Metric::bytes($record->download)->format(), 'amount' => Metric::bytes($record->download)->format(),
]); ]);

View File

@@ -648,6 +648,33 @@ if (! function_exists('getThumbnailFileList')) {
} }
} }
if (! function_exists('mapTrafficRecords')) {
/**
* Map missing dates
*/
function mapTrafficRecords(Collection $trafficRecords): Collection
{
$records = collect();
foreach (range(44, 0) as $day) {
$day = now()->subDays($day)->translatedFormat('d. M. Y');
if (optional($trafficRecords)[$day]) {
$records->push($trafficRecords[$day]);
} else {
$record = new Collection();
$record->upload = 0;
$record->download = 0;
$record->created_at = $day;
$records->add($record);
}
}
return $records;
}
}
if (! function_exists('map_language_translations')) { if (! function_exists('map_language_translations')) {
/** /**
* It map language translations as language key and language value * It map language translations as language key and language value