mirror of
https://github.com/chansee97/nova-admin.git
synced 2025-04-05 19:41:59 +08:00
fix: import order
This commit is contained in:
parent
e450a029ac
commit
7da454563b
@ -1,16 +1,16 @@
|
|||||||
import UnoCSS from '@unocss/vite'
|
import UnoCSS from '@unocss/vite'
|
||||||
import vue from '@vitejs/plugin-vue'
|
import vue from '@vitejs/plugin-vue'
|
||||||
import vueJsx from '@vitejs/plugin-vue-jsx'
|
import vueJsx from '@vitejs/plugin-vue-jsx'
|
||||||
import VueDevTools from 'vite-plugin-vue-devtools'
|
|
||||||
import Components from 'unplugin-vue-components/vite'
|
|
||||||
import AutoImport from 'unplugin-auto-import/vite'
|
import AutoImport from 'unplugin-auto-import/vite'
|
||||||
import { NaiveUiResolver } from 'unplugin-vue-components/resolvers'
|
|
||||||
import viteCompression from 'vite-plugin-compression'
|
|
||||||
import Icons from 'unplugin-icons/vite'
|
|
||||||
import { FileSystemIconLoader } from 'unplugin-icons/loaders'
|
import { FileSystemIconLoader } from 'unplugin-icons/loaders'
|
||||||
|
|
||||||
// https://github.com/antfu/unplugin-icons
|
// https://github.com/antfu/unplugin-icons
|
||||||
import IconsResolver from 'unplugin-icons/resolver'
|
import IconsResolver from 'unplugin-icons/resolver'
|
||||||
|
import Icons from 'unplugin-icons/vite'
|
||||||
|
import { NaiveUiResolver } from 'unplugin-vue-components/resolvers'
|
||||||
|
import Components from 'unplugin-vue-components/vite'
|
||||||
|
import viteCompression from 'vite-plugin-compression'
|
||||||
|
|
||||||
|
import VueDevTools from 'vite-plugin-vue-devtools'
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description: 设置vite插件配置
|
* @description: 设置vite插件配置
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
|
import { naiveI18nOptions } from '@/utils'
|
||||||
import { darkTheme } from 'naive-ui'
|
import { darkTheme } from 'naive-ui'
|
||||||
import { useAppStore } from './store'
|
import { useAppStore } from './store'
|
||||||
import { naiveI18nOptions } from '@/utils'
|
|
||||||
|
|
||||||
const appStore = useAppStore()
|
const appStore = useAppStore()
|
||||||
|
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { NFlex } from 'naive-ui'
|
|
||||||
import { useAppStore } from '@/store'
|
import { useAppStore } from '@/store'
|
||||||
import IconSun from '~icons/icon-park-outline/sun-one'
|
|
||||||
import IconMoon from '~icons/icon-park-outline/moon'
|
|
||||||
import IconAuto from '~icons/icon-park-outline/laptop-computer'
|
import IconAuto from '~icons/icon-park-outline/laptop-computer'
|
||||||
|
import IconMoon from '~icons/icon-park-outline/moon'
|
||||||
|
import IconSun from '~icons/icon-park-outline/sun-one'
|
||||||
|
import { NFlex } from 'naive-ui'
|
||||||
|
|
||||||
const { t } = useI18n()
|
const { t } = useI18n()
|
||||||
|
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import type { ToolbarNames } from 'md-editor-v3'
|
import type { ToolbarNames } from 'md-editor-v3'
|
||||||
|
|
||||||
import { MdEditor } from 'md-editor-v3'
|
import { useAppStore } from '@/store'
|
||||||
|
|
||||||
|
import { MdEditor } from 'md-editor-v3'
|
||||||
// https://imzbf.github.io/md-editor-v3/zh-CN/docs
|
// https://imzbf.github.io/md-editor-v3/zh-CN/docs
|
||||||
import 'md-editor-v3/lib/style.css'
|
import 'md-editor-v3/lib/style.css'
|
||||||
import { useAppStore } from '@/store'
|
|
||||||
|
|
||||||
const model = defineModel<string>()
|
const model = defineModel<string>()
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import Quill from 'quill'
|
import Quill from 'quill'
|
||||||
import 'quill/dist/quill.snow.css'
|
|
||||||
import { useTemplateRef } from 'vue'
|
import { useTemplateRef } from 'vue'
|
||||||
|
import 'quill/dist/quill.snow.css'
|
||||||
|
|
||||||
defineOptions({
|
defineOptions({
|
||||||
name: 'RichTextEditor',
|
name: 'RichTextEditor',
|
||||||
|
@ -1,6 +1,3 @@
|
|||||||
import * as echarts from 'echarts/core'
|
|
||||||
import { BarChart, LineChart, PieChart, RadarChart } from 'echarts/charts'
|
|
||||||
import { useTemplateRef } from 'vue'
|
|
||||||
// 系列类型的定义后缀都为 SeriesOption
|
// 系列类型的定义后缀都为 SeriesOption
|
||||||
import type {
|
import type {
|
||||||
BarSeriesOption,
|
BarSeriesOption,
|
||||||
@ -8,7 +5,6 @@ import type {
|
|||||||
PieSeriesOption,
|
PieSeriesOption,
|
||||||
RadarSeriesOption,
|
RadarSeriesOption,
|
||||||
} from 'echarts/charts'
|
} from 'echarts/charts'
|
||||||
|
|
||||||
// 组件类型的定义后缀都为 ComponentOption
|
// 组件类型的定义后缀都为 ComponentOption
|
||||||
import type {
|
import type {
|
||||||
DatasetComponentOption,
|
DatasetComponentOption,
|
||||||
@ -18,6 +14,9 @@ import type {
|
|||||||
ToolboxComponentOption,
|
ToolboxComponentOption,
|
||||||
TooltipComponentOption,
|
TooltipComponentOption,
|
||||||
} from 'echarts/components'
|
} from 'echarts/components'
|
||||||
|
import { useAppStore } from '@/store'
|
||||||
|
import { BarChart, LineChart, PieChart, RadarChart } from 'echarts/charts'
|
||||||
|
|
||||||
import {
|
import {
|
||||||
DatasetComponent, // 数据集组件
|
DatasetComponent, // 数据集组件
|
||||||
GridComponent,
|
GridComponent,
|
||||||
@ -27,10 +26,11 @@ import {
|
|||||||
TooltipComponent,
|
TooltipComponent,
|
||||||
TransformComponent, // 内置数据转换器组件 (filter, sort)
|
TransformComponent, // 内置数据转换器组件 (filter, sort)
|
||||||
} from 'echarts/components'
|
} from 'echarts/components'
|
||||||
|
import * as echarts from 'echarts/core'
|
||||||
|
|
||||||
import { LabelLayout, UniversalTransition } from 'echarts/features'
|
import { LabelLayout, UniversalTransition } from 'echarts/features'
|
||||||
import { CanvasRenderer } from 'echarts/renderers'
|
import { CanvasRenderer } from 'echarts/renderers'
|
||||||
import { useAppStore } from '@/store'
|
import { useTemplateRef } from 'vue'
|
||||||
|
|
||||||
// 通过 ComposeOption 来组合出一个只有必须组件和图表的 Option 类型
|
// 通过 ComposeOption 来组合出一个只有必须组件和图表的 Option 类型
|
||||||
export type ECOption = echarts.ComposeOption<
|
export type ECOption = echarts.ComposeOption<
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { isArray, isString } from 'radash'
|
|
||||||
import { useAuthStore } from '@/store'
|
import { useAuthStore } from '@/store'
|
||||||
|
import { isArray, isString } from 'radash'
|
||||||
|
|
||||||
/** 权限判断 */
|
/** 权限判断 */
|
||||||
export function usePermission() {
|
export function usePermission() {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import LayoutSelector from './LayoutSelector.vue'
|
|
||||||
import { useAppStore } from '@/store'
|
import { useAppStore } from '@/store'
|
||||||
|
import LayoutSelector from './LayoutSelector.vue'
|
||||||
|
|
||||||
const appStore = useAppStore()
|
const appStore = useAppStore()
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { useRouteStore } from '@/store'
|
|
||||||
import { useBoolean } from '@/hooks'
|
import { useBoolean } from '@/hooks'
|
||||||
|
import { useRouteStore } from '@/store'
|
||||||
|
|
||||||
const routeStore = useRouteStore()
|
const routeStore = useRouteStore()
|
||||||
|
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { renderIcon } from '@/utils/icon'
|
|
||||||
import { useAuthStore } from '@/store'
|
import { useAuthStore } from '@/store'
|
||||||
import IconGithub from '~icons/icon-park-outline/github'
|
import { renderIcon } from '@/utils/icon'
|
||||||
import IconUser from '~icons/icon-park-outline/user'
|
|
||||||
import IconLogout from '~icons/icon-park-outline/logout'
|
|
||||||
import IconBookOpen from '~icons/icon-park-outline/book-open'
|
import IconBookOpen from '~icons/icon-park-outline/book-open'
|
||||||
|
import IconGithub from '~icons/icon-park-outline/github'
|
||||||
|
import IconLogout from '~icons/icon-park-outline/logout'
|
||||||
|
import IconUser from '~icons/icon-park-outline/user'
|
||||||
|
|
||||||
const { t } = useI18n()
|
const { t } = useI18n()
|
||||||
|
|
||||||
|
@ -1,30 +1,30 @@
|
|||||||
import Logo from './sider/Logo.vue'
|
import BackTop from './common/BackTop.vue'
|
||||||
import Menu from './sider/Menu.vue'
|
import Setting from './common/Setting.vue'
|
||||||
|
|
||||||
|
import SettingDrawer from './common/SettingDrawer.vue'
|
||||||
import Breadcrumb from './header/Breadcrumb.vue'
|
import Breadcrumb from './header/Breadcrumb.vue'
|
||||||
import CollapaseButton from './header/CollapaseButton.vue'
|
import CollapaseButton from './header/CollapaseButton.vue'
|
||||||
import FullScreen from './header/FullScreen.vue'
|
import FullScreen from './header/FullScreen.vue'
|
||||||
import Notices from './header/Notices.vue'
|
import Notices from './header/Notices.vue'
|
||||||
import UserCenter from './header/UserCenter.vue'
|
|
||||||
import Search from './header/Search.vue'
|
import Search from './header/Search.vue'
|
||||||
|
|
||||||
|
import UserCenter from './header/UserCenter.vue'
|
||||||
|
|
||||||
|
import Logo from './sider/Logo.vue'
|
||||||
|
import Menu from './sider/Menu.vue'
|
||||||
import TabBar from './tab/TabBar.vue'
|
import TabBar from './tab/TabBar.vue'
|
||||||
|
|
||||||
import BackTop from './common/BackTop.vue'
|
|
||||||
import Setting from './common/Setting.vue'
|
|
||||||
import SettingDrawer from './common/SettingDrawer.vue'
|
|
||||||
|
|
||||||
export {
|
export {
|
||||||
|
BackTop,
|
||||||
Breadcrumb,
|
Breadcrumb,
|
||||||
CollapaseButton,
|
CollapaseButton,
|
||||||
Menu,
|
|
||||||
Logo,
|
|
||||||
FullScreen,
|
FullScreen,
|
||||||
|
Logo,
|
||||||
|
Menu,
|
||||||
|
Notices,
|
||||||
|
Search,
|
||||||
Setting,
|
Setting,
|
||||||
SettingDrawer,
|
SettingDrawer,
|
||||||
Notices,
|
|
||||||
UserCenter,
|
|
||||||
Search,
|
|
||||||
TabBar,
|
TabBar,
|
||||||
BackTop,
|
UserCenter,
|
||||||
}
|
}
|
||||||
|
@ -1,15 +1,15 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import type { RouteLocationNormalized } from 'vue-router'
|
import type { RouteLocationNormalized } from 'vue-router'
|
||||||
import Reload from './Reload.vue'
|
|
||||||
import DropTabs from './DropTabs.vue'
|
|
||||||
import ContentFullScreen from './ContentFullScreen.vue'
|
|
||||||
import { useAppStore, useTabStore } from '@/store'
|
import { useAppStore, useTabStore } from '@/store'
|
||||||
import IconRedo from '~icons/icon-park-outline/redo'
|
|
||||||
import IconClose from '~icons/icon-park-outline/close'
|
import IconClose from '~icons/icon-park-outline/close'
|
||||||
import IconDelete from '~icons/icon-park-outline/delete-four'
|
import IconDelete from '~icons/icon-park-outline/delete-four'
|
||||||
|
import IconFullwith from '~icons/icon-park-outline/fullwidth'
|
||||||
|
import IconRedo from '~icons/icon-park-outline/redo'
|
||||||
import IconLeft from '~icons/icon-park-outline/to-left'
|
import IconLeft from '~icons/icon-park-outline/to-left'
|
||||||
import IconRight from '~icons/icon-park-outline/to-right'
|
import IconRight from '~icons/icon-park-outline/to-right'
|
||||||
import IconFullwith from '~icons/icon-park-outline/fullwidth'
|
import ContentFullScreen from './ContentFullScreen.vue'
|
||||||
|
import DropTabs from './DropTabs.vue'
|
||||||
|
import Reload from './Reload.vue'
|
||||||
|
|
||||||
const tabStore = useTabStore()
|
const tabStore = useTabStore()
|
||||||
const appStore = useAppStore()
|
const appStore = useAppStore()
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import leftMenu from './leftMenu.layout.vue'
|
|
||||||
import topMenu from './topMenu.layout.vue'
|
|
||||||
import mixMenu from './mixMenu.layout.vue'
|
|
||||||
import { SettingDrawer } from './components'
|
|
||||||
import { useAppStore } from '@/store/app'
|
import { useAppStore } from '@/store/app'
|
||||||
|
import { SettingDrawer } from './components'
|
||||||
|
import leftMenu from './leftMenu.layout.vue'
|
||||||
|
import mixMenu from './mixMenu.layout.vue'
|
||||||
|
import topMenu from './topMenu.layout.vue'
|
||||||
|
|
||||||
const appStore = useAppStore()
|
const appStore = useAppStore()
|
||||||
const layoutMap = {
|
const layoutMap = {
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
|
import { useAppStore, useRouteStore } from '@/store'
|
||||||
import {
|
import {
|
||||||
BackTop,
|
BackTop,
|
||||||
Breadcrumb,
|
Breadcrumb,
|
||||||
@ -12,7 +13,6 @@ import {
|
|||||||
TabBar,
|
TabBar,
|
||||||
UserCenter,
|
UserCenter,
|
||||||
} from './components'
|
} from './components'
|
||||||
import { useAppStore, useRouteStore } from '@/store'
|
|
||||||
|
|
||||||
const routeStore = useRouteStore()
|
const routeStore = useRouteStore()
|
||||||
const appStore = useAppStore()
|
const appStore = useAppStore()
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import type { MenuInst, MenuOption } from 'naive-ui'
|
import type { MenuInst, MenuOption } from 'naive-ui'
|
||||||
|
import { useAppStore, useRouteStore } from '@/store'
|
||||||
import {
|
import {
|
||||||
BackTop,
|
BackTop,
|
||||||
CollapaseButton,
|
CollapaseButton,
|
||||||
@ -11,7 +12,6 @@ import {
|
|||||||
TabBar,
|
TabBar,
|
||||||
UserCenter,
|
UserCenter,
|
||||||
} from './components'
|
} from './components'
|
||||||
import { useAppStore, useRouteStore } from '@/store'
|
|
||||||
|
|
||||||
const routeStore = useRouteStore()
|
const routeStore = useRouteStore()
|
||||||
const appStore = useAppStore()
|
const appStore = useAppStore()
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
|
import { useAppStore, useRouteStore } from '@/store'
|
||||||
import {
|
import {
|
||||||
BackTop,
|
BackTop,
|
||||||
FullScreen,
|
FullScreen,
|
||||||
@ -10,7 +11,6 @@ import {
|
|||||||
TabBar,
|
TabBar,
|
||||||
UserCenter,
|
UserCenter,
|
||||||
} from './components'
|
} from './components'
|
||||||
import { useAppStore, useRouteStore } from '@/store'
|
|
||||||
|
|
||||||
const routeStore = useRouteStore()
|
const routeStore = useRouteStore()
|
||||||
const appStore = useAppStore()
|
const appStore = useAppStore()
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import type { App } from 'vue'
|
import type { App } from 'vue'
|
||||||
import AppVue from './App.vue'
|
|
||||||
import AppLoading from './components/common/AppLoading.vue'
|
|
||||||
import { installRouter } from '@/router'
|
import { installRouter } from '@/router'
|
||||||
import { installPinia } from '@/store'
|
import { installPinia } from '@/store'
|
||||||
|
import AppVue from './App.vue'
|
||||||
|
import AppLoading from './components/common/AppLoading.vue'
|
||||||
|
|
||||||
async function setupApp() {
|
async function setupApp() {
|
||||||
// 载入全局loading加载状态
|
// 载入全局loading加载状态
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import { createI18n } from 'vue-i18n'
|
|
||||||
import type { App } from 'vue'
|
import type { App } from 'vue'
|
||||||
|
import { local } from '@/utils'
|
||||||
|
import { createI18n } from 'vue-i18n'
|
||||||
import enUS from '../../locales/en_US.json'
|
import enUS from '../../locales/en_US.json'
|
||||||
import zhCN from '../../locales/zh_CN.json'
|
import zhCN from '../../locales/zh_CN.json'
|
||||||
import { local } from '@/utils'
|
|
||||||
|
|
||||||
const { VITE_DEFAULT_LANG } = import.meta.env
|
const { VITE_DEFAULT_LANG } = import.meta.env
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import type { App } from 'vue'
|
import type { App } from 'vue'
|
||||||
import { createRouter, createWebHashHistory, createWebHistory } from 'vue-router'
|
import { createRouter, createWebHashHistory, createWebHistory } from 'vue-router'
|
||||||
import { routes } from './routes.inner'
|
|
||||||
import { setupRouterGuard } from './guard'
|
import { setupRouterGuard } from './guard'
|
||||||
|
import { routes } from './routes.inner'
|
||||||
|
|
||||||
const { VITE_ROUTE_MODE = 'hash', VITE_BASE_URL } = import.meta.env
|
const { VITE_ROUTE_MODE = 'hash', VITE_BASE_URL } = import.meta.env
|
||||||
export const router = createRouter({
|
export const router = createRouter({
|
||||||
|
@ -1,18 +1,18 @@
|
|||||||
|
import { local } from '@/utils'
|
||||||
import { createAlova } from 'alova'
|
import { createAlova } from 'alova'
|
||||||
import VueHook, { type VueHookType } from 'alova/vue'
|
|
||||||
import adapterFetch from 'alova/fetch'
|
|
||||||
import { createServerTokenAuthentication } from 'alova/client'
|
import { createServerTokenAuthentication } from 'alova/client'
|
||||||
|
import adapterFetch from 'alova/fetch'
|
||||||
|
import VueHook, { type VueHookType } from 'alova/vue'
|
||||||
|
import {
|
||||||
|
DEFAULT_ALOVA_OPTIONS,
|
||||||
|
DEFAULT_BACKEND_OPTIONS,
|
||||||
|
} from './config'
|
||||||
import {
|
import {
|
||||||
handleBusinessError,
|
handleBusinessError,
|
||||||
handleRefreshToken,
|
handleRefreshToken,
|
||||||
handleResponseError,
|
handleResponseError,
|
||||||
handleServiceResult,
|
handleServiceResult,
|
||||||
} from './handle'
|
} from './handle'
|
||||||
import {
|
|
||||||
DEFAULT_ALOVA_OPTIONS,
|
|
||||||
DEFAULT_BACKEND_OPTIONS,
|
|
||||||
} from './config'
|
|
||||||
import { local } from '@/utils'
|
|
||||||
|
|
||||||
const { onAuthRequired, onResponseRefreshToken } = createServerTokenAuthentication<VueHookType>({
|
const { onAuthRequired, onResponseRefreshToken } = createServerTokenAuthentication<VueHookType>({
|
||||||
// 服务端判定token过期
|
// 服务端判定token过期
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
|
import { fetchUpdateToken } from '@/service'
|
||||||
|
import { useAuthStore } from '@/store'
|
||||||
|
import { local } from '@/utils'
|
||||||
import {
|
import {
|
||||||
ERROR_NO_TIP_STATUS,
|
ERROR_NO_TIP_STATUS,
|
||||||
ERROR_STATUS,
|
ERROR_STATUS,
|
||||||
} from './config'
|
} from './config'
|
||||||
import { useAuthStore } from '@/store'
|
|
||||||
import { fetchUpdateToken } from '@/service'
|
|
||||||
import { local } from '@/utils'
|
|
||||||
|
|
||||||
type ErrorStatus = keyof typeof ERROR_STATUS
|
type ErrorStatus = keyof typeof ERROR_STATUS
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { createAlovaInstance } from './alova'
|
|
||||||
import { serviceConfig } from '@/../service.config'
|
|
||||||
import { generateProxyPattern } from '@/../build/proxy'
|
import { generateProxyPattern } from '@/../build/proxy'
|
||||||
|
import { serviceConfig } from '@/../service.config'
|
||||||
|
import { createAlovaInstance } from './alova'
|
||||||
|
|
||||||
const isHttpProxy = import.meta.env.DEV && import.meta.env.VITE_HTTP_PROXY === 'Y'
|
const isHttpProxy = import.meta.env.DEV && import.meta.env.VITE_HTTP_PROXY === 'Y'
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
export * from './api/system'
|
|
||||||
export * from './api/login'
|
|
||||||
export * from './api/list'
|
export * from './api/list'
|
||||||
|
export * from './api/login'
|
||||||
|
export * from './api/system'
|
||||||
export * from './api/test'
|
export * from './api/test'
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import type { GlobalThemeOverrides } from 'naive-ui'
|
import type { GlobalThemeOverrides } from 'naive-ui'
|
||||||
|
import { local, setLocale } from '@/utils'
|
||||||
import { colord } from 'colord'
|
import { colord } from 'colord'
|
||||||
import { set } from 'radash'
|
import { set } from 'radash'
|
||||||
import themeConfig from './theme.json'
|
import themeConfig from './theme.json'
|
||||||
import { local, setLocale } from '@/utils'
|
|
||||||
|
|
||||||
export type TransitionAnimation = '' | 'fade-slide' | 'fade-bottom' | 'fade-scale' | 'zoom-fade' | 'zoom-out'
|
export type TransitionAnimation = '' | 'fade-slide' | 'fade-bottom' | 'fade-scale' | 'zoom-fade' | 'zoom-out'
|
||||||
export type LayoutMode = 'leftMenu' | 'topMenu' | 'mixMenu'
|
export type LayoutMode = 'leftMenu' | 'topMenu' | 'mixMenu'
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
|
import { router } from '@/router'
|
||||||
|
import { fetchLogin } from '@/service'
|
||||||
|
import { local } from '@/utils'
|
||||||
import { useRouteStore } from './router'
|
import { useRouteStore } from './router'
|
||||||
import { useTabStore } from './tab'
|
import { useTabStore } from './tab'
|
||||||
import { fetchLogin } from '@/service'
|
|
||||||
import { router } from '@/router'
|
|
||||||
import { local } from '@/utils'
|
|
||||||
|
|
||||||
interface AuthStatus {
|
interface AuthStatus {
|
||||||
userInfo: Api.Login.Info | null
|
userInfo: Api.Login.Info | null
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
import { clone, min, omit, pick } from 'radash'
|
|
||||||
import type { RouteRecordRaw } from 'vue-router'
|
|
||||||
import type { MenuOption } from 'naive-ui'
|
import type { MenuOption } from 'naive-ui'
|
||||||
import { RouterLink } from 'vue-router'
|
import type { RouteRecordRaw } from 'vue-router'
|
||||||
import Layout from '@/layouts/index.vue'
|
|
||||||
import { usePermission } from '@/hooks'
|
import { usePermission } from '@/hooks'
|
||||||
|
import Layout from '@/layouts/index.vue'
|
||||||
import { $t, arrayToTree, renderIcon } from '@/utils'
|
import { $t, arrayToTree, renderIcon } from '@/utils'
|
||||||
|
import { clone, min, omit, pick } from 'radash'
|
||||||
|
import { RouterLink } from 'vue-router'
|
||||||
|
|
||||||
const metaFields: AppRoute.MetaKeys[]
|
const metaFields: AppRoute.MetaKeys[]
|
||||||
= ['title', 'icon', 'requiresAuth', 'roles', 'keepAlive', 'hide', 'order', 'href', 'activeMenu', 'withoutTab', 'pinTab', 'menuType']
|
= ['title', 'icon', 'requiresAuth', 'roles', 'keepAlive', 'hide', 'order', 'href', 'activeMenu', 'withoutTab', 'pinTab', 'menuType']
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
import type { MenuOption } from 'naive-ui'
|
import type { MenuOption } from 'naive-ui'
|
||||||
import { createMenus, createRoutes, generateCacheRoutes } from './helper'
|
|
||||||
import { $t, local } from '@/utils'
|
|
||||||
import { router } from '@/router'
|
import { router } from '@/router'
|
||||||
import { fetchUserRoutes } from '@/service'
|
|
||||||
import { staticRoutes } from '@/router/routes.static'
|
import { staticRoutes } from '@/router/routes.static'
|
||||||
|
import { fetchUserRoutes } from '@/service'
|
||||||
import { useAuthStore } from '@/store/auth'
|
import { useAuthStore } from '@/store/auth'
|
||||||
|
import { $t, local } from '@/utils'
|
||||||
|
import { createMenus, createRoutes, generateCacheRoutes } from './helper'
|
||||||
|
|
||||||
interface RoutesStatus {
|
interface RoutesStatus {
|
||||||
isInitAuthRoute: boolean
|
isInitAuthRoute: boolean
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import type { NDateLocale, NLocale } from 'naive-ui'
|
import type { NDateLocale, NLocale } from 'naive-ui'
|
||||||
import { dateZhCN, zhCN } from 'naive-ui'
|
|
||||||
import { i18n } from '@/modules/i18n'
|
import { i18n } from '@/modules/i18n'
|
||||||
|
import { dateZhCN, zhCN } from 'naive-ui'
|
||||||
|
|
||||||
export function setLocale(locale: App.lang) {
|
export function setLocale(locale: App.lang) {
|
||||||
i18n.global.locale.value = locale
|
i18n.global.locale.value = locale
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
|
export * from './array'
|
||||||
|
export * from './dict'
|
||||||
|
export * from './i18n'
|
||||||
export * from './icon'
|
export * from './icon'
|
||||||
export * from './storage'
|
export * from './storage'
|
||||||
export * from './array'
|
|
||||||
export * from './i18n'
|
|
||||||
export * from './dict'
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { graphic } from 'echarts'
|
|
||||||
import { type ECOption, useEcharts } from '@/hooks'
|
import { type ECOption, useEcharts } from '@/hooks'
|
||||||
|
import { graphic } from 'echarts'
|
||||||
|
|
||||||
const lineOptions = ref<ECOption>({
|
const lineOptions = ref<ECOption>({
|
||||||
tooltip: {
|
tooltip: {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { graphic } from 'echarts'
|
|
||||||
import { type ECOption, useEcharts } from '@/hooks'
|
import { type ECOption, useEcharts } from '@/hooks'
|
||||||
|
import { graphic } from 'echarts'
|
||||||
|
|
||||||
const chartData = [
|
const chartData = [
|
||||||
{ name: '1', value: 300 },
|
{ name: '1', value: 300 },
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import Chart from './components/chart.vue'
|
|
||||||
import { useAuthStore } from '@/store'
|
import { useAuthStore } from '@/store'
|
||||||
|
import Chart from './components/chart.vue'
|
||||||
|
|
||||||
const { userInfo } = useAuthStore()
|
const { userInfo } = useAuthStore()
|
||||||
</script>
|
</script>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { graphic } from 'echarts'
|
|
||||||
import { type ECOption, useEcharts } from '@/hooks'
|
import { type ECOption, useEcharts } from '@/hooks'
|
||||||
|
import { graphic } from 'echarts'
|
||||||
|
|
||||||
// 饼状图
|
// 饼状图
|
||||||
const pieOptions = ref<ECOption>({
|
const pieOptions = ref<ECOption>({
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { useRequest } from 'alova/client'
|
|
||||||
import {
|
import {
|
||||||
downloadFile,
|
downloadFile,
|
||||||
} from '@/service'
|
} from '@/service'
|
||||||
|
import { useRequest } from 'alova/client'
|
||||||
|
|
||||||
const emit = defineEmits<{
|
const emit = defineEmits<{
|
||||||
update: [data: any]
|
update: [data: any]
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { useRequest } from 'alova/client'
|
|
||||||
|
|
||||||
import {
|
import {
|
||||||
fetchGet,
|
fetchGet,
|
||||||
} from '@/service'
|
} from '@/service'
|
||||||
|
|
||||||
|
import { useRequest } from 'alova/client'
|
||||||
|
|
||||||
const emit = defineEmits<{
|
const emit = defineEmits<{
|
||||||
update: [data: any] // 具名元组语法
|
update: [data: any] // 具名元组语法
|
||||||
}>()
|
}>()
|
||||||
|
@ -1,20 +1,20 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import Env from './components/Env.vue'
|
|
||||||
import Get from './components/Get.vue'
|
|
||||||
import Post from './components/Post.vue'
|
|
||||||
import FormPost from './components/FormPost.vue'
|
|
||||||
import Delete from './components/Delete.vue'
|
import Delete from './components/Delete.vue'
|
||||||
import Put from './components/Put.vue'
|
|
||||||
import UseRequest from './components/UseRequest.vue'
|
|
||||||
import NoToken from './components/NoToken.vue'
|
|
||||||
import DownLoad from './components/DownLoad.vue'
|
import DownLoad from './components/DownLoad.vue'
|
||||||
import DownLoadWithProgress from './components/DownLoadWithProgress.vue'
|
import DownLoadWithProgress from './components/DownLoadWithProgress.vue'
|
||||||
|
import Env from './components/Env.vue'
|
||||||
import FailedRequest from './components/FailedRequest.vue'
|
import FailedRequest from './components/FailedRequest.vue'
|
||||||
import FailedResponse from './components/FailedResponse.vue'
|
import FailedResponse from './components/FailedResponse.vue'
|
||||||
import FailedResponseWithoutTip from './components/FailedResponseWithoutTip.vue'
|
import FailedResponseWithoutTip from './components/FailedResponseWithoutTip.vue'
|
||||||
import Transform from './components/Transform.vue'
|
import FormPost from './components/FormPost.vue'
|
||||||
|
import Get from './components/Get.vue'
|
||||||
|
import NoToken from './components/NoToken.vue'
|
||||||
|
import Post from './components/Post.vue'
|
||||||
|
import Put from './components/Put.vue'
|
||||||
import RefreshToken from './components/RefreshToken.vue'
|
import RefreshToken from './components/RefreshToken.vue'
|
||||||
import TokenExpiration from './components/TokenExpiration.vue'
|
import TokenExpiration from './components/TokenExpiration.vue'
|
||||||
|
import Transform from './components/Transform.vue'
|
||||||
|
import UseRequest from './components/UseRequest.vue'
|
||||||
|
|
||||||
const msg = ref()
|
const msg = ref()
|
||||||
function handleUpdate(data: any) {
|
function handleUpdate(data: any) {
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
<script setup lang="tsx">
|
<script setup lang="tsx">
|
||||||
import type { DataTableColumns, FormInst } from 'naive-ui'
|
import type { DataTableColumns, FormInst } from 'naive-ui'
|
||||||
|
import { Gender } from '@/constants'
|
||||||
|
import { useBoolean } from '@/hooks'
|
||||||
|
import { fetchUserPage } from '@/service'
|
||||||
import { NButton, NPopconfirm, NSpace, NSwitch, NTag } from 'naive-ui'
|
import { NButton, NPopconfirm, NSpace, NSwitch, NTag } from 'naive-ui'
|
||||||
import TableModal from './components/TableModal.vue'
|
import TableModal from './components/TableModal.vue'
|
||||||
import { fetchUserPage } from '@/service'
|
|
||||||
import { useBoolean } from '@/hooks'
|
|
||||||
import { Gender } from '@/constants'
|
|
||||||
|
|
||||||
const { bool: loading, setTrue: startLoading, setFalse: endLoading } = useBoolean(false)
|
const { bool: loading, setTrue: startLoading, setFalse: endLoading } = useBoolean(false)
|
||||||
const { bool: visible, setTrue: openModal } = useBoolean(false)
|
const { bool: visible, setTrue: openModal } = useBoolean(false)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { useAuthStore } from '@/store'
|
|
||||||
import { usePermission } from '@/hooks'
|
import { usePermission } from '@/hooks'
|
||||||
|
import { useAuthStore } from '@/store'
|
||||||
|
|
||||||
const authStore = useAuthStore()
|
const authStore = useAuthStore()
|
||||||
const { hasPermission } = usePermission()
|
const { hasPermission } = usePermission()
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import type { FormInst } from 'naive-ui'
|
import type { FormInst } from 'naive-ui'
|
||||||
import { local } from '@/utils'
|
|
||||||
import { useAuthStore } from '@/store'
|
import { useAuthStore } from '@/store'
|
||||||
|
import { local } from '@/utils'
|
||||||
|
|
||||||
const emit = defineEmits(['update:modelValue'])
|
const emit = defineEmits(['update:modelValue'])
|
||||||
|
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
<script setup lang="tsx">
|
<script setup lang="tsx">
|
||||||
import type { DataTableColumns, FormInst } from 'naive-ui'
|
import type { DataTableColumns, FormInst } from 'naive-ui'
|
||||||
|
import CopyText from '@/components/custom/CopyText.vue'
|
||||||
|
import { Gender } from '@/constants'
|
||||||
|
import { useBoolean } from '@/hooks'
|
||||||
|
import { fetchUserPage } from '@/service'
|
||||||
import { NButton, NPopconfirm, NSpace, NSwitch, NTag } from 'naive-ui'
|
import { NButton, NPopconfirm, NSpace, NSwitch, NTag } from 'naive-ui'
|
||||||
import TableModal from './components/TableModal.vue'
|
import TableModal from './components/TableModal.vue'
|
||||||
import { fetchUserPage } from '@/service'
|
|
||||||
import { useBoolean } from '@/hooks'
|
|
||||||
import { Gender } from '@/constants'
|
|
||||||
import CopyText from '@/components/custom/CopyText.vue'
|
|
||||||
|
|
||||||
const { bool: loading, setTrue: startLoading, setFalse: endLoading } = useBoolean(false)
|
const { bool: loading, setTrue: startLoading, setFalse: endLoading } = useBoolean(false)
|
||||||
|
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
<script setup lang="tsx">
|
<script setup lang="tsx">
|
||||||
import type { DataTableColumns } from 'naive-ui'
|
import type { DataTableColumns } from 'naive-ui'
|
||||||
|
import CopyText from '@/components/custom/CopyText.vue'
|
||||||
|
import { useBoolean } from '@/hooks'
|
||||||
|
import { fetchDictList } from '@/service'
|
||||||
|
import { getDictByNet } from '@/utils'
|
||||||
import { NButton, NFlex, NPopconfirm } from 'naive-ui'
|
import { NButton, NFlex, NPopconfirm } from 'naive-ui'
|
||||||
import DictModal from './components/DictModal.vue'
|
import DictModal from './components/DictModal.vue'
|
||||||
import { fetchDictList } from '@/service'
|
|
||||||
import { useBoolean } from '@/hooks'
|
|
||||||
import { getDictByNet } from '@/utils'
|
|
||||||
import CopyText from '@/components/custom/CopyText.vue'
|
|
||||||
|
|
||||||
const { bool: dictLoading, setTrue: startDictLoading, setFalse: endDictLoading } = useBoolean(false)
|
const { bool: dictLoading, setTrue: startDictLoading, setFalse: endDictLoading } = useBoolean(false)
|
||||||
const { bool: contentLoading, setTrue: startContentLoading, setFalse: endContentLoading } = useBoolean(false)
|
const { bool: contentLoading, setTrue: startContentLoading, setFalse: endContentLoading } = useBoolean(false)
|
||||||
|
@ -3,8 +3,8 @@ import type {
|
|||||||
FormItemRule,
|
FormItemRule,
|
||||||
} from 'naive-ui'
|
} from 'naive-ui'
|
||||||
import HelpInfo from '@/components/common/HelpInfo.vue'
|
import HelpInfo from '@/components/common/HelpInfo.vue'
|
||||||
import { useBoolean } from '@/hooks'
|
|
||||||
import { Regex } from '@/constants'
|
import { Regex } from '@/constants'
|
||||||
|
import { useBoolean } from '@/hooks'
|
||||||
import { fetchRoleList } from '@/service'
|
import { fetchRoleList } from '@/service'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
<script setup lang="tsx">
|
<script setup lang="tsx">
|
||||||
import type { DataTableColumns } from 'naive-ui'
|
import type { DataTableColumns } from 'naive-ui'
|
||||||
|
import CopyText from '@/components/custom/CopyText.vue'
|
||||||
|
import { useBoolean } from '@/hooks'
|
||||||
|
import { fetchAllRoutes } from '@/service'
|
||||||
|
import { arrayToTree, createIcon } from '@/utils'
|
||||||
import { NButton, NPopconfirm, NSpace, NTag } from 'naive-ui'
|
import { NButton, NPopconfirm, NSpace, NTag } from 'naive-ui'
|
||||||
import TableModal from './components/TableModal.vue'
|
import TableModal from './components/TableModal.vue'
|
||||||
import { fetchAllRoutes } from '@/service'
|
|
||||||
import { useBoolean } from '@/hooks'
|
|
||||||
import { arrayToTree, createIcon } from '@/utils'
|
|
||||||
import CopyText from '@/components/custom/CopyText.vue'
|
|
||||||
|
|
||||||
const { bool: loading, setTrue: startLoading, setFalse: endLoading } = useBoolean(false)
|
const { bool: loading, setTrue: startLoading, setFalse: endLoading } = useBoolean(false)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user