mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-05-27 23:04:43 +00:00
Shared pages refactoring part 3
This commit is contained in:
@@ -24,7 +24,7 @@
|
|||||||
</span>
|
</span>
|
||||||
|
|
||||||
<!--Item icon-->
|
<!--Item icon-->
|
||||||
<hard-drive-icon v-if="nodes.location === 'files'" size="17" class="icon vue-feather" :class="{ 'text-theme dark-text-theme': isSelectedItem }" />
|
<hard-drive-icon v-if="['public', 'files'].includes(nodes.location)" size="17" class="icon vue-feather" :class="{ 'text-theme dark-text-theme': isSelectedItem }" />
|
||||||
<users-icon v-if="nodes.location === 'team-folders'" size="17" class="icon vue-feather" :class="{ 'text-theme dark-text-theme': isSelectedItem }" />
|
<users-icon v-if="nodes.location === 'team-folders'" size="17" class="icon vue-feather" :class="{ 'text-theme dark-text-theme': isSelectedItem }" />
|
||||||
<user-plus-icon v-if="nodes.location === 'shared-with-me'" size="17" class="icon vue-feather" :class="{ 'text-theme dark-text-theme': isSelectedItem }" />
|
<user-plus-icon v-if="nodes.location === 'shared-with-me'" size="17" class="icon vue-feather" :class="{ 'text-theme dark-text-theme': isSelectedItem }" />
|
||||||
<folder-icon v-if="!nodes.location" size="17" class="icon vue-feather" :class="{ 'text-theme dark-text-theme': isSelectedItem }" />
|
<folder-icon v-if="!nodes.location" size="17" class="icon vue-feather" :class="{ 'text-theme dark-text-theme': isSelectedItem }" />
|
||||||
@@ -45,7 +45,6 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
//import TreeMenu from './TreeMenu'
|
|
||||||
import { FolderIcon, ChevronRightIcon, HardDriveIcon, UsersIcon, UserPlusIcon } from 'vue-feather-icons'
|
import { FolderIcon, ChevronRightIcon, HardDriveIcon, UsersIcon, UserPlusIcon } from 'vue-feather-icons'
|
||||||
import { events } from '../../bus'
|
import { events } from '../../bus'
|
||||||
import { mapGetters } from 'vuex'
|
import { mapGetters } from 'vuex'
|
||||||
|
|||||||
+2
-1
@@ -151,7 +151,7 @@ const FunctionHelpers = {
|
|||||||
|
|
||||||
Vue.prototype.$uploadFiles = async function (files) {
|
Vue.prototype.$uploadFiles = async function (files) {
|
||||||
// Show alert message when upload is disabled
|
// Show alert message when upload is disabled
|
||||||
if (!store.getters.user.data.meta.restrictions.canUpload) {
|
if (store.getters.user && !store.getters.user.data.meta.restrictions.canUpload) {
|
||||||
Vue.prototype.$temporarilyDisabledUpload()
|
Vue.prototype.$temporarilyDisabledUpload()
|
||||||
|
|
||||||
return
|
return
|
||||||
@@ -325,6 +325,7 @@ const FunctionHelpers = {
|
|||||||
|
|
||||||
Vue.prototype.$getDataByLocation = function () {
|
Vue.prototype.$getDataByLocation = function () {
|
||||||
let routes = {
|
let routes = {
|
||||||
|
Public: ['getSharedFolder', router.currentRoute.params.id || undefined],
|
||||||
Files: ['getFolder', router.currentRoute.params.id || undefined],
|
Files: ['getFolder', router.currentRoute.params.id || undefined],
|
||||||
RecentUploads: ['getRecentUploads'],
|
RecentUploads: ['getRecentUploads'],
|
||||||
MySharedItems: ['getMySharedItems'],
|
MySharedItems: ['getMySharedItems'],
|
||||||
|
|||||||
Vendored
+1
-1
@@ -25,7 +25,7 @@ const itemHelpers = {
|
|||||||
|
|
||||||
Vue.prototype.$createFolder = function () {
|
Vue.prototype.$createFolder = function () {
|
||||||
// Show alert message when create folder is disabled
|
// Show alert message when create folder is disabled
|
||||||
if (!store.getters.user.data.meta.restrictions.canCreateFolder) {
|
if (store.getters.user && !store.getters.user.data.meta.restrictions.canCreateFolder) {
|
||||||
Vue.prototype.$temporarilyDisabledFolderCreate()
|
Vue.prototype.$temporarilyDisabledFolderCreate()
|
||||||
|
|
||||||
return
|
return
|
||||||
|
|||||||
+8
-8
@@ -211,8 +211,6 @@ const actions = {
|
|||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
reject(error)
|
reject(error)
|
||||||
|
|
||||||
console.log(error)
|
|
||||||
|
|
||||||
let messages = {
|
let messages = {
|
||||||
423: {
|
423: {
|
||||||
title: i18n.t('popup_exceed_limit.title'),
|
title: i18n.t('popup_exceed_limit.title'),
|
||||||
@@ -227,15 +225,17 @@ const actions = {
|
|||||||
message: i18n.t('popup_paylod_error.message'),
|
message: i18n.t('popup_paylod_error.message'),
|
||||||
},
|
},
|
||||||
401: {
|
401: {
|
||||||
//title: error.response.data.message,
|
title: error.response.data.message,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
events.$emit('alert:open', {
|
if (messages[error.response.status]) {
|
||||||
emoji: '😬😬😬',
|
events.$emit('alert:open', {
|
||||||
title: messages[error.response.status]['title'],
|
emoji: '😬😬😬',
|
||||||
message: messages[error.response.status]['message'] || null,
|
title: messages[error.response.status]['title'] || null,
|
||||||
})
|
message: messages[error.response.status]['message'] || null,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
commit('PROCESSING_FILE', false)
|
commit('PROCESSING_FILE', false)
|
||||||
commit('CLEAR_UPLOAD_PROGRESS')
|
commit('CLEAR_UPLOAD_PROGRESS')
|
||||||
|
|||||||
@@ -10,7 +10,8 @@ class CreateNewUserAction extends Controller
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
protected AutoSubscribeForMeteredBillingAction $autoSubscribeForMeteredBilling,
|
protected AutoSubscribeForMeteredBillingAction $autoSubscribeForMeteredBilling,
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Validate and create a new user.
|
* Validate and create a new user.
|
||||||
|
|||||||
@@ -1,21 +1,21 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace Domain\Admin\Controllers\Users;
|
namespace Domain\Admin\Controllers\Users;
|
||||||
|
|
||||||
use App\Users\Actions\CreateNewUserAction;
|
|
||||||
use App\Users\DTO\CreateUserData;
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
use App\Users\DTO\CreateUserData;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use App\Users\Resources\UserResource;
|
use App\Users\Resources\UserResource;
|
||||||
use App\Users\Resources\UsersCollection;
|
use App\Users\Resources\UsersCollection;
|
||||||
|
use App\Users\Actions\CreateNewUserAction;
|
||||||
use Domain\Admin\Requests\CreateUserByAdmin;
|
use Domain\Admin\Requests\CreateUserByAdmin;
|
||||||
|
|
||||||
class UserController extends Controller
|
class UserController extends Controller
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
protected CreateNewUserAction $createNewUser,
|
protected CreateNewUserAction $createNewUser,
|
||||||
) {}
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all users
|
* Get all users
|
||||||
|
|||||||
@@ -5,10 +5,13 @@ use Illuminate\Http\Response;
|
|||||||
use Domain\Sharing\Models\Share;
|
use Domain\Sharing\Models\Share;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Domain\Files\Requests\UploadRequest;
|
use Domain\Files\Requests\UploadRequest;
|
||||||
|
use Domain\Files\Resources\FileResource;
|
||||||
use Domain\Files\Actions\UploadFileAction;
|
use Domain\Files\Actions\UploadFileAction;
|
||||||
use Support\Demo\Actions\FakeUploadFileAction;
|
use Support\Demo\Actions\FakeUploadFileAction;
|
||||||
|
use App\Users\Exceptions\InvalidUserActionException;
|
||||||
use Domain\Sharing\Actions\ProtectShareRecordAction;
|
use Domain\Sharing\Actions\ProtectShareRecordAction;
|
||||||
use Domain\Sharing\Actions\VerifyAccessToItemAction;
|
use Domain\Sharing\Actions\VerifyAccessToItemAction;
|
||||||
|
use Illuminate\Contracts\Filesystem\FileNotFoundException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* guest user upload file into shared folder
|
* guest user upload file into shared folder
|
||||||
@@ -23,6 +26,9 @@ class VisitorUploadFileController extends Controller
|
|||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws FileNotFoundException
|
||||||
|
*/
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
UploadRequest $request,
|
UploadRequest $request,
|
||||||
Share $shared,
|
Share $shared,
|
||||||
@@ -42,12 +48,19 @@ class VisitorUploadFileController extends Controller
|
|||||||
// Check access to requested directory
|
// Check access to requested directory
|
||||||
($this->verifyAccessToItem)($request->input('parent_id'), $shared);
|
($this->verifyAccessToItem)($request->input('parent_id'), $shared);
|
||||||
|
|
||||||
// Return new uploaded file
|
try {
|
||||||
$new_file = ($this->uploadFile)($request, $shared);
|
// Return new uploaded file
|
||||||
|
$file = ($this->uploadFile)($request, $shared);
|
||||||
|
|
||||||
// Set public access url
|
// Set public access url
|
||||||
$new_file->setPublicUrl($shared->token);
|
$file->setPublicUrl($shared->token);
|
||||||
|
|
||||||
return response($new_file, 201);
|
return response(new FileResource($file), 201);
|
||||||
|
} catch (InvalidUserActionException $e) {
|
||||||
|
return response([
|
||||||
|
'type' => 'error',
|
||||||
|
'message' => $e->getMessage(),
|
||||||
|
], 401);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Files\Resources;
|
namespace Domain\Files\Resources;
|
||||||
|
|
||||||
use Carbon\Carbon;
|
|
||||||
use ByteUnits\Metric;
|
use ByteUnits\Metric;
|
||||||
use Domain\Sharing\Resources\ShareResource;
|
use Domain\Sharing\Resources\ShareResource;
|
||||||
use Illuminate\Http\Resources\Json\JsonResource;
|
use Illuminate\Http\Resources\Json\JsonResource;
|
||||||
@@ -25,14 +24,14 @@ class FileResource extends JsonResource
|
|||||||
'id' => $this->id,
|
'id' => $this->id,
|
||||||
'type' => $this->type,
|
'type' => $this->type,
|
||||||
'attributes' => [
|
'attributes' => [
|
||||||
'filesize' => $fileSize,
|
'filesize' => $fileSize,
|
||||||
'name' => $this->name,
|
'name' => $this->name,
|
||||||
'basename' => $this->basename,
|
'basename' => $this->basename,
|
||||||
'mimetype' => $this->mimetype,
|
'mimetype' => $this->mimetype,
|
||||||
'file_url' => $this->file_url,
|
'file_url' => $this->file_url,
|
||||||
'thumbnail' => $this->thumbnail,
|
'thumbnail' => $this->thumbnail,
|
||||||
'metadata' => $this->metadata,
|
'metadata' => $this->metadata,
|
||||||
'parent_id' => $this->parent_id,
|
'parent_id' => $this->parent_id,
|
||||||
'created_at' => set_time_by_user_timezone($this->owner, $this->created_at),
|
'created_at' => set_time_by_user_timezone($this->owner, $this->created_at),
|
||||||
'updated_at' => set_time_by_user_timezone($this->owner, $this->updated_at),
|
'updated_at' => set_time_by_user_timezone($this->owner, $this->updated_at),
|
||||||
'deleted_at' => $this->deleted_at
|
'deleted_at' => $this->deleted_at
|
||||||
|
|||||||
@@ -36,10 +36,11 @@ class VisitorNavigationFolderTreeController extends Controller
|
|||||||
|
|
||||||
return [
|
return [
|
||||||
[
|
[
|
||||||
'id' => $shared->item_id,
|
'name' => __t('home'),
|
||||||
'name' => __t('home'),
|
'location' => 'public',
|
||||||
'location' => 'public',
|
'folders' => $folders,
|
||||||
'folders' => $folders,
|
'isMovable' => true,
|
||||||
|
'isOpen' => true,
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Folders\Resources;
|
namespace Domain\Folders\Resources;
|
||||||
|
|
||||||
use Carbon\Carbon;
|
|
||||||
use Domain\Sharing\Resources\ShareResource;
|
use Domain\Sharing\Resources\ShareResource;
|
||||||
use Illuminate\Http\Resources\Json\JsonResource;
|
use Illuminate\Http\Resources\Json\JsonResource;
|
||||||
use Domain\Teams\Resources\TeamMembersCollection;
|
use Domain\Teams\Resources\TeamMembersCollection;
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Homepage\Controllers;
|
namespace Domain\Homepage\Controllers;
|
||||||
|
|
||||||
use Illuminate\Contracts\Foundation\Application;
|
|
||||||
use Illuminate\Contracts\View\Factory;
|
|
||||||
use Domain\Pages\Models\Page;
|
use Domain\Pages\Models\Page;
|
||||||
use Doctrine\DBAL\Driver\PDOException;
|
|
||||||
use Illuminate\Contracts\View\View;
|
use Illuminate\Contracts\View\View;
|
||||||
|
use Doctrine\DBAL\Driver\PDOException;
|
||||||
|
use Illuminate\Contracts\View\Factory;
|
||||||
|
use Illuminate\Contracts\Foundation\Application;
|
||||||
|
|
||||||
class IndexController
|
class IndexController
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -6,8 +6,8 @@ use Domain\Files\Resources\FileResource;
|
|||||||
use Domain\Folders\Resources\FolderResource;
|
use Domain\Folders\Resources\FolderResource;
|
||||||
use Domain\Items\Requests\RenameItemRequest;
|
use Domain\Items\Requests\RenameItemRequest;
|
||||||
use Domain\Items\Actions\RenameFileOrFolderAction;
|
use Domain\Items\Actions\RenameFileOrFolderAction;
|
||||||
use Domain\Folders\Actions\UpdateFolderPropertyAction;
|
|
||||||
use Illuminate\Auth\Access\AuthorizationException;
|
use Illuminate\Auth\Access\AuthorizationException;
|
||||||
|
use Domain\Folders\Actions\UpdateFolderPropertyAction;
|
||||||
use Support\Demo\Actions\FakeRenameFileOrFolderAction;
|
use Support\Demo\Actions\FakeRenameFileOrFolderAction;
|
||||||
|
|
||||||
class RenameFileOrFolderController extends Controller
|
class RenameFileOrFolderController extends Controller
|
||||||
@@ -41,7 +41,6 @@ class RenameFileOrFolderController extends Controller
|
|||||||
$item = ($this->renameFileOrFolder)($request, $id);
|
$item = ($this->renameFileOrFolder)($request, $id);
|
||||||
|
|
||||||
if ($request->input('type') === 'folder') {
|
if ($request->input('type') === 'folder') {
|
||||||
|
|
||||||
return new FolderResource($item);
|
return new FolderResource($item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -23,7 +23,6 @@ class SharePublicIndexController extends Controller
|
|||||||
public function __invoke(
|
public function __invoke(
|
||||||
Share $share,
|
Share $share,
|
||||||
): View | StreamedResponse | RedirectResponse {
|
): View | StreamedResponse | RedirectResponse {
|
||||||
|
|
||||||
// Check if user can see shared record
|
// Check if user can see shared record
|
||||||
if (! $share->user->canVisitShared()) {
|
if (! $share->user->canVisitShared()) {
|
||||||
return redirect('/temporary-unavailable');
|
return redirect('/temporary-unavailable');
|
||||||
@@ -38,7 +37,6 @@ class SharePublicIndexController extends Controller
|
|||||||
|
|
||||||
// Check if shared is image file and then show it
|
// Check if shared is image file and then show it
|
||||||
if ($share->type === 'file') {
|
if ($share->type === 'file') {
|
||||||
|
|
||||||
// Get file
|
// Get file
|
||||||
$file = File::whereUserId($share->user_id)
|
$file = File::whereUserId($share->user_id)
|
||||||
->where('type', 'image')
|
->where('type', 'image')
|
||||||
|
|||||||
Reference in New Issue
Block a user