2022-03-31 00:33:29 +02:00
|
|
|
<script setup lang="ts">
|
|
|
|
import { RouterView } from 'vue-router'
|
|
|
|
import { layouts } from './layouts';
|
|
|
|
import { computed } from 'vue';
|
|
|
|
import { useRoute } from 'vue-router'
|
2022-04-04 14:07:24 +02:00
|
|
|
import { darkThemeOverrides, lightThemeOverrides } from './themes'
|
|
|
|
import { NThemeEditor } from 'naive-ui'; // TODO: remove before mep
|
2022-03-31 00:33:29 +02:00
|
|
|
import {
|
2022-04-04 01:52:59 +02:00
|
|
|
darkTheme,
|
2022-03-31 00:33:29 +02:00
|
|
|
NConfigProvider,
|
|
|
|
NGlobalStyle,
|
|
|
|
} from 'naive-ui'
|
2022-04-04 01:52:59 +02:00
|
|
|
import { useStyleStore } from './stores/style.store';
|
2022-03-31 00:33:29 +02:00
|
|
|
|
|
|
|
const route = useRoute();
|
|
|
|
const layout = computed(() => route?.meta?.layout ?? layouts.base)
|
2022-04-04 01:52:59 +02:00
|
|
|
const styleStore = useStyleStore()
|
|
|
|
|
|
|
|
const theme = computed(() => styleStore.isDarkTheme ? darkTheme : null)
|
2022-04-04 14:07:24 +02:00
|
|
|
const themeOverrides = computed(() => styleStore.isDarkTheme ? darkThemeOverrides : lightThemeOverrides)
|
2022-03-31 00:33:29 +02:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2022-04-04 14:07:24 +02:00
|
|
|
<n-config-provider :theme="theme" :theme-overrides="themeOverrides">
|
2022-03-31 00:33:29 +02:00
|
|
|
<n-global-style />
|
2022-04-04 00:24:45 +02:00
|
|
|
<n-message-provider placement="bottom">
|
2022-04-04 14:07:24 +02:00
|
|
|
<n-theme-editor>
|
|
|
|
<!-- TODO: remove before mep -->
|
|
|
|
<component :is="layout">
|
|
|
|
<router-view />
|
|
|
|
</component>
|
|
|
|
</n-theme-editor>
|
2022-04-04 00:24:45 +02:00
|
|
|
</n-message-provider>
|
2022-03-31 00:33:29 +02:00
|
|
|
</n-config-provider>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<style>
|
|
|
|
body {
|
|
|
|
min-height: 100%;
|
|
|
|
margin: 0;
|
|
|
|
padding: 0;
|
|
|
|
}
|
2022-04-12 13:24:14 +02:00
|
|
|
|
2022-03-31 00:33:29 +02:00
|
|
|
html {
|
|
|
|
height: 100%;
|
|
|
|
margin: 0;
|
|
|
|
padding: 0;
|
|
|
|
}
|
2022-04-12 13:24:14 +02:00
|
|
|
|
2022-03-31 00:33:29 +02:00
|
|
|
* {
|
|
|
|
box-sizing: border-box;
|
|
|
|
}
|
|
|
|
</style>
|