mirror of
https://github.com/vbenjs/vue-vben-admin.git
synced 2025-08-27 16:15:19 +08:00
feat: add naive app
This commit is contained in:
52
apps/web-naive/src/app.vue
Normal file
52
apps/web-naive/src/app.vue
Normal file
@@ -0,0 +1,52 @@
|
||||
<script lang="ts" setup>
|
||||
import { computed } from 'vue';
|
||||
|
||||
import { useNaiveDesignTokens } from '@vben/hooks';
|
||||
import { preferences } from '@vben/preferences';
|
||||
|
||||
import {
|
||||
darkTheme,
|
||||
dateEnUS,
|
||||
dateZhCN,
|
||||
enUS,
|
||||
GlobalThemeOverrides,
|
||||
lightTheme,
|
||||
zhCN,
|
||||
} from 'naive-ui';
|
||||
|
||||
defineOptions({ name: 'App' });
|
||||
|
||||
const { commonTokens } = useNaiveDesignTokens();
|
||||
|
||||
const tokenLocale = computed(() =>
|
||||
preferences.app.locale === 'zh-CN' ? zhCN : enUS,
|
||||
);
|
||||
const tokenDateLocale = computed(() =>
|
||||
preferences.app.locale === 'zh-CN' ? dateZhCN : dateEnUS,
|
||||
);
|
||||
const tokenTheme = computed(() =>
|
||||
preferences.theme.mode === 'dark' ? darkTheme : lightTheme,
|
||||
);
|
||||
|
||||
const themeOverrides = computed((): GlobalThemeOverrides => {
|
||||
return {
|
||||
common: commonTokens,
|
||||
};
|
||||
});
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<NConfigProvider
|
||||
:date-locale="tokenDateLocale"
|
||||
:locale="tokenLocale"
|
||||
:theme="tokenTheme"
|
||||
:theme-overrides="themeOverrides"
|
||||
class="h-full"
|
||||
>
|
||||
<NNotificationProvider>
|
||||
<NMessageProvider>
|
||||
<RouterView />
|
||||
</NMessageProvider>
|
||||
</NNotificationProvider>
|
||||
</NConfigProvider>
|
||||
</template>
|
Reference in New Issue
Block a user