mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-18 16:22:14 +00:00
fixed missing days and sorting in traffic widget
This commit is contained in:
@@ -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>
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
@@ -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];
|
||||||
|
|||||||
@@ -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(),
|
||||||
]);
|
]);
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user