import store from '@/store';
|
import { defineComponent } from 'vue';
|
|
const { body } = document;
|
const WIDTH = 992; // refer to Bootstrap's responsive design
|
|
export default defineComponent({
|
watch: {
|
$route() {
|
if (this.device === 'mobile' && this.sidebar.opened) {
|
store.app().closeSidebar({ withoutAnimation: false });
|
}
|
}
|
},
|
beforeMount() {
|
window.addEventListener('resize', this.resizeHandler);
|
},
|
beforeUnmount() {
|
window.removeEventListener('resize', this.resizeHandler);
|
},
|
mounted() {
|
const isMobile = this.isMobile();
|
if (isMobile) {
|
store.app().toggleDevice('mobile');
|
store.app().closeSidebar({ withoutAnimation: true });
|
}
|
},
|
methods: {
|
// do not use $_ for mixins properties
|
// https://vuejs.org/v2/style-guide/index.html#Private-property-names-essential
|
isMobile() {
|
const rect = body.getBoundingClientRect();
|
return rect.width - 1 < WIDTH;
|
},
|
resizeHandler() {}
|
}
|
});
|