diff --git a/filemanager/src/models/DirectoryModel.js b/filemanager/src/models/DirectoryModel.js index 3e496ee30..e1505b79c 100644 --- a/filemanager/src/models/DirectoryModel.js +++ b/filemanager/src/models/DirectoryModel.js @@ -2,6 +2,8 @@ import superagent from 'superagent'; import { sanitize } from 'pankow/utils'; +const BASE_URL = import.meta.env.BASE_URL || '/'; + export function createDirectoryModel(origin, accessToken, api) { return { @@ -21,12 +23,23 @@ export function createDirectoryModel(origin, accessToken, api) { // this prepares the entries to be compatible with all components result.body.entries.forEach(item => { + item.id = item.fileName; + item.name = item.fileName; + item.folderPath = path; + item.modified = new Date(item.mtime); + item.type = item.isDirectory ? 'directory' : 'file', + item.icon = `${BASE_URL}mime-types/${item.mimeType === 'inode/symlink' ? 'none' : item.mimeType.split('/').join('-')}.svg`; + // if we have an image, attach previewUrl if (item.mimeType.indexOf('image/') === 0) { item.previewUrl = `${origin}/api/v1/${api}/files/${encodeURIComponent(path + '/' + item.fileName)}?access_token=${accessToken}`; } - item.folderPath = path; + item.owner = 'unkown'; + if (item.uid === 0) item.owner = 'root'; + if (item.uid === 33) item.owner = 'www-data'; + if (item.uid === 1000) item.owner = 'cloudron'; + if (item.uid === 1001) item.owner = 'git'; }); return result.body.entries; diff --git a/filemanager/src/views/Home.vue b/filemanager/src/views/Home.vue index 7653c8962..fc2a81d5b 100644 --- a/filemanager/src/views/Home.vue +++ b/filemanager/src/views/Home.vue @@ -44,6 +44,9 @@