mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-05-13 08:45:01 +00:00
get and browse team folders shared with me
This commit is contained in:
@@ -110,5 +110,30 @@
|
|||||||
"/chunks/shared/authenticate.f99485cf74326346a8b1.hot-update.js": "/chunks/shared/authenticate.f99485cf74326346a8b1.hot-update.js",
|
"/chunks/shared/authenticate.f99485cf74326346a8b1.hot-update.js": "/chunks/shared/authenticate.f99485cf74326346a8b1.hot-update.js",
|
||||||
"/chunks/shared.56ccba53201e5195af28.hot-update.js": "/chunks/shared.56ccba53201e5195af28.hot-update.js",
|
"/chunks/shared.56ccba53201e5195af28.hot-update.js": "/chunks/shared.56ccba53201e5195af28.hot-update.js",
|
||||||
"/chunks/shared.4d20e6443aee96d57755.hot-update.js": "/chunks/shared.4d20e6443aee96d57755.hot-update.js",
|
"/chunks/shared.4d20e6443aee96d57755.hot-update.js": "/chunks/shared.4d20e6443aee96d57755.hot-update.js",
|
||||||
"/chunks/shared.231c37d4d932d493e5ba.hot-update.js": "/chunks/shared.231c37d4d932d493e5ba.hot-update.js"
|
"/chunks/shared.231c37d4d932d493e5ba.hot-update.js": "/chunks/shared.231c37d4d932d493e5ba.hot-update.js",
|
||||||
|
"/js/main.88844afbc713230b2ac6.hot-update.js": "/js/main.88844afbc713230b2ac6.hot-update.js",
|
||||||
|
"/js/main.f20ab3eb1934b88b78bf.hot-update.js": "/js/main.f20ab3eb1934b88b78bf.hot-update.js",
|
||||||
|
"/chunks/admin~chunks/app-language~chunks/dashboard~chunks/files~chunks/invoices~chunks/my-shared-item~9b68162c.js": "/chunks/admin~chunks/app-language~chunks/dashboard~chunks/files~chunks/invoices~chunks/my-shared-item~9b68162c.js?id=556460202edd9a6086fe",
|
||||||
|
"/chunks/admin~chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/settin~673d1ac3.js": "/chunks/admin~chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/settin~673d1ac3.js?id=c01cde1da36dcd859bed",
|
||||||
|
"/chunks/admin~chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/settin~97130d1f.js": "/chunks/admin~chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/settin~97130d1f.js?id=23023a327ee0b32a7f1f",
|
||||||
|
"/chunks/admin~chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/shared~1bec6fe4.js": "/chunks/admin~chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/shared~1bec6fe4.js?id=2483e956635c6b940795",
|
||||||
|
"/chunks/app-language~chunks/dashboard~chunks/files~chunks/invoices~chunks/my-shared-items~chunks/page~7dbb6a42.js": "/chunks/app-language~chunks/dashboard~chunks/files~chunks/invoices~chunks/my-shared-items~chunks/page~7dbb6a42.js?id=edf36a5ddf8f6705f7e4",
|
||||||
|
"/chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/shared-with-me~chun~fd99312c.js": "/chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/shared-with-me~chun~fd99312c.js?id=42944aee3313456a7e1c",
|
||||||
|
"/chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/shared~chunks/share~c7960950.js": "/chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunks/shared~chunks/share~c7960950.js?id=373ceb601d388f0872d3",
|
||||||
|
"/chunks/files~chunks/my-shared-items~chunks/recent-uploads~chunks/settings-subscription~chunks/shared~f3cd1a63.js": "/chunks/files~chunks/my-shared-items~chunks/recent-uploads~chunks/settings-subscription~chunks/shared~f3cd1a63.js?id=93200e8f38e44f4b59f0",
|
||||||
|
"/chunks/files~chunks/my-shared-items~chunks/recent-uploads~chunks/shared-with-me~chunks/shared/files~~34b5eb22.js": "/chunks/files~chunks/my-shared-items~chunks/recent-uploads~chunks/shared-with-me~chunks/shared/files~~34b5eb22.js?id=eb119943f935f9ec4c66",
|
||||||
|
"/chunks/files~chunks/my-shared-items~chunks/recent-uploads~chunks/shared-with-me~chunks/shared/files~~bf3ddedc.js": "/chunks/files~chunks/my-shared-items~chunks/recent-uploads~chunks/shared-with-me~chunks/shared/files~~bf3ddedc.js?id=d764385b104ca8009e36",
|
||||||
|
"/chunks/files~chunks/shared-with-me~chunks/shared/files~chunks/team-folders.js": "/chunks/files~chunks/shared-with-me~chunks/shared/files~chunks/team-folders.js?id=fbf0381594bdcd60f933",
|
||||||
|
"/chunks/shared-with-me.js": "/chunks/shared-with-me.js?id=8e2cbd8ee04cc259c3ef",
|
||||||
|
"/vendors~chunks/admin~chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunk~40ccbae3.js": "/vendors~chunks/admin~chunks/files~chunks/my-shared-items~chunks/platform~chunks/recent-uploads~chunk~40ccbae3.js?id=37ce1e1ab9968c100712",
|
||||||
|
"/js/main.9d081c43dda89cccca63.hot-update.js": "/js/main.9d081c43dda89cccca63.hot-update.js",
|
||||||
|
"/chunks/shared-with-me.9d081c43dda89cccca63.hot-update.js": "/chunks/shared-with-me.9d081c43dda89cccca63.hot-update.js",
|
||||||
|
"/js/main.15713ba41c25f6bd5f72.hot-update.js": "/js/main.15713ba41c25f6bd5f72.hot-update.js",
|
||||||
|
"/chunks/shared-with-me.15713ba41c25f6bd5f72.hot-update.js": "/chunks/shared-with-me.15713ba41c25f6bd5f72.hot-update.js",
|
||||||
|
"/js/main.028cd308790f8e3e1d76.hot-update.js": "/js/main.028cd308790f8e3e1d76.hot-update.js",
|
||||||
|
"/chunks/shared-with-me.48ff296470c6c8d9c8e1.hot-update.js": "/chunks/shared-with-me.48ff296470c6c8d9c8e1.hot-update.js",
|
||||||
|
"/chunks/shared-with-me.45f55a938be68c52688f.hot-update.js": "/chunks/shared-with-me.45f55a938be68c52688f.hot-update.js",
|
||||||
|
"/chunks/shared-with-me.6eea1ed760d886c08ef8.hot-update.js": "/chunks/shared-with-me.6eea1ed760d886c08ef8.hot-update.js",
|
||||||
|
"/js/main.b938f61eef37f98d19fe.hot-update.js": "/js/main.b938f61eef37f98d19fe.hot-update.js",
|
||||||
|
"/js/main.a9db17282c61afba01bd.hot-update.js": "/js/main.a9db17282c61afba01bd.hot-update.js"
|
||||||
}
|
}
|
||||||
|
|||||||
+2
@@ -212,6 +212,7 @@ const FunctionHelpers = {
|
|||||||
'Public': this.$t('Files'),
|
'Public': this.$t('Files'),
|
||||||
'Files': this.$t('Files'),
|
'Files': this.$t('Files'),
|
||||||
'TeamFolders': this.$t('Team Folders'),
|
'TeamFolders': this.$t('Team Folders'),
|
||||||
|
'SharedWithMe': this.$t('Shared With Me'),
|
||||||
}[this.$route.name]
|
}[this.$route.name]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -221,6 +222,7 @@ const FunctionHelpers = {
|
|||||||
let locations = {
|
let locations = {
|
||||||
'Public': {name: 'Public', params: {token: this.$route.params.token, id: id}},
|
'Public': {name: 'Public', params: {token: this.$route.params.token, id: id}},
|
||||||
'TeamFolders': {name: 'TeamFolders', params: {id: id}},
|
'TeamFolders': {name: 'TeamFolders', params: {id: id}},
|
||||||
|
'SharedWithMe': {name: 'SharedWithMe', params: {id: id}},
|
||||||
'MySharedItems': {name: 'Files', params: {id: id}},
|
'MySharedItems': {name: 'Files', params: {id: id}},
|
||||||
'Trash': {name: 'Trash', params: {id: id}},
|
'Trash': {name: 'Trash', params: {id: id}},
|
||||||
'Files': {name: 'Files', params: {id: id}},
|
'Files': {name: 'Files', params: {id: id}},
|
||||||
|
|||||||
Vendored
+1
-1
@@ -54,7 +54,7 @@ const routesFile = [
|
|||||||
name: 'SharedWithMe',
|
name: 'SharedWithMe',
|
||||||
path: '/platform/shared-with-me/:id?',
|
path: '/platform/shared-with-me/:id?',
|
||||||
component: () =>
|
component: () =>
|
||||||
import(/* webpackChunkName: "chunks/shared-with-me" */ '../views/FileView/Trash'),
|
import(/* webpackChunkName: "chunks/shared-with-me" */ '../views/FileView/SharedWithMe'),
|
||||||
meta: {
|
meta: {
|
||||||
requiresAuth: true
|
requiresAuth: true
|
||||||
},
|
},
|
||||||
|
|||||||
Vendored
+40
@@ -48,6 +48,46 @@ const actions = {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
getSharedWithMeFolder: ({commit, getters}, id) => {
|
||||||
|
commit('LOADING_STATE', {loading: true, data: []})
|
||||||
|
|
||||||
|
if (typeof id === 'undefined') {
|
||||||
|
commit('SET_CURRENT_TEAM_FOLDER', null)
|
||||||
|
}
|
||||||
|
|
||||||
|
axios
|
||||||
|
.get(`${getters.api}/teams/shared-with-me/${id}/${getters.sorting.URI}`)
|
||||||
|
.then(response => {
|
||||||
|
let folders = response.data.folders.data
|
||||||
|
let files = response.data.files.data
|
||||||
|
|
||||||
|
commit('LOADING_STATE', {loading: false, data: folders.concat(files)})
|
||||||
|
commit('SET_CURRENT_FOLDER', response.data.root)
|
||||||
|
|
||||||
|
if (! getters.currentTeamFolder || getters.currentTeamFolder.data.id !== response.data.teamFolder.data.id) {
|
||||||
|
commit('SET_CURRENT_TEAM_FOLDER', response.data.teamFolder)
|
||||||
|
}
|
||||||
|
|
||||||
|
events.$emit('scrollTop')
|
||||||
|
})
|
||||||
|
.catch(error => {
|
||||||
|
|
||||||
|
// Redirect if unauthenticated
|
||||||
|
if ([401, 403].includes(error.response.status)) {
|
||||||
|
|
||||||
|
commit('SET_AUTHORIZED', false)
|
||||||
|
router.push({name: 'SignIn'})
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
// Show error message
|
||||||
|
events.$emit('alert:open', {
|
||||||
|
title: i18n.t('popup_error.title'),
|
||||||
|
message: i18n.t('popup_error.message'),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
const mutations = {
|
const mutations = {
|
||||||
|
|||||||
@@ -0,0 +1,234 @@
|
|||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<MobileContextMenu>
|
||||||
|
<OptionGroup v-if="item && isFolder">
|
||||||
|
<Option @click.native="addToFavourites" :title="isInFavourites ? $t('context_menu.remove_from_favourites') : $t('context_menu.add_to_favourites')" icon="favourites" />
|
||||||
|
</OptionGroup>
|
||||||
|
|
||||||
|
<OptionGroup v-if="item">
|
||||||
|
<Option @click.native="$renameFileOrFolder(item)" :title="$t('context_menu.rename')" icon="rename" />
|
||||||
|
<Option @click.native="$moveFileOrFolder(item)" :title="$t('context_menu.move')" icon="move-item" />
|
||||||
|
<Option @click.native="$deleteFileOrFolder(item)" :title="$t('context_menu.delete')" icon="trash" />
|
||||||
|
</OptionGroup>
|
||||||
|
<OptionGroup v-if="item">
|
||||||
|
<Option @click.native="$shareFileOrFolder(item)" :title="item.data.relationships.shared ? $t('context_menu.share_edit') : $t('context_menu.share')" icon="share" />
|
||||||
|
<Option @click.native="$updateTeamFolder(item)" v-if="isFolder" :title="$t('Convert as Team Folder')" icon="users" />
|
||||||
|
</OptionGroup>
|
||||||
|
|
||||||
|
<OptionGroup v-if="item">
|
||||||
|
<Option @click.native="$downloadSelection(item)" :title="$t('context_menu.download')" icon="download" />
|
||||||
|
</OptionGroup>
|
||||||
|
</MobileContextMenu>
|
||||||
|
|
||||||
|
<MobileCreateMenu>
|
||||||
|
<OptionGroup>
|
||||||
|
<OptionUpload :title="$t('actions.upload')" is-hover-disabled="true" />
|
||||||
|
</OptionGroup>
|
||||||
|
<OptionGroup>
|
||||||
|
<Option @click.stop.native="$createTeamFolder" :title="$t('Create Team Folder')" icon="users" is-hover-disabled="true" />
|
||||||
|
<Option @click.stop.native="createFolder" :title="$t('actions.create_folder')" icon="folder-plus" is-hover-disabled="true" />
|
||||||
|
</OptionGroup>
|
||||||
|
</MobileCreateMenu>
|
||||||
|
|
||||||
|
<MobileMultiSelectToolbar>
|
||||||
|
<ToolbarButton @click.native="$moveFileOrFolder(clipboard)" class="action-btn" source="move" :action="$t('actions.move')" :class="{'is-inactive' : clipboard.length < 1}" />
|
||||||
|
<ToolbarButton @click.native="$deleteFileOrFolder(clipboard)" class="action-btn" source="trash" :class="{'is-inactive' : clipboard.length < 1}" :action="$t('actions.delete')" />
|
||||||
|
<ToolbarButton @click.native="$downloadSelection(item)" class="action-btn" source="download" :action="$t('actions.download')" />
|
||||||
|
</MobileMultiSelectToolbar>
|
||||||
|
|
||||||
|
<ContextMenu>
|
||||||
|
<template v-slot:empty-select>
|
||||||
|
<OptionGroup v-if="! isTeamFolderHomepage">
|
||||||
|
<OptionUpload :title="$t('actions.upload')" />
|
||||||
|
<Option @click.stop.native="$createFolder" :title="$t('actions.create_folder')" icon="folder-plus" />
|
||||||
|
</OptionGroup>
|
||||||
|
<OptionGroup v-if="isTeamFolderHomepage">
|
||||||
|
<Option @click.native="$createTeamFolder" :title="$t('Create Team Folder')" icon="users" />
|
||||||
|
</OptionGroup>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<template v-slot:single-select v-if="item">
|
||||||
|
<OptionGroup v-if="isFolder">
|
||||||
|
<Option @click.native="addToFavourites" :title="isInFavourites ? $t('context_menu.remove_from_favourites') : $t('context_menu.add_to_favourites')" icon="favourites" />
|
||||||
|
</OptionGroup>
|
||||||
|
<OptionGroup>
|
||||||
|
<Option @click.native="$renameFileOrFolder(item)" :title="$t('context_menu.rename')" icon="rename" />
|
||||||
|
<Option @click.native="$moveFileOrFolder(item)" :title="$t('context_menu.move')" icon="move-item" />
|
||||||
|
<Option @click.native="$deleteFileOrFolder(item)" :title="$t('context_menu.delete')" icon="trash" />
|
||||||
|
</OptionGroup>
|
||||||
|
<OptionGroup>
|
||||||
|
<Option @click.native="$shareFileOrFolder(item)" :title="item.data.relationships.shared ? $t('context_menu.share_edit') : $t('context_menu.share')" icon="share" />
|
||||||
|
<Option @click.native="$updateTeamFolder(item)" v-if="isFolder" :title="$t('Edit Team Members')" icon="users" />
|
||||||
|
</OptionGroup>
|
||||||
|
<OptionGroup>
|
||||||
|
<Option @click.native="$openInDetailPanel(item)" :title="$t('context_menu.detail')" icon="detail" />
|
||||||
|
<Option @click.native="$downloadSelection(item)" :title="$t('context_menu.download')" icon="download" />
|
||||||
|
</OptionGroup>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<template v-slot:multiple-select v-if="item">
|
||||||
|
<OptionGroup v-if="!hasFile">
|
||||||
|
<Option @click.native="addToFavourites" :title="isInFavourites ? $t('context_menu.remove_from_favourites') : $t('context_menu.add_to_favourites')" icon="favourites" />
|
||||||
|
</OptionGroup>
|
||||||
|
<OptionGroup>
|
||||||
|
<Option @click.native="$moveFileOrFolder(item)" :title="$t('context_menu.move')" icon="move-item" />
|
||||||
|
<Option @click.native="$deleteFileOrFolder(item)" :title="$t('context_menu.delete')" icon="trash" />
|
||||||
|
</OptionGroup>
|
||||||
|
<OptionGroup>
|
||||||
|
<Option @click.native="$downloadSelection(item)" :title="$t('context_menu.download')" icon="download" />
|
||||||
|
</OptionGroup>
|
||||||
|
</template>
|
||||||
|
</ContextMenu>
|
||||||
|
|
||||||
|
<FileBrowser>
|
||||||
|
<template v-slot:file-actions-mobile>
|
||||||
|
<MobileActionButton @click.native="$openSpotlight" icon="search">
|
||||||
|
{{ $t('actions.search') }}
|
||||||
|
</MobileActionButton>
|
||||||
|
<MobileActionButton @click.native="$showLocations" icon="filter">
|
||||||
|
{{ filterLocationTitle }}
|
||||||
|
</MobileActionButton>
|
||||||
|
<MobileActionButton @click.native="$createItems" v-if="$checkPermission(['master', 'editor'])" icon="cloud-plus">
|
||||||
|
{{ $t('mobile.create') }}
|
||||||
|
</MobileActionButton>
|
||||||
|
<MobileActionButton @click.native="$enableMultiSelectMode" icon="check-square">
|
||||||
|
{{ $t('context_menu.select') }}
|
||||||
|
</MobileActionButton>
|
||||||
|
<MobileActionButton @click.native="$showViewOptions" icon="preview-sorting">
|
||||||
|
{{ $t('preview_sorting.preview_sorting_button') }}
|
||||||
|
</MobileActionButton>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<template v-slot:empty-file-page>
|
||||||
|
|
||||||
|
<template v-if="isTeamFolderHomepage">
|
||||||
|
<h1 class="title">
|
||||||
|
{{ $t('Nothing shared with you') }}
|
||||||
|
</h1>
|
||||||
|
<p class="description">
|
||||||
|
{{ $t('All items that are shared with you will be visible here.') }}
|
||||||
|
</p>
|
||||||
|
<ButtonBase @click.native="$createTeamFolder" button-style="theme" class="m-center">
|
||||||
|
{{ $t('Create your Team Folder') }}
|
||||||
|
</ButtonBase>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<template v-if="! isTeamFolderHomepage">
|
||||||
|
<h1 class="title">
|
||||||
|
{{ $t('empty_page.title') }}
|
||||||
|
</h1>
|
||||||
|
<p class="description">
|
||||||
|
{{ $t('empty_page.description') }}
|
||||||
|
</p>
|
||||||
|
<ButtonUpload button-style="theme">
|
||||||
|
{{ $t('empty_page.call_to_action') }}
|
||||||
|
</ButtonUpload>
|
||||||
|
</template>
|
||||||
|
</template>
|
||||||
|
</FileBrowser>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import MobileActionButtonUpload from '/resources/js/components/FilesView/MobileActionButtonUpload'
|
||||||
|
import MobileMultiSelectToolbar from "/resources/js/components/FilesView/MobileMultiSelectToolbar"
|
||||||
|
import MobileActionButton from '/resources/js/components/FilesView/MobileActionButton'
|
||||||
|
import MobileContextMenu from "/resources/js/components/FilesView/MobileContextMenu"
|
||||||
|
import MobileCreateMenu from '/resources/js/components/FilesView/MobileCreateMenu'
|
||||||
|
import ButtonUpload from '/resources/js/components/FilesView/ButtonUpload'
|
||||||
|
import ToolbarButton from '/resources/js/components/FilesView/ToolbarButton'
|
||||||
|
import OptionUpload from '/resources/js/components/FilesView/OptionUpload'
|
||||||
|
import FileBrowser from '/resources/js/components/FilesView/FileBrowser'
|
||||||
|
import ContextMenu from '/resources/js/components/FilesView/ContextMenu'
|
||||||
|
import OptionGroup from '/resources/js/components/FilesView/OptionGroup'
|
||||||
|
import ButtonBase from '/resources/js/components/FilesView/ButtonBase'
|
||||||
|
import Option from '/resources/js/components/FilesView/Option'
|
||||||
|
import { mapGetters } from 'vuex'
|
||||||
|
import {events} from "../../bus";
|
||||||
|
import Vue from "vue";
|
||||||
|
import router from "../../router";
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: 'SharedWithMe',
|
||||||
|
components: {
|
||||||
|
MobileActionButtonUpload,
|
||||||
|
MobileMultiSelectToolbar,
|
||||||
|
MobileActionButton,
|
||||||
|
MobileContextMenu,
|
||||||
|
MobileCreateMenu,
|
||||||
|
ToolbarButton,
|
||||||
|
ButtonUpload,
|
||||||
|
OptionUpload,
|
||||||
|
OptionGroup,
|
||||||
|
FileBrowser,
|
||||||
|
ContextMenu,
|
||||||
|
ButtonBase,
|
||||||
|
Option,
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
...mapGetters([
|
||||||
|
'clipboard',
|
||||||
|
'config',
|
||||||
|
'user',
|
||||||
|
]),
|
||||||
|
isTeamFolderHomepage() {
|
||||||
|
return this.$isThisRoute(this.$route, ['SharedWithMe'])
|
||||||
|
&& ! this.$route.params.id
|
||||||
|
},
|
||||||
|
isFolder() {
|
||||||
|
return this.item && this.item.data.type === 'folder'
|
||||||
|
},
|
||||||
|
isInFavourites() {
|
||||||
|
return this.favourites.find((el) => el.id === this.item.id)
|
||||||
|
},
|
||||||
|
hasFile() {
|
||||||
|
return this.clipboard.find(item => item.type !== 'folder')
|
||||||
|
},
|
||||||
|
favourites() {
|
||||||
|
return this.user.data.relationships.favourites.data
|
||||||
|
},
|
||||||
|
filterLocationTitle() {
|
||||||
|
return {
|
||||||
|
'RecentUploads': this.$t('Recent'),
|
||||||
|
'MySharedItems': this.$t('Shared'),
|
||||||
|
'Trash': this.$t('Trash'),
|
||||||
|
'Public': this.$t('Files'),
|
||||||
|
'Files': this.$t('Files'),
|
||||||
|
}[this.$route.name]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
item: undefined,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
addToFavourites() {
|
||||||
|
// Check if folder is in favourites and then add/remove from favourites
|
||||||
|
if (this.favourites && !this.favourites.find(el => el.id === this.item.data.id)) {
|
||||||
|
// Add to favourite folder that is not selected
|
||||||
|
if (!this.clipboard.includes(this.item)) {
|
||||||
|
this.$store.dispatch('addToFavourites', this.item)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add to favourites all selected folders
|
||||||
|
if (this.clipboard.includes(this.item)) {
|
||||||
|
this.$store.dispatch('addToFavourites', null)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this.$store.dispatch('removeFromFavourites', this.item)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
createFolder() {
|
||||||
|
events.$emit('popup:open', {name: 'create-folder'})
|
||||||
|
},
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.$store.dispatch('getSharedWithMeFolder', this.$route.params.id)
|
||||||
|
|
||||||
|
events.$on('context-menu:show', (event, item) => this.item = item)
|
||||||
|
events.$on('mobile-context-menu:show', item => this.item = item)
|
||||||
|
events.$on('context-menu:current-folder', folder => this.item = folder)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace App\Console\Commands;
|
namespace App\Console\Commands;
|
||||||
|
|
||||||
use App\Users\Models\User;
|
use App\Users\Models\User;
|
||||||
@@ -34,10 +35,11 @@ class SetupDevEnvironment extends Command
|
|||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private CreateDiskDirectoriesAction $createDiskDirectories,
|
private CreateDiskDirectoriesAction $createDiskDirectories,
|
||||||
private SeedDefaultSettingsAction $seedDefaultSettings,
|
private SeedDefaultSettingsAction $seedDefaultSettings,
|
||||||
private SeedDefaultLanguageAction $seedDefaultLanguage,
|
private SeedDefaultLanguageAction $seedDefaultLanguage,
|
||||||
private SeedDefaultPagesAction $seedDefaultPages,
|
private SeedDefaultPagesAction $seedDefaultPages,
|
||||||
) {
|
)
|
||||||
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
$this->setUpFaker();
|
$this->setUpFaker();
|
||||||
}
|
}
|
||||||
@@ -71,6 +73,7 @@ class SetupDevEnvironment extends Command
|
|||||||
$this->info('Creating default demo content...');
|
$this->info('Creating default demo content...');
|
||||||
$this->create_admin_default_content();
|
$this->create_admin_default_content();
|
||||||
$this->create_team_folders_content();
|
$this->create_team_folders_content();
|
||||||
|
$this->create_share_with_me_team_folders_content();
|
||||||
$this->create_share_records();
|
$this->create_share_records();
|
||||||
|
|
||||||
$this->info('Clearing application cache...');
|
$this->info('Clearing application cache...');
|
||||||
@@ -125,26 +128,32 @@ class SetupDevEnvironment extends Command
|
|||||||
collect([
|
collect([
|
||||||
[
|
[
|
||||||
'avatar' => 'avatar-02.png',
|
'avatar' => 'avatar-02.png',
|
||||||
|
'email' => 'alice@vuefilemanager.com',
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'avatar' => 'avatar-03.png',
|
'avatar' => 'avatar-03.png',
|
||||||
|
'email' => $this->faker->email,
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'avatar' => 'avatar-04.png',
|
'avatar' => 'avatar-04.png',
|
||||||
|
'email' => $this->faker->email,
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'avatar' => 'avatar-05.png',
|
'avatar' => 'avatar-05.png',
|
||||||
|
'email' => $this->faker->email,
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'avatar' => 'avatar-06.png',
|
'avatar' => 'avatar-06.png',
|
||||||
|
'email' => $this->faker->email,
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'avatar' => 'avatar-07.png',
|
'avatar' => 'avatar-07.png',
|
||||||
|
'email' => $this->faker->email,
|
||||||
],
|
],
|
||||||
])->each(function ($user) {
|
])->each(function ($user) {
|
||||||
$newbie = User::forceCreate([
|
$newbie = User::forceCreate([
|
||||||
'role' => 'user',
|
'role' => 'user',
|
||||||
'email' => $this->faker->email,
|
'email' => $user['email'],
|
||||||
'password' => bcrypt('vuefilemanager'),
|
'password' => bcrypt('vuefilemanager'),
|
||||||
'email_verified_at' => now(),
|
'email_verified_at' => now(),
|
||||||
]);
|
]);
|
||||||
@@ -756,7 +765,7 @@ class SetupDevEnvironment extends Command
|
|||||||
|
|
||||||
collect([$members[0]->id, $members[1]->id])
|
collect([$members[0]->id, $members[1]->id])
|
||||||
->each(
|
->each(
|
||||||
fn ($id) => DB::table('team_folder_members')
|
fn($id) => DB::table('team_folder_members')
|
||||||
->insert([
|
->insert([
|
||||||
'parent_id' => $companyProjectFolder->id,
|
'parent_id' => $companyProjectFolder->id,
|
||||||
'user_id' => $id,
|
'user_id' => $id,
|
||||||
@@ -766,7 +775,7 @@ class SetupDevEnvironment extends Command
|
|||||||
|
|
||||||
collect([$members[2]->id, $members[3]->id])
|
collect([$members[2]->id, $members[3]->id])
|
||||||
->each(
|
->each(
|
||||||
fn ($id) => DB::table('team_folder_members')
|
fn($id) => DB::table('team_folder_members')
|
||||||
->insert([
|
->insert([
|
||||||
'parent_id' => $financeDocumentsFolder->id,
|
'parent_id' => $financeDocumentsFolder->id,
|
||||||
'user_id' => $id,
|
'user_id' => $id,
|
||||||
@@ -777,7 +786,7 @@ class SetupDevEnvironment extends Command
|
|||||||
// Create invitations
|
// Create invitations
|
||||||
collect([$members[4], $members[5]])
|
collect([$members[4], $members[5]])
|
||||||
->each(
|
->each(
|
||||||
fn ($user) => TeamFolderInvitation::factory()
|
fn($user) => TeamFolderInvitation::factory()
|
||||||
->create([
|
->create([
|
||||||
'email' => $user->email,
|
'email' => $user->email,
|
||||||
'parent_id' => $companyProjectFolder->id,
|
'parent_id' => $companyProjectFolder->id,
|
||||||
@@ -787,6 +796,96 @@ class SetupDevEnvironment extends Command
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function create_share_with_me_team_folders_content(): void
|
||||||
|
{
|
||||||
|
$member = User::whereEmail('howdy@hi5ve.digital')
|
||||||
|
->first();
|
||||||
|
|
||||||
|
$owner = User::whereEmail('alice@vuefilemanager.com')
|
||||||
|
->first();
|
||||||
|
|
||||||
|
$folder = Folder::factory()
|
||||||
|
->create([
|
||||||
|
'user_id' => $owner->id,
|
||||||
|
'team_folder' => true,
|
||||||
|
'name' => "Alice's Project Files",
|
||||||
|
]);
|
||||||
|
|
||||||
|
$memes = Folder::factory()
|
||||||
|
->create([
|
||||||
|
'user_id' => $owner->id,
|
||||||
|
'parent_id' => $folder->id,
|
||||||
|
'name' => '9 Gag',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$hug = Folder::factory()
|
||||||
|
->create([
|
||||||
|
'user_id' => $owner->id,
|
||||||
|
'parent_id' => $folder->id,
|
||||||
|
'name' => 'Digital Hug',
|
||||||
|
]);
|
||||||
|
|
||||||
|
DB::table('team_folder_members')
|
||||||
|
->insert([
|
||||||
|
'parent_id' => $folder->id,
|
||||||
|
'user_id' => $member->id,
|
||||||
|
'permission' => 'can-edit',
|
||||||
|
]);
|
||||||
|
|
||||||
|
// Get meme gallery
|
||||||
|
collect([
|
||||||
|
'Sofishticated.jpg',
|
||||||
|
'whaaaaat.jpg',
|
||||||
|
'You Are My Sunshine.jpg',
|
||||||
|
])
|
||||||
|
->each(function ($file) use ($owner, $memes) {
|
||||||
|
$basename = Str::random(12) . '-' . $file;
|
||||||
|
|
||||||
|
// Copy file into app storage
|
||||||
|
Storage::putFileAs("files/$owner->id", storage_path("demo/images/memes/$file"), $basename, 'private');
|
||||||
|
Storage::putFileAs("files/$owner->id", storage_path("demo/images/memes/thumbnail-$file"), "thumbnail-$basename", 'private');
|
||||||
|
|
||||||
|
// Create file record
|
||||||
|
File::create([
|
||||||
|
'parent_id' => $memes->id,
|
||||||
|
'user_id' => $owner->id,
|
||||||
|
'name' => $file,
|
||||||
|
'basename' => $basename,
|
||||||
|
'type' => 'image',
|
||||||
|
'author' => 'user',
|
||||||
|
'mimetype' => 'jpg',
|
||||||
|
'filesize' => rand(1000000, 4000000),
|
||||||
|
'thumbnail' => "thumbnail-$basename",
|
||||||
|
'created_at' => now()->subMinutes(rand(1, 5)),
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
collect([
|
||||||
|
'Eggcited bro.jpg',
|
||||||
|
'Get a Rest.jpg',
|
||||||
|
])
|
||||||
|
->each(function ($file) use ($owner, $hug) {
|
||||||
|
$basename = Str::random(12) . '-' . $file;
|
||||||
|
|
||||||
|
// Copy file into app storage
|
||||||
|
Storage::putFileAs("files/$owner->id", storage_path("demo/images/memes/$file"), $basename, 'private');
|
||||||
|
Storage::putFileAs("files/$owner->id", storage_path("demo/images/memes/thumbnail-$file"), "thumbnail-$basename", 'private');
|
||||||
|
|
||||||
|
// Create file record
|
||||||
|
File::create([
|
||||||
|
'parent_id' => $hug->id,
|
||||||
|
'user_id' => $owner->id,
|
||||||
|
'name' => $file,
|
||||||
|
'basename' => $basename,
|
||||||
|
'type' => 'image',
|
||||||
|
'author' => 'user',
|
||||||
|
'mimetype' => 'jpg',
|
||||||
|
'filesize' => rand(1000000, 4000000),
|
||||||
|
'thumbnail' => "thumbnail-$basename",
|
||||||
|
'created_at' => now()->subMinutes(rand(1, 5)),
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
private function create_share_records(): void
|
private function create_share_records(): void
|
||||||
{
|
{
|
||||||
$user = User::whereEmail('howdy@hi5ve.digital')
|
$user = User::whereEmail('howdy@hi5ve.digital')
|
||||||
|
|||||||
@@ -1,9 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Files\Controllers\FileAccess;
|
namespace Domain\Files\Controllers\FileAccess;
|
||||||
|
|
||||||
use Illuminate\Http\Request;
|
use Gate;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Auth;
|
|
||||||
use Domain\Files\Models\File as UserFile;
|
use Domain\Files\Models\File as UserFile;
|
||||||
use Domain\Files\Actions\DownloadFileAction;
|
use Domain\Files\Actions\DownloadFileAction;
|
||||||
use Domain\Traffic\Actions\RecordDownloadAction;
|
use Domain\Traffic\Actions\RecordDownloadAction;
|
||||||
@@ -14,28 +13,26 @@ class GetFileController extends Controller
|
|||||||
public function __construct(
|
public function __construct(
|
||||||
private RecordDownloadAction $recordDownload,
|
private RecordDownloadAction $recordDownload,
|
||||||
private DownloadFileAction $downloadFile,
|
private DownloadFileAction $downloadFile,
|
||||||
) {
|
) {}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get file
|
|
||||||
*/
|
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
Request $request,
|
|
||||||
string $filename,
|
string $filename,
|
||||||
): BinaryFileResponse {
|
): BinaryFileResponse {
|
||||||
// Get file record
|
|
||||||
$file = UserFile::withTrashed()
|
$file = UserFile::withTrashed()
|
||||||
->where('user_id', Auth::id())
|
|
||||||
->where('basename', $filename)
|
->where('basename', $filename)
|
||||||
->firstOrFail();
|
->firstOrFail();
|
||||||
|
|
||||||
|
if (! Gate::any(['can-edit', 'can-visit'], [$file, null])) {
|
||||||
|
abort(403, 'Access Denied');
|
||||||
|
}
|
||||||
|
|
||||||
// Store user download size
|
// Store user download size
|
||||||
($this->recordDownload)(
|
($this->recordDownload)(
|
||||||
file_size: (int) $file->getRawOriginal('filesize'),
|
file_size: (int) $file->getRawOriginal('filesize'),
|
||||||
user_id: Auth::id(),
|
user_id: $file->user_id,
|
||||||
);
|
);
|
||||||
|
|
||||||
return ($this->downloadFile)($file, Auth::id());
|
return ($this->downloadFile)($file, $file->user_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Domain\Files\Controllers\FileAccess;
|
namespace Domain\Files\Controllers\FileAccess;
|
||||||
|
|
||||||
|
use Gate;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use Illuminate\Support\Facades\Auth;
|
|
||||||
use Domain\Files\Models\File as UserFile;
|
use Domain\Files\Models\File as UserFile;
|
||||||
use Domain\Files\Actions\DownloadThumbnailAction;
|
use Domain\Files\Actions\DownloadThumbnailAction;
|
||||||
use Symfony\Component\HttpFoundation\StreamedResponse;
|
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||||
@@ -13,21 +13,21 @@ class GetThumbnailController extends Controller
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private DownloadThumbnailAction $downloadThumbnail,
|
private DownloadThumbnailAction $downloadThumbnail,
|
||||||
) {
|
) {}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get image thumbnail
|
|
||||||
*/
|
|
||||||
public function __invoke(
|
public function __invoke(
|
||||||
Request $request,
|
Request $request,
|
||||||
string $filename,
|
string $filename,
|
||||||
): FileNotFoundException | StreamedResponse {
|
): FileNotFoundException | StreamedResponse {
|
||||||
|
|
||||||
$file = UserFile::withTrashed()
|
$file = UserFile::withTrashed()
|
||||||
->whereUserId(Auth::id())
|
->where('thumbnail', $filename)
|
||||||
->whereThumbnail($filename)
|
|
||||||
->firstOrFail();
|
->firstOrFail();
|
||||||
|
|
||||||
return ($this->downloadThumbnail)($file, Auth::id());
|
if (! Gate::any(['can-edit', 'can-visit'], [$file, null])) {
|
||||||
|
abort(403, 'Access Denied');
|
||||||
|
}
|
||||||
|
|
||||||
|
return ($this->downloadThumbnail)($file, $file->user_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace Domain\Teams\Controllers;
|
namespace Domain\Teams\Controllers;
|
||||||
|
|
||||||
|
use Domain\Files\Resources\FilesCollection;
|
||||||
|
use Domain\Folders\Resources\FolderCollection;
|
||||||
|
use Domain\Folders\Resources\FolderResource;
|
||||||
use Str;
|
use Str;
|
||||||
use Domain\Files\Models\File;
|
use Domain\Files\Models\File;
|
||||||
use Domain\Folders\Models\Folder;
|
use Domain\Folders\Models\Folder;
|
||||||
@@ -11,43 +15,35 @@ class BrowseSharedWithMeController
|
|||||||
{
|
{
|
||||||
public function __invoke($id): array
|
public function __invoke($id): array
|
||||||
{
|
{
|
||||||
$rootId = Str::isUuid($id) ? $id : null;
|
$id = Str::isUuid($id) ? $id : null;
|
||||||
$requestedFolder = Str::isUuid($id) ? Folder::findOrFail($rootId) : null;
|
|
||||||
|
|
||||||
$relations = [
|
if ($id) {
|
||||||
'parent:id,name',
|
$folders = Folder::with(['parent:id,name'])
|
||||||
'shared:token,id,item_id,permission,is_protected,expire_in',
|
->where('parent_id', $id)
|
||||||
];
|
|
||||||
|
|
||||||
if ($rootId) {
|
|
||||||
$folders = Folder::with($relations)
|
|
||||||
->where('id', $id)
|
|
||||||
->sortable()
|
->sortable()
|
||||||
->get();
|
->get();
|
||||||
|
|
||||||
$files = File::with($relations)
|
$files = File::with(['parent:id,name'])
|
||||||
->where('parent_id', $id)
|
->where('parent_id', $id)
|
||||||
->sortable()
|
->sortable()
|
||||||
->get();
|
->get();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! $rootId) {
|
if (!$id) {
|
||||||
$folderIds = DB::table('team_folder_members')
|
$sharedFolderIds = DB::table('team_folder_members')
|
||||||
->where('user_id', Auth::id())
|
->where('user_id', Auth::id())
|
||||||
->pluck('parent_id');
|
->pluck('parent_id');
|
||||||
|
|
||||||
$folders = Folder::with($relations)
|
$folders = Folder::whereIn('id', $sharedFolderIds)
|
||||||
->whereIn('id', $folderIds)
|
|
||||||
->sortable()
|
->sortable()
|
||||||
->get();
|
->get();
|
||||||
|
|
||||||
$files = [];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Collect folders and files to single array
|
|
||||||
return [
|
return [
|
||||||
'content' => collect([$folders, $files])->collapse(),
|
'root' => $id ? new FolderResource(Folder::findOrFail($id)) : null,
|
||||||
'folder' => $requestedFolder,
|
'folders' => new FolderCollection($folders),
|
||||||
|
'files' => isset($files) ? new FilesCollection($files) : new FilesCollection([]),
|
||||||
|
'teamFolder' => $id ? new FolderResource(Folder::findOrFail($id)->getLatestParent()) : null,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -117,10 +117,9 @@ class ContentAccessTest extends TestCase
|
|||||||
'name' => 'fake-thumbnail.jpg',
|
'name' => 'fake-thumbnail.jpg',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
Sanctum::actingAs($users[1]);
|
$this->actingAs($users[1])
|
||||||
|
->get("thumbnail/$thumbnail->name")
|
||||||
$this->get("thumbnail/$thumbnail->name")
|
->assertForbidden();
|
||||||
->assertNotFound();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -144,10 +143,9 @@ class ContentAccessTest extends TestCase
|
|||||||
'name' => 'fake-file.pdf',
|
'name' => 'fake-file.pdf',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
Sanctum::actingAs($users[1]);
|
$this->actingAs($users[1])
|
||||||
|
->get("file/$file->name")
|
||||||
$this->get("file/$file->name")
|
->assertForbidden();
|
||||||
->assertStatus(404);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
Reference in New Issue
Block a user