change of the browsing functionality

This commit is contained in:
Milos Holba
2022-04-14 16:25:57 +02:00
parent d71e598758
commit ad8793ce28
3 changed files with 90 additions and 29 deletions
+1 -1
View File
@@ -62,6 +62,6 @@ return [
], ],
'paginate' => [ 'paginate' => [
'perPage' => 50 'perPage' => 15
] ]
]; ];
@@ -2,7 +2,6 @@
namespace Domain\Browsing\Controllers; namespace Domain\Browsing\Controllers;
use Str; use Str;
use Illuminate\Http\Request;
use Domain\Files\Models\File; use Domain\Files\Models\File;
use Domain\Folders\Models\Folder; use Domain\Folders\Models\Folder;
use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Auth;
@@ -11,25 +10,40 @@ use Domain\Folders\Resources\FolderResource;
class BrowseFolderController class BrowseFolderController
{ {
public function __invoke( public function __invoke(
Request $request,
string $id, string $id,
): array { ): array {
$root_id = Str::isUuid($id) ? $id : null; $root_id = Str::isUuid($id) ? $id : null;
$folderQuery = [
'parent_id' => $root_id,
'team_folder' => false,
'user_id' => Auth::id(),
'deleted_at' => null
];
$fileQuery = [
'parent_id' => $root_id,
'user_id' => Auth::id(),
'deleted_at' => null
];
list($foldersTake, $foldersSkip, $filesTake, $filesSkip, $totalItemsCount) = getRecordsCount($folderQuery, $fileQuery);
$folders = Folder::with(['parent:id,name', 'shared:token,id,item_id,permission,is_protected,expire_in']) $folders = Folder::with(['parent:id,name', 'shared:token,id,item_id,permission,is_protected,expire_in'])
->where('parent_id', $root_id) ->where($folderQuery)
->where('team_folder', false)
->where('user_id', Auth::id())
->sortable() ->sortable()
->skip($foldersSkip)
->take($foldersTake)
->get(); ->get();
$files = File::with(['parent:id,name', 'shared:token,id,item_id,permission,is_protected,expire_in']) $files = File::with(['parent:id,name', 'shared:token,id,item_id,permission,is_protected,expire_in'])
->where('parent_id', $root_id) ->where($fileQuery)
->where('user_id', Auth::id())
->sortable() ->sortable()
->skip($filesSkip)
->take($filesTake)
->get(); ->get();
list($data, $paginate, $links) = groupPaginate($request, $folders, $files); list($data, $paginate, $links) = groupPaginate($folders, $files, $totalItemsCount);
return [ return [
'data' => $data, 'data' => $data,
+65 -18
View File
@@ -5,12 +5,12 @@ use ByteUnits\Metric;
use App\Users\Models\User; use App\Users\Models\User;
use Illuminate\Support\Arr; use Illuminate\Support\Arr;
use Illuminate\Support\Str; use Illuminate\Support\Str;
use Illuminate\Http\Request;
use Domain\Files\Models\File; use Domain\Files\Models\File;
use Domain\Sharing\Models\Share; use Domain\Sharing\Models\Share;
use Domain\Folders\Models\Folder; use Domain\Folders\Models\Folder;
use Illuminate\Support\Collection; use Illuminate\Support\Collection;
use Domain\Settings\Models\Setting; use Domain\Settings\Models\Setting;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Http; use Illuminate\Support\Facades\Http;
use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\QueryException; use Illuminate\Database\QueryException;
@@ -1157,13 +1157,13 @@ if (! function_exists('replace_occurrence')) {
* Group paginate of Foldes and Files * Group paginate of Foldes and Files
*/ */
function groupPaginate( function groupPaginate(
Request $request,
?Collection $folders = null, ?Collection $folders = null,
?Collection $files = null ?Collection $files = null,
int $totalItemsCount
) : array { ) : array {
$perPage = config('vuefilemanager.paginate.perPage'); $perPage = config('vuefilemanager.paginate.perPage');
$currentPage = $request->get('page') === 'all' ? 1 : (int)$request->get('page'); $currentPage = request()->input('page') === 'all' ? 1 : (int)request()->input('page');
// Collect Folders with Files // Collect Folders with Files
$entries = collect([ $entries = collect([
@@ -1171,20 +1171,11 @@ if (! function_exists('replace_occurrence')) {
$files ? json_decode((new FilesCollection($files))->toJson(), true) : null, $files ? json_decode((new FilesCollection($files))->toJson(), true) : null,
])->collapse(); ])->collapse();
if($request->input('page') === 'all') { $uri = request()->fullUrl();
// If is page set to 'all' return all records $lastPage = ceil($totalItemsCount / $perPage);
$groupPaginate = $entries;
} else {
// Paginate grouped Folders and Files
$groupPaginate = $entries->forPage($currentPage, $perPage)->values();
}
$uri = $request->fullUrl();
$lastPage = ceil(count($entries) / $perPage);
return [ return [
$groupPaginate, $entries,
[ [
'currentPage' => $currentPage, 'currentPage' => $currentPage,
'from' => 1, 'from' => 1,
@@ -1192,7 +1183,7 @@ if (! function_exists('replace_occurrence')) {
'path' => $uri, 'path' => $uri,
'perPage' => $perPage, 'perPage' => $perPage,
'to' => $perPage, 'to' => $perPage,
'total' => count($entries), 'total' => $totalItemsCount,
], ],
[ [
'first' => $uri . '&page=' . 1, 'first' => $uri . '&page=' . 1,
@@ -1202,6 +1193,62 @@ if (! function_exists('replace_occurrence')) {
] ]
]; ];
} }
}
if(! function_exists('getRecordsCount')) {
/**
* Get count of items from the Database
*/
function getRecordsCount (
array $folderQuery,
array $fileQuery
) : array {
$perPage = config('vuefilemanager.paginate.perPage');
$currentPage = request()->input('page') === 'all' ? 1 : (int)request()->input('page');
$foldersSkip = 0;
$foldersTake = 0;
$filesSkip = 0;
$filesTake = 0;
$foldersCount = DB::table('folders')
->where($folderQuery)
->count();
$filesCount = DB::table('files')
->where($fileQuery)
->count();
$totalItemsCount = $foldersCount + $filesCount;
if(request()->input('page') !== 'all') {
// Folders pages
if($foldersCount >= $currentPage * $perPage) {
$foldersTake = $perPage;
$foldersSkip = ($currentPage - 1) * $perPage;
}
// Mixed page
if($foldersCount < $currentPage * $perPage && ceil($currentPage) === ceil($foldersCount / $perPage) ) {
$foldersSkip = ($currentPage - 1) * $perPage;
$foldersTake = $foldersCount - $foldersSkip;
$filesTake = ($currentPage * $perPage) - $foldersCount;
$filesSkip = 0;
}
// Files pages
if($currentPage > ceil($foldersCount / $perPage)) {
$filesTake = $perPage;
$filesSkip = ((ceil($foldersCount / $perPage) * $perPage) - $foldersCount) + ($currentPage - (ceil($foldersCount / $perPage)) -1) * $perPage;
}
} else {
$foldersTake = $foldersCount;
$filesTake = $filesCount;
}
return [$foldersTake, $foldersSkip, $filesTake, $filesSkip, $totalItemsCount];
}
}
}
} }