| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- <template>
- <main>
- <!-- The client only is used to show the loading picture (@see https://nuxtjs.org/docs/2.x/features/nuxt-components#the-client-only-component) -->
- <client-only placeholder=" " />
- <v-app dark>
- <LayoutMenu v-if="displayedMenu" :menu="menu" :mini-variant="properties.miniVariant" />
- <LayoutHeader @handle-open-menu-click="handleOpenMenu" />
- <v-main class="ot_content_color">
- <LayoutSubheader v-if="displayedSubHeader" />
- <LayoutAlertbar class="mt-1"></LayoutAlertbar>
- <!-- Page will be rendered here-->
- <nuxt />
- </v-main>
- <lazy-LayoutAlertContainer />
- </v-app>
- </main>
- </template>
- <script lang="ts">
- import { computed, ComputedRef, defineComponent, reactive, useContext } from '@nuxtjs/composition-api'
- import { $useMenu } from '@/use/layout/menu'
- export default defineComponent({
- name: 'DefaultLayout',
- middleware: ['auth'],
- setup () {
- const { store } = useContext()
- const menu = $useMenu.setupContext().useLateralMenuConstruct()
- const properties = reactive({
- clipped: false,
- miniVariant: false
- })
- const displayedMenu: ComputedRef<boolean> = computed(() => store.state.profile.access.hasLateralMenu)
- const displayedSubHeader: ComputedRef<boolean> = computed(
- () => store.state.profile.access.hasLateralMenu || store.state.profile.access.isTeacher
- )
- const handleOpenMenu = (miniVariant: boolean) => {
- properties.miniVariant = miniVariant
- }
- return {
- properties,
- menu,
- displayedMenu,
- displayedSubHeader,
- handleOpenMenu
- }
- }
- })
- </script>
- <style scoped>
- .client-only-placeholder {
- height: 100%;
- width: 100%;
- position: absolute;
- z-index: 100;
- background-color: #2c3a48;
- background-position: center;
- background-repeat: no-repeat;
- background-image: url("");
- }
- </style>
|