mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-06 02:33:48 +00:00
164 lines
4.8 KiB
JavaScript
Vendored
164 lines
4.8 KiB
JavaScript
Vendored
import axios from 'axios'
|
|
import {events} from '@/bus'
|
|
import i18n from '@/i18n/index.js'
|
|
import router from '@/router'
|
|
|
|
const defaultState = {
|
|
authorized: undefined,
|
|
permission: 'master', // master | editor | visitor
|
|
user: undefined,
|
|
}
|
|
|
|
const actions = {
|
|
getAppData: ({commit, getters}) => {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
axios
|
|
.get(getters.api + '/user' + getters.sorting.URI)
|
|
.then((response) => {
|
|
resolve(response)
|
|
|
|
// Redirect user if is logged
|
|
if (router.currentRoute.name === 'SignIn')
|
|
router.push({ name: 'Files' })
|
|
|
|
commit('RETRIEVE_USER', response.data)
|
|
|
|
}).catch((error) => {
|
|
reject(error)
|
|
|
|
// Redirect if unauthenticated
|
|
if ([401, 403].includes(error.response.status)) {
|
|
|
|
commit('SET_AUTHORIZED', false)
|
|
//router.push({name: 'SignIn'})
|
|
}
|
|
}
|
|
)
|
|
})
|
|
},
|
|
logOut: ({getters, commit}) => {
|
|
axios
|
|
.get(getters.api + '/logout')
|
|
.then(() => {
|
|
|
|
// Commit Remove Access Token from vuex storage
|
|
commit('DESTROY_DATA')
|
|
|
|
router.push({name: 'SignIn'})
|
|
})
|
|
},
|
|
addToFavourites: (context, folder) => {
|
|
let addFavourites = []
|
|
let items = [folder]
|
|
|
|
if(!folder){
|
|
items = context.getters.fileInfoDetail
|
|
}
|
|
|
|
items.forEach((data) => {
|
|
if(data.type === 'folder' ) {
|
|
if(context.getters.user.relationships.favourites.data.attributes.folders.find(folder => folder.unique_id === data.unique_id)) return
|
|
addFavourites.push({
|
|
'unique_id': data.unique_id
|
|
})
|
|
}
|
|
})
|
|
|
|
if(!folder) {
|
|
context.commit('CLEAR_FILEINFO_DETAIL')
|
|
}
|
|
|
|
let pushToFavorites = []
|
|
|
|
//Check is favorites already don't include some of pushed folders
|
|
items.map(data => {
|
|
if(!context.getters.user.relationships.favourites.data.attributes.folders.find(folder => folder.unique_id === data.unique_id)){
|
|
pushToFavorites.push(data)
|
|
}
|
|
})
|
|
|
|
// Add to storage
|
|
context.commit('ADD_TO_FAVOURITES', pushToFavorites)
|
|
|
|
axios
|
|
.post(context.getters.api + '/folders/favourites', {
|
|
folders: addFavourites
|
|
})
|
|
.catch(() => {
|
|
// Show error message
|
|
events.$emit('alert:open', {
|
|
title: i18n.t('popup_error.title'),
|
|
message: i18n.t('popup_error.message'),
|
|
})
|
|
})
|
|
},
|
|
removeFromFavourites: (context, folder) => {
|
|
|
|
// Remove from storage
|
|
context.commit('REMOVE_ITEM_FROM_FAVOURITES', folder)
|
|
|
|
axios
|
|
.post(context.getters.api + '/folders/favourites/' + folder.unique_id, {
|
|
_method: 'delete'
|
|
})
|
|
.catch(() => {
|
|
// Show error message
|
|
events.$emit('alert:open', {
|
|
title: i18n.t('popup_error.title'),
|
|
message: i18n.t('popup_error.message'),
|
|
})
|
|
})
|
|
},
|
|
}
|
|
|
|
const mutations = {
|
|
RETRIEVE_USER(state, user) {
|
|
state.user = user
|
|
},
|
|
SET_PERMISSION(state, role) {
|
|
state.permission = role
|
|
},
|
|
DESTROY_DATA(state) {
|
|
state.authorized = false
|
|
state.app = undefined
|
|
},
|
|
ADD_TO_FAVOURITES(state, folder) {
|
|
folder.forEach(item => {
|
|
state.user.relationships.favourites.data.attributes.folders.push({
|
|
unique_id: item.unique_id,
|
|
name: item.name,
|
|
type: item.type,
|
|
})
|
|
})
|
|
},
|
|
UPDATE_NAME(state, name) {
|
|
state.user.data.attributes.name = name
|
|
},
|
|
UPDATE_AVATAR(state, avatar) {
|
|
state.user.data.attributes.avatar = avatar
|
|
},
|
|
REMOVE_ITEM_FROM_FAVOURITES(state, item) {
|
|
state.user.relationships.favourites.data.attributes.folders = state.user.relationships.favourites.data.attributes.folders.filter(folder => folder.unique_id !== item.unique_id)
|
|
},
|
|
UPDATE_NAME_IN_FAVOURITES(state, data) {
|
|
state.user.relationships.favourites.data.attributes.folders.find(folder => {
|
|
if (folder.unique_id == data.unique_id) folder.name = data.name
|
|
})
|
|
}
|
|
}
|
|
|
|
const getters = {
|
|
permission: state => state.permission,
|
|
isGuest: state => ! state.authorized,
|
|
isLogged: state => state.authorized,
|
|
user: state => state.user,
|
|
}
|
|
|
|
export default {
|
|
state: defaultState,
|
|
getters,
|
|
actions,
|
|
mutations
|
|
}
|