diff options
author | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2025-04-22 16:28:31 +0200 |
---|---|---|
committer | nextcloud-command <nextcloud-command@users.noreply.github.com> | 2025-05-14 17:51:12 +0000 |
commit | a4ab5a3cdfba1e71b324b817544621eeb13b7140 (patch) | |
tree | 169346118aa25ea26700ae60e381c1bb77867795 /apps/files/src/components/FileEntry.vue | |
parent | 1b72ddd8c8aa187a6723a93575643a96f9191387 (diff) | |
download | nextcloud-server-a4ab5a3cdfba1e71b324b817544621eeb13b7140.tar.gz nextcloud-server-a4ab5a3cdfba1e71b324b817544621eeb13b7140.zip |
feat(files): allow showing file type (mime) column
Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
Diffstat (limited to 'apps/files/src/components/FileEntry.vue')
-rw-r--r-- | apps/files/src/components/FileEntry.vue | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/apps/files/src/components/FileEntry.vue b/apps/files/src/components/FileEntry.vue index 9642c4709d8..3e455a2f135 100644 --- a/apps/files/src/components/FileEntry.vue +++ b/apps/files/src/components/FileEntry.vue @@ -49,6 +49,15 @@ :opened.sync="openedMenu" :source="source" /> + <!-- Mime --> + <td v-if="isMimeAvailable" + :title="mime" + class="files-list__row-mime" + data-cy-files-list-row-mime + @click="openDetailsIfAvailable"> + <span>{{ mime }}</span> + </td> + <!-- Size --> <td v-if="!compact && isSizeAvailable" :style="sizeOpacity" @@ -85,7 +94,7 @@ </template> <script lang="ts"> -import { formatFileSize } from '@nextcloud/files' +import { FileType, formatFileSize } from '@nextcloud/files' import { useHotKey } from '@nextcloud/vue/composables/useHotKey' import { defineComponent } from 'vue' import NcDateTime from '@nextcloud/vue/components/NcDateTime' @@ -123,6 +132,10 @@ export default defineComponent({ ], props: { + isMimeAvailable: { + type: Boolean, + default: false, + }, isSizeAvailable: { type: Boolean, default: false, @@ -186,6 +199,17 @@ export default defineComponent({ return this.currentView.columns || [] }, + mime() { + if (this.source.type === FileType.Folder) { + return this.t('files', 'Folder') + } + + if (!this.source.mime || this.source.mime === 'application/octet-stream') { + return t('files', 'Unknown file type') + } + + return this.source.mime + }, size() { const size = this.source.size if (size === undefined || isNaN(size) || size < 0) { |