mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-05 18:23:48 +00:00
added it_get_trash_root
This commit is contained in:
@@ -29,12 +29,12 @@ class BrowseController extends Controller
|
||||
$folders_trashed = Folder::onlyTrashed()
|
||||
->with(['trashed_folders', 'parent'])
|
||||
->where('user_id', $user_id)
|
||||
->get(['parent_id', 'unique_id', 'name']);
|
||||
->get(['parent_id', 'id', 'name']);
|
||||
|
||||
$folders = Folder::onlyTrashed()
|
||||
->with(['parent'])
|
||||
->where('user_id', $user_id)
|
||||
->whereIn('unique_id', filter_folders_ids($folders_trashed))
|
||||
->whereIn('id', filter_folders_ids($folders_trashed))
|
||||
->sortable()
|
||||
->get();
|
||||
|
||||
@@ -42,6 +42,7 @@ class BrowseController extends Controller
|
||||
$files_trashed = File::onlyTrashed()
|
||||
->with(['parent'])
|
||||
->where('user_id', $user_id)
|
||||
->whereNull('folder_id')
|
||||
->whereNotIn('folder_id', array_values(array_unique(recursiveFind($folders_trashed->toArray(), 'unique_id'))))
|
||||
->sortable()
|
||||
->get();
|
||||
|
||||
@@ -418,11 +418,11 @@ function appeared_once($arr)
|
||||
* @param $folders
|
||||
* @return array
|
||||
*/
|
||||
function filter_folders_ids($folders, $by_column = 'unique_id')
|
||||
function filter_folders_ids($folders, $by_column = 'id')
|
||||
{
|
||||
$folder_unique_ids = recursiveFind($folders->toArray(), $by_column);
|
||||
$folder_ids = recursiveFind($folders->toArray(), $by_column);
|
||||
|
||||
return appeared_once($folder_unique_ids);
|
||||
return appeared_once($folder_ids);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -53,13 +53,13 @@ Route::group(['middleware' => ['auth:sanctum']], function () {
|
||||
Route::get('/sharing', [BrowseController::class, 'shared']);
|
||||
Route::get('/latest', [BrowseController::class, 'latest']);
|
||||
Route::get('/search', [BrowseController::class, 'search']);
|
||||
Route::get('/trash', [BrowseController::class, 'trash']);
|
||||
});
|
||||
|
||||
// Trash
|
||||
Route::group(['prefix' => 'trash'], function () {
|
||||
Route::post('/restore-items', [TrashController::class, 'restore']);
|
||||
Route::delete('/empty-trash', [TrashController::class, 'clear']);
|
||||
Route::get('/', [BrowseController::class, 'trash']);
|
||||
});
|
||||
|
||||
// Favourites
|
||||
|
||||
@@ -57,7 +57,7 @@ class BrowseTest extends TestCase
|
||||
|
||||
$this->getJson("/api/browse/navigation")
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
->assertExactJson([
|
||||
[
|
||||
"name" => "Home",
|
||||
"location" => "base",
|
||||
@@ -149,7 +149,7 @@ class BrowseTest extends TestCase
|
||||
|
||||
$this->getJson("/api/browse/folders/$root->id")
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
->assertExactJson([
|
||||
[
|
||||
"id" => $folder->id,
|
||||
"user_id" => $user->id,
|
||||
@@ -245,7 +245,7 @@ class BrowseTest extends TestCase
|
||||
|
||||
$this->getJson("/api/browse/latest")
|
||||
->assertStatus(200)
|
||||
->assertJson([
|
||||
->assertExactJson([
|
||||
[
|
||||
"id" => $file_2->id,
|
||||
"user_id" => $user->id,
|
||||
@@ -297,6 +297,95 @@ class BrowseTest extends TestCase
|
||||
]);
|
||||
}
|
||||
|
||||
public function it_get_participant_uploads()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* @test
|
||||
*/
|
||||
public function it_get_trash_root()
|
||||
{
|
||||
$user = User::factory(User::class)
|
||||
->create();
|
||||
|
||||
Sanctum::actingAs($user);
|
||||
|
||||
$folder = Folder::factory(Folder::class)
|
||||
->create([
|
||||
'parent_id' => null,
|
||||
'name' => 'root',
|
||||
'user_id' => $user->id,
|
||||
'deleted_at' => Carbon::now(),
|
||||
"user_scope" => "master",
|
||||
]);
|
||||
|
||||
$file = File::factory(File::class)
|
||||
->create([
|
||||
'folder_id' => null,
|
||||
'name' => 'Document',
|
||||
'basename' => 'document.pdf',
|
||||
"mimetype" => "application/pdf",
|
||||
"user_scope" => "master",
|
||||
"type" => "file",
|
||||
'user_id' => $user->id,
|
||||
'deleted_at' => Carbon::now(),
|
||||
]);
|
||||
|
||||
File::factory(File::class)
|
||||
->create([
|
||||
'folder_id' => $folder->id,
|
||||
'name' => 'Document 1',
|
||||
'basename' => 'document-1.pdf',
|
||||
"mimetype" => "application/pdf",
|
||||
"user_scope" => "master",
|
||||
"type" => "file",
|
||||
'user_id' => $user->id,
|
||||
'deleted_at' => Carbon::now(),
|
||||
]);
|
||||
|
||||
$this->getJson("/api/browse/trash")
|
||||
->assertStatus(200)
|
||||
->assertExactJson([
|
||||
[
|
||||
"id" => $folder->id,
|
||||
"user_id" => $user->id,
|
||||
"parent_id" => null,
|
||||
"name" => "root",
|
||||
"color" => null,
|
||||
"emoji" => null,
|
||||
"user_scope" => "master",
|
||||
"deleted_at" => $folder->deleted_at,
|
||||
"created_at" => $folder->created_at,
|
||||
"updated_at" => $folder->updated_at->toJson(),
|
||||
"items" => 0,
|
||||
"trashed_items" => 1,
|
||||
"type" => "folder",
|
||||
"parent" => null,
|
||||
],
|
||||
[
|
||||
"id" => $file->id,
|
||||
"user_id" => $user->id,
|
||||
"folder_id" => null,
|
||||
"thumbnail" => null,
|
||||
"name" => "Document",
|
||||
"basename" => "document.pdf",
|
||||
"mimetype" => "application/pdf",
|
||||
"filesize" => $file->filesize,
|
||||
"type" => "file",
|
||||
"metadata" => null,
|
||||
"user_scope" => "master",
|
||||
"deleted_at" => $file->deleted_at,
|
||||
"created_at" => $file->created_at,
|
||||
"updated_at" => $file->updated_at->toJson(),
|
||||
"file_url" => "http://localhost/file/document.pdf",
|
||||
"parent" => null
|
||||
],
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
public function it_get_searched_file()
|
||||
{
|
||||
|
||||
@@ -307,18 +396,8 @@ class BrowseTest extends TestCase
|
||||
|
||||
}
|
||||
|
||||
public function it_get_trash()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function it_get_shared_files()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function it_get_participant_uploads()
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user