From d0d14b909202b1f74dd0d0f26e158c72eff986f9 Mon Sep 17 00:00:00 2001 From: Christopher Ng Date: Wed, 17 Jan 2024 16:22:34 -0800 Subject: [PATCH] enh(a11y): Update folder design to fix contrast issues Signed-off-by: Christopher Ng --- src/assets/grid-sizes.js | 27 ++-- src/components/FolderTagPreview.vue | 187 ++++++++++------------------ src/mixins/FileFolder.scss | 3 +- src/views/Folders.vue | 25 +++- 4 files changed, 97 insertions(+), 145 deletions(-) diff --git a/src/assets/grid-sizes.js b/src/assets/grid-sizes.js index 16341ebd0..7633e2cd1 100644 --- a/src/assets/grid-sizes.js +++ b/src/assets/grid-sizes.js @@ -20,9 +20,6 @@ * */ -// for now we want to keep the same gap everywhere -const gap = 8 - /** * Define the max width proportions * The number (key) indicate the MAX size @@ -34,63 +31,63 @@ module.exports = { sizes: { 400: { marginTop: 66, - marginW: gap, + marginW: 8, count: 3, - gap, + folderCount: 1, }, 700: { marginTop: 66, - marginW: gap, + marginW: 8, count: 4, - gap, + folderCount: 1, }, 1024: { marginTop: 66, marginW: 44, count: 5, - gap, + folderCount: 2, }, 1280: { marginTop: 66, marginW: 44, count: 4, - gap, + folderCount: 2, }, 1440: { marginTop: 88, marginW: 66, count: 5, - gap, + folderCount: 3, }, 1600: { marginTop: 88, marginW: 66, count: 6, - gap, + folderCount: 4, }, 2048: { marginTop: 88, marginW: 66, count: 7, - gap, + folderCount: 4, }, 2560: { marginTop: 88, marginW: 88, count: 8, - gap, + folderCount: 6, }, 3440: { marginTop: 88, marginW: 88, count: 9, - gap, + folderCount: 8, }, max: { marginTop: 88, marginW: 88, count: 10, - gap, + folderCount: 10, }, }, } diff --git a/src/components/FolderTagPreview.vue b/src/components/FolderTagPreview.vue index 412cf0c77..d0c1de943 100644 --- a/src/components/FolderTagPreview.vue +++ b/src/components/FolderTagPreview.vue @@ -21,35 +21,25 @@ --> @@ -57,9 +47,15 @@ import { generateUrl } from '@nextcloud/router' import { getCurrentUser } from '@nextcloud/auth' +import Folder from 'vue-material-design-icons/Folder.vue' + export default { name: 'FolderTagPreview', + components: { + Folder, + }, + props: { icon: { type: String, @@ -89,7 +85,6 @@ export default { data() { return { - loaded: false, failed: [], } }, @@ -100,11 +95,8 @@ export default { return this.previewList.length === 0 }, - ariaUuid() { - return `folder-${this.id}` - }, ariaLabel() { - return t('photos', 'Open the "{name}" sub-directory', { name: this.name }) + return t('photos', 'Open the "{name}" folder', { name: this.name }) }, /** @@ -117,6 +109,15 @@ export default { .filter(file => this.failed.indexOf(file.fileid) === -1) }, + previewUrl() { + if (this.previewList.length === 0) { + return null + } + const { fileid, etag } = this.previewList.at(-1) + // use etag to force cache reload if file changed + return generateUrl(`/core/preview?fileId=${fileid}&c=${etag}&x=${250}&y=${250}&forceIcon=0&a=0`) + }, + /** * We do not want encoded slashes when browsing by folder * so we generate a new valid route object based on the @@ -148,10 +149,6 @@ export default { }, methods: { - generateImgSrc({ fileid, etag }) { - // use etag to force cache reload if file changed - return generateUrl(`/core/preview?fileId=${fileid}&c=${etag}&x=${250}&y=${250}&forceIcon=0&a=0`) - }, onPreviewFail({ fileid }) { this.failed.push(fileid) }, @@ -160,105 +157,49 @@ export default { diff --git a/src/mixins/FileFolder.scss b/src/mixins/FileFolder.scss index 951734787..53e2be9f6 100644 --- a/src/mixins/FileFolder.scss +++ b/src/mixins/FileFolder.scss @@ -20,8 +20,7 @@ * */ -.file, -.folder { +.file { position: relative; display: flex; align-items: center; diff --git a/src/views/Folders.vue b/src/views/Folders.vue index 2188f9fdd..7a644dde2 100644 --- a/src/views/Folders.vue +++ b/src/views/Folders.vue @@ -53,12 +53,16 @@ {{ t('photos', 'No photos in here') }} -
+
+ :get-column-count="() => haveFolders ? gridConfig.folderCount : gridConfig.count" + :get-grid-gap="() => haveFolders ? 16 : 8" />
@@ -170,8 +174,8 @@ export default { ...folder, showShared: this.showShared, }, - width: 256, - height: 256, + width: 232, + height: 280, columnSpan: 1, renderComponent: Folder, } @@ -291,6 +295,17 @@ export default { @include grid-sizes using ($marginTop, $marginW) { padding: 0px #{$marginW}px 256px #{$marginW}px; } + &--folders { + padding: 32px 48px; + @media only screen and (max-width: 400px) { + display: flex; + justify-content: center; + width: 100%; + } + @media only screen and (min-width: 400px) { + width: fit-content; + } + } } .photos-navigation {