2024-05-16 18:54:30 +08:00
|
|
|
<template>
|
2024-12-14 13:49:32 +08:00
|
|
|
<div class="app-container" :class="{ mobile: isMobile, noElectron: !isElectron }">
|
2024-12-28 16:43:52 +08:00
|
|
|
<n-config-provider :theme="theme === 'dark' ? darkTheme : lightTheme">
|
2024-05-16 18:54:30 +08:00
|
|
|
<n-dialog-provider>
|
2024-12-25 19:55:24 +08:00
|
|
|
<n-message-provider>
|
|
|
|
|
<router-view></router-view>
|
|
|
|
|
</n-message-provider>
|
2024-05-16 18:54:30 +08:00
|
|
|
</n-dialog-provider>
|
|
|
|
|
</n-config-provider>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
2024-11-28 08:12:37 +08:00
|
|
|
<script setup lang="ts">
|
2024-12-28 16:43:52 +08:00
|
|
|
import { darkTheme, lightTheme } from 'naive-ui';
|
2024-12-12 22:18:52 +08:00
|
|
|
import { onMounted } from 'vue';
|
2024-05-16 18:54:30 +08:00
|
|
|
|
2024-12-14 13:49:32 +08:00
|
|
|
import { isElectron } from '@/hooks/MusicHook';
|
2024-12-15 14:35:18 +08:00
|
|
|
import homeRouter from '@/router/home';
|
2024-05-16 18:54:30 +08:00
|
|
|
import store from '@/store';
|
|
|
|
|
|
2024-05-23 17:12:35 +08:00
|
|
|
import { isMobile } from './utils';
|
|
|
|
|
|
2024-12-28 16:43:52 +08:00
|
|
|
const theme = computed(() => {
|
|
|
|
|
return store.state.theme;
|
|
|
|
|
});
|
|
|
|
|
|
2024-05-16 18:54:30 +08:00
|
|
|
onMounted(() => {
|
2024-12-08 21:50:58 +08:00
|
|
|
store.dispatch('initializeSettings');
|
2024-12-28 16:43:52 +08:00
|
|
|
store.dispatch('initializeTheme');
|
2024-12-15 14:35:18 +08:00
|
|
|
if (isMobile.value) {
|
|
|
|
|
store.commit(
|
|
|
|
|
'setMenus',
|
|
|
|
|
homeRouter.filter((item) => item.meta.isMobile),
|
|
|
|
|
);
|
2024-12-30 11:20:23 +08:00
|
|
|
console.log(
|
|
|
|
|
'qqq ',
|
|
|
|
|
homeRouter.filter((item) => item.meta.isMobile),
|
|
|
|
|
);
|
2024-12-15 14:35:18 +08:00
|
|
|
}
|
2024-05-16 18:54:30 +08:00
|
|
|
});
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
2024-11-28 08:12:37 +08:00
|
|
|
.app-container {
|
|
|
|
|
@apply h-full w-full;
|
2024-05-16 18:54:30 +08:00
|
|
|
user-select: none;
|
|
|
|
|
}
|
2024-05-23 17:12:35 +08:00
|
|
|
|
|
|
|
|
.mobile {
|
|
|
|
|
.text-base {
|
|
|
|
|
font-size: 14px !important;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.html:has(.mobile) {
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
}
|
2024-05-16 18:54:30 +08:00
|
|
|
</style>
|