From d737ead2da60a4801917323b4d1ac6a346f8c2dc Mon Sep 17 00:00:00 2001 From: Michiel Nijenhuis Date: Mon, 12 Aug 2024 15:55:48 +0200 Subject: [PATCH] chore: use more css vars instead of hardcoded values --- nuxt/assets/scss/defaults.scss | 7 +++++++ nuxt/assets/scss/transitions.scss | 16 ++++++++-------- nuxt/components/Atoms/Accordeon.vue | 6 ++---- nuxt/components/Atoms/ArtworkTeaser.vue | 2 +- nuxt/components/Atoms/CategoryTeaser.vue | 2 +- nuxt/components/Molecules/Form/Upload.vue | 2 +- nuxt/components/organisms/CategorySlider.vue | 2 +- nuxt/components/organisms/Create/Editor.vue | 6 +++--- .../organisms/Create/PreviewSidebar.vue | 10 +++++----- nuxt/pages/index.vue | 2 +- 10 files changed, 30 insertions(+), 25 deletions(-) diff --git a/nuxt/assets/scss/defaults.scss b/nuxt/assets/scss/defaults.scss index d682e92..6cd3755 100644 --- a/nuxt/assets/scss/defaults.scss +++ b/nuxt/assets/scss/defaults.scss @@ -38,4 +38,11 @@ $value: $i * $increment; --space-#{$i}: #{$value}; } + + // Transitions + --transition-page-vertical: top 1s; + --transition-page-horizontal: left 1s; + --transition-slider: 0.15s ease-in-out; + --transition-accordeon: 0.4s ease-in-out; + --transition-state: all 0.3s ease; } diff --git a/nuxt/assets/scss/transitions.scss b/nuxt/assets/scss/transitions.scss index c4bf4d6..392a939 100644 --- a/nuxt/assets/scss/transitions.scss +++ b/nuxt/assets/scss/transitions.scss @@ -1,10 +1,10 @@ /** * Transition to and from the art pages */ - .up { +.up { &.slide-leave-active, &.slide-enter-active { - transition: top 1s; + transition: var(--transition-page-vertical); } &.slide-enter-from { @@ -17,14 +17,14 @@ .down { &.slide-leave-active { - transition: top 1s; + transition: var(--transition-page-vertical); } &.slide-leave-from { top: 0; } &.slide-leave-to { - top: 100% + top: 100%; } } @@ -34,14 +34,14 @@ .left { &.slide-leave-active, &.slide-enter-active { - transition: left 1s; + transition: var(--transition-page-horizontal); } &.slide-enter-from { left: 100%; } &.slide-enter-to { - left: 0 + left: 0; } &.slide-leave-to { left: -100%; @@ -54,7 +54,7 @@ .right { &.slide-leave-active, &.slide-enter-active { - transition: left 1s; + transition: var(--transition-page-horizontal); } &.slide-enter-from { @@ -62,7 +62,7 @@ } &.slide-enter-to { - left: 0% + left: 0%; } &.slide-leave-to { left: 100%; diff --git a/nuxt/components/Atoms/Accordeon.vue b/nuxt/components/Atoms/Accordeon.vue index f09e399..63605dc 100644 --- a/nuxt/components/Atoms/Accordeon.vue +++ b/nuxt/components/Atoms/Accordeon.vue @@ -55,7 +55,7 @@ const toggle = () => { cursor: pointer; .icon { - transition: transform 0.3s ease; + transition: transform var(--transition-accordeon); &.open { transform: rotate(90deg) translate(0, 6px); @@ -65,9 +65,7 @@ const toggle = () => { &-body { overflow: hidden; - transition-property: max-height, opacity; - transition-duration: 0.4s; - transition-timing-function: ease-in-out; + transition: max-height var(--transition-accordeon), opacity var(--transition-accordeon); &.open { max-height: 100vh; diff --git a/nuxt/components/Atoms/ArtworkTeaser.vue b/nuxt/components/Atoms/ArtworkTeaser.vue index 5836692..578854a 100644 --- a/nuxt/components/Atoms/ArtworkTeaser.vue +++ b/nuxt/components/Atoms/ArtworkTeaser.vue @@ -69,7 +69,7 @@ defineProps<{ width: 100%; height: 100%; object-fit: cover; - transition: 0.15s ease-in-out; + transition: var(--transition-slider); } } diff --git a/nuxt/components/Atoms/CategoryTeaser.vue b/nuxt/components/Atoms/CategoryTeaser.vue index bb01245..7fa49cc 100644 --- a/nuxt/components/Atoms/CategoryTeaser.vue +++ b/nuxt/components/Atoms/CategoryTeaser.vue @@ -86,7 +86,7 @@ const to = computed(() => { width: var(--max-width-slide); height: 100%; object-fit: cover; - transition: 0.15s ease-in-out; + transition: var(--transition-slider); filter: blur(0.625rem); position: absolute; left: 50%; diff --git a/nuxt/components/Molecules/Form/Upload.vue b/nuxt/components/Molecules/Form/Upload.vue index 3a2def0..c13dcde 100644 --- a/nuxt/components/Molecules/Form/Upload.vue +++ b/nuxt/components/Molecules/Form/Upload.vue @@ -190,7 +190,7 @@ const clearInput = () => { padding: var(--space-6); border-radius: 50%; background: var(--blues-blue); - color: white; + color: var(--primary-color); } } } diff --git a/nuxt/components/organisms/CategorySlider.vue b/nuxt/components/organisms/CategorySlider.vue index 5e9f8e7..c73ac2e 100644 --- a/nuxt/components/organisms/CategorySlider.vue +++ b/nuxt/components/organisms/CategorySlider.vue @@ -42,7 +42,7 @@ const slideStyles = computed(() => { background-color: var(--primary-color); .category-slide { - transition: 0.15s ease-in-out; + transition: var(--transition-slider); &:hover { width: var(--max-width-slide) !important; diff --git a/nuxt/components/organisms/Create/Editor.vue b/nuxt/components/organisms/Create/Editor.vue index 58c0d52..27990bf 100644 --- a/nuxt/components/organisms/Create/Editor.vue +++ b/nuxt/components/organisms/Create/Editor.vue @@ -93,20 +93,20 @@ onBeforeMount(async () => { display: flex; align-items: center; justify-content: space-between; - gap: 1rem; + gap: var(--space-4); margin: 0 var(--space-20); .actions { display: flex; align-items: center; - gap: 1rem; + gap: var(--space-4); } } .preview { display: flex; overflow-x: scroll; - min-height: calc(100vh - 96px); // full height minus banner + min-height: calc(100vh - var(--space-24)); // full height minus banner &-laptop { max-height: 1080px; diff --git a/nuxt/components/organisms/Create/PreviewSidebar.vue b/nuxt/components/organisms/Create/PreviewSidebar.vue index 1cdd502..2d95d28 100644 --- a/nuxt/components/organisms/Create/PreviewSidebar.vue +++ b/nuxt/components/organisms/Create/PreviewSidebar.vue @@ -270,7 +270,7 @@ onUnmounted(() => { .divider { background-color: #8c8c8c; - height: 1px; + height: var(--space-0); width: 100%; margin: var(--space-2) 0 var(--space-2); } @@ -308,13 +308,13 @@ onUnmounted(() => { } .responsive-view-button { - width: 88px; - height: 65px; + width: var(--space-22); + height: var(--space-16); border: 2px solid gray; - transition: all 0.2s ease; + transition: var(--transition-state); svg { - transition: color 0.2s ease; + transition: var(--transition-state); } &:hover, diff --git a/nuxt/pages/index.vue b/nuxt/pages/index.vue index 129b002..ddaa304 100644 --- a/nuxt/pages/index.vue +++ b/nuxt/pages/index.vue @@ -52,7 +52,7 @@ a { text-decoration: none; color: white; padding: var(--space-2); - transition: color 0.3s ease; + transition: var(--transition-state); &:hover { color: blue;