Change: UI to display correctly on mobile #162

This commit is contained in:
advplyr
2021-11-04 17:35:59 -05:00
parent b0ea2f8008
commit b827667a72
30 changed files with 239 additions and 102 deletions

View File

@ -1,5 +1,8 @@
<template>
<div class="w-44 fixed left-0 top-16 z-40 h-full bg-bg bg-opacity-70 shadow-lg border-r border-white border-opacity-5 py-4">
<div class="w-44 fixed left-0 top-16 z-40 h-full bg-bg bg-opacity-100 md:bg-opacity-70 shadow-lg border-r border-white border-opacity-5 py-4 transform transition-transform" :class="drawerOpen ? 'translate-x-0' : '-translate-x-44'" v-click-outside="clickOutside">
<div class="md:hidden flex items-center justify-end py-2 px-4 mb-1" @click="closeDrawer">
<span class="material-icons text-2xl">arrow_back</span>
</div>
<nuxt-link to="/config" class="w-full px-4 h-12 border-b border-opacity-0 flex items-center cursor-pointer relative" :class="routeName === 'config' ? 'bg-primary bg-opacity-70' : 'hover:bg-primary hover:bg-opacity-30'">
<p>Settings</p>
<div v-show="routeName === 'config'" class="h-full w-0.5 bg-yellow-400 absolute top-0 left-0" />
@ -30,10 +33,19 @@
<script>
export default {
props: {
isOpen: Boolean
},
data() {
return {}
return {
windowWidth: 0
}
},
computed: {
drawerOpen() {
if (this.windowWidth < 758) return this.isOpen
return true
},
routeName() {
return this.$route.name
},
@ -50,7 +62,24 @@ export default {
return this.versionData.githubTagUrl
}
},
methods: {},
mounted() {}
methods: {
clickOutside() {
if (!this.isOpen) return
this.closeDrawer()
},
closeDrawer() {
this.$emit('update:isOpen', false)
},
resize() {
this.windowWidth = window.innerWidth
}
},
mounted() {
window.addEventListener('resize', this.resize)
this.windowWidth = this.resize
},
beforeDestroy() {
window.removeEventListener('resize', this.resize)
}
}
</script>