mirror of
				https://github.com/soybeanjs/soybean-admin.git
				synced 2025-10-25 11:03:42 +08:00 
			
		
		
		
	Compare commits
	
		
			16 Commits
		
	
	
		
			tauri-v1.3
			...
			tauri-v1.3
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 320bb9b38c | ||
|  | 217a3bb259 | ||
|  | d37591dd7a | ||
|  | cf67d55cbf | ||
|  | 98b75c22c3 | ||
|  | 993e9caf79 | ||
|  | f26d0a61eb | ||
|  | eed617f9eb | ||
|  | ea8aa6c4e6 | ||
|  | 4dde4c22b1 | ||
|  | 59f07d8ac4 | ||
|  | e8378318c6 | ||
|  | 840273474f | ||
|  | 4e55b0e9bd | ||
|  | 5377002932 | ||
|  | c469512bd4 | 
							
								
								
									
										56
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										56
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,6 +1,62 @@ | ||||
| # Changelog | ||||
|  | ||||
|  | ||||
| ## [v1.3.2](https://github.com/honghuangdc/soybean-admin/compare/v1.3.1...v1.3.2) (2024-07-30) | ||||
|  | ||||
| ###    🚀 Features | ||||
|  | ||||
| - **projects**: | ||||
|   - add color fading mode.close #567  -  by @Azir-11 in https://github.com/honghuangdc/soybean-admin/issues/569 and https://github.com/honghuangdc/soybean-admin/issues/567 [<samp>(4dde4)</samp>](https://github.com/honghuangdc/soybean-admin/commit/4dde4c2) | ||||
|   - add full screen watermark. close#571  -  by @paynezhuang in https://github.com/honghuangdc/soybean-admin/issues/573 and https://github.com/honghuangdc/soybean-admin/issues/571 [<samp>(ea8aa)</samp>](https://github.com/honghuangdc/soybean-admin/commit/ea8aa6c) | ||||
|  | ||||
| ###    🐞 Bug Fixes | ||||
|  | ||||
| - **projects**: fix vertical-mix menu selected  -  by @honghuangdc [<samp>(59f07)</samp>](https://github.com/honghuangdc/soybean-admin/commit/59f07d8) | ||||
|  | ||||
| ###    🛠 Optimizations | ||||
|  | ||||
| - **projects**: | ||||
|   - add type WatermarkProps  -  by @honghuangdc [<samp>(f26d0)</samp>](https://github.com/honghuangdc/soybean-admin/commit/f26d0a6) | ||||
|   - remove home NAlert closable  -  by @honghuangdc [<samp>(98b75)</samp>](https://github.com/honghuangdc/soybean-admin/commit/98b75c2) | ||||
|   - optimize response code comparison  -  by @honghuangdc [<samp>(cf67d)</samp>](https://github.com/honghuangdc/soybean-admin/commit/cf67d55) | ||||
| - **types**: | ||||
|   - remove useless types.  -  by **Azir** [<samp>(eed61)</samp>](https://github.com/honghuangdc/soybean-admin/commit/eed617f) | ||||
|  | ||||
| ###    📖 Documentation | ||||
|  | ||||
| - **projects**: update CHANGELOG  -  by @honghuangdc [<samp>(d3759)</samp>](https://github.com/honghuangdc/soybean-admin/commit/d37591d) | ||||
|  | ||||
| ###    🏡 Chore | ||||
|  | ||||
| - **deps**: update deps  -  by @honghuangdc [<samp>(993e9)</samp>](https://github.com/honghuangdc/soybean-admin/commit/993e9ca) | ||||
|  | ||||
| ###    ❤️ Contributors | ||||
|  | ||||
| [](https://github.com/honghuangdc)  [](https://github.com/paynezhuang)  [](https://github.com/Azir-11)   | ||||
| [Azir](mailto:2075125282@qq.com),  | ||||
|  | ||||
| ## [v1.3.1](https://github.com/honghuangdc/soybean-admin/compare/v1.3.0...v1.3.1) (2024-07-22) | ||||
|  | ||||
| ###    🐞 Bug Fixes | ||||
|  | ||||
| - **projects**: | ||||
|   - fix the issue of abnormal width of the sidebar in the top menu mix and reverse mode  -  by @Azir-11 in https://github.com/honghuangdc/soybean-admin/issues/562 [<samp>(c4695)</samp>](https://github.com/honghuangdc/soybean-admin/commit/c469512) | ||||
|   - fix HorizontalMixMenu inverted. fixed #563  -  by @honghuangdc in https://github.com/honghuangdc/soybean-admin/issues/563 [<samp>(4e55b)</samp>](https://github.com/honghuangdc/soybean-admin/commit/4e55b0e) | ||||
|   - fix vertical-menu will not render when the layout is from mobile  -  by @honghuangdc [<samp>(84027)</samp>](https://github.com/honghuangdc/soybean-admin/commit/8402734) | ||||
|  | ||||
| ###    📖 Documentation | ||||
|  | ||||
| - **projects**: update CHANGELOG  -  by @honghuangdc [<samp>(613c8)</samp>](https://github.com/honghuangdc/soybean-admin/commit/613c836) | ||||
|  | ||||
| ###    🎨 Styles | ||||
|  | ||||
| - **other**: modify the Chinese name of the grayscale mode  -  by **Azir** [<samp>(53770)</samp>](https://github.com/honghuangdc/soybean-admin/commit/5377002) | ||||
|  | ||||
| ###    ❤️ Contributors | ||||
|  | ||||
| [](https://github.com/honghuangdc)  [](https://github.com/Azir-11)   | ||||
| [Azir](mailto:2075125282@qq.com),  | ||||
|  | ||||
| ## [v1.3.0](https://github.com/soybeanjs/soybean-admin/compare/v1.2.8...v1.3.0) (2024-07-22) | ||||
|  | ||||
| ###    🚨 Breaking Changes | ||||
|   | ||||
| @@ -1,5 +1,27 @@ | ||||
| # 更新日志 | ||||
|  | ||||
| ## [v1.3.1](https://github.com/honghuangdc/soybean-admin/compare/v1.3.0...v1.3.1) (2024-07-22) | ||||
|  | ||||
| ###    🐞 Bug 修复 | ||||
|  | ||||
| - **项目**: | ||||
|   - 修复顶部菜单混合和反向模式下侧边栏宽度异常的问题  -  由 @Azir-11 在 https://github.com/honghuangdc/soybean-admin/issues/562 修复 [<samp>(c4695)</samp>](https://github.com/honghuangdc/soybean-admin/commit/c469512) | ||||
|   - 修复水平混合菜单反转问题。修复 #563  -  由 @honghuangdc 在 https://github.com/honghuangdc/soybean-admin/issues/563 修复 [<samp>(4e55b)</samp>](https://github.com/honghuangdc/soybean-admin/commit/4e55b0e) | ||||
|   - 修复当布局来自移动端时垂直菜单不渲染的问题  -  由 @honghuangdc 修复 [<samp>(84027)</samp>](https://github.com/honghuangdc/soybean-admin/commit/8402734) | ||||
|  | ||||
| ###    📖 文档 | ||||
|  | ||||
| - **项目**: 更新更新日志  -  由 @honghuangdc 更新 [<samp>(613c8)</samp>](https://github.com/honghuangdc/soybean-admin/commit/613c836) | ||||
|  | ||||
| ###    🎨 样式 | ||||
|  | ||||
| - **其他**: 修改灰度模式的中文名称  -  由 **Azir** 修改 [<samp>(53770)</samp>](https://github.com/honghuangdc/soybean-admin/commit/5377002) | ||||
|  | ||||
| ###    ❤️ 贡献者 | ||||
|  | ||||
| [](https://github.com/honghuangdc)  [](https://github.com/Azir-11)   | ||||
| [Azir](mailto:2075125282@qq.com),  | ||||
|  | ||||
|  | ||||
| ## [v1.3.0](https://github.com/soybeanjs/soybean-admin/compare/v1.2.8...v1.3.0) (2024-07-22) | ||||
|  | ||||
|   | ||||
							
								
								
									
										36
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | ||||
| { | ||||
|   "name": "soybean-admin", | ||||
|   "type": "module", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "description": "A fresh and elegant admin template, based on Vue3、Vite3、TypeScript、NaiveUI and UnoCSS. 一个基于Vue3、Vite3、TypeScript、NaiveUI and UnoCSS的清新优雅的中后台模版。", | ||||
|   "author": { | ||||
|     "name": "Soybean", | ||||
| @@ -63,45 +63,45 @@ | ||||
|     "echarts": "5.5.1", | ||||
|     "naive-ui": "2.39.0", | ||||
|     "nprogress": "0.2.0", | ||||
|     "pinia": "2.1.7", | ||||
|     "pinia": "2.2.0", | ||||
|     "tailwind-merge": "2.4.0", | ||||
|     "vue": "3.4.33", | ||||
|     "vue": "3.4.34", | ||||
|     "vue-draggable-plus": "0.5.2", | ||||
|     "vue-i18n": "9.13.1", | ||||
|     "vue-router": "4.4.0" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@elegant-router/vue": "0.3.7", | ||||
|     "@iconify/json": "2.2.230", | ||||
|     "@iconify/json": "2.2.232", | ||||
|     "@sa/scripts": "workspace:*", | ||||
|     "@sa/uno-preset": "workspace:*", | ||||
|     "@soybeanjs/eslint-config": "1.3.7", | ||||
|     "@tauri-apps/cli": "1.6.0", | ||||
|     "@types/node": "20.14.11", | ||||
|     "@types/node": "22.0.0", | ||||
|     "@types/nprogress": "0.2.3", | ||||
|     "@unocss/eslint-config": "0.61.5", | ||||
|     "@unocss/preset-icons": "0.61.5", | ||||
|     "@unocss/preset-uno": "0.61.5", | ||||
|     "@unocss/transformer-directives": "0.61.5", | ||||
|     "@unocss/transformer-variant-group": "0.61.5", | ||||
|     "@unocss/vite": "0.61.5", | ||||
|     "@vitejs/plugin-vue": "5.0.5", | ||||
|     "@unocss/eslint-config": "0.61.7", | ||||
|     "@unocss/preset-icons": "0.61.7", | ||||
|     "@unocss/preset-uno": "0.61.7", | ||||
|     "@unocss/transformer-directives": "0.61.7", | ||||
|     "@unocss/transformer-variant-group": "0.61.7", | ||||
|     "@unocss/vite": "0.61.7", | ||||
|     "@vitejs/plugin-vue": "5.1.1", | ||||
|     "@vitejs/plugin-vue-jsx": "4.0.0", | ||||
|     "eslint": "9.7.0", | ||||
|     "eslint": "9.8.0", | ||||
|     "eslint-plugin-vue": "9.27.0", | ||||
|     "lint-staged": "15.2.7", | ||||
|     "sass": "1.77.8", | ||||
|     "simple-git-hooks": "2.11.1", | ||||
|     "tsx": "4.16.2", | ||||
|     "typescript": "5.5.3", | ||||
|     "unplugin-icons": "0.19.0", | ||||
|     "typescript": "5.5.4", | ||||
|     "unplugin-icons": "0.19.1", | ||||
|     "unplugin-vue-components": "0.27.3", | ||||
|     "vite": "5.3.4", | ||||
|     "vite": "5.3.5", | ||||
|     "vite-plugin-progress": "0.0.7", | ||||
|     "vite-plugin-svg-icons": "2.0.1", | ||||
|     "vite-plugin-vue-devtools": "7.3.6", | ||||
|     "vite-plugin-vue-devtools": "7.3.7", | ||||
|     "vue-eslint-parser": "9.4.3", | ||||
|     "vue-tsc": "2.0.26" | ||||
|     "vue-tsc": "2.0.29" | ||||
|   }, | ||||
|   "simple-git-hooks": { | ||||
|     "commit-msg": "pnpm sa git-commit-verify", | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@sa/axios", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "exports": { | ||||
|     ".": "./src/index.ts" | ||||
|   }, | ||||
| @@ -12,7 +12,7 @@ | ||||
|   "dependencies": { | ||||
|     "@sa/utils": "workspace:*", | ||||
|     "axios": "1.7.2", | ||||
|     "axios-retry": "4.4.1", | ||||
|     "axios-retry": "4.4.2", | ||||
|     "qs": "6.12.3" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@sa/color", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "exports": { | ||||
|     ".": "./src/index.ts" | ||||
|   }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@sa/hooks", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "exports": { | ||||
|     ".": "./src/index.ts" | ||||
|   }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@sa/materials", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "exports": { | ||||
|     ".": "./src/index.ts" | ||||
|   }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@sa/fetch", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "exports": { | ||||
|     ".": "./src/index.ts" | ||||
|   }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@sa/scripts", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "bin": { | ||||
|     "sa": "./bin.ts" | ||||
|   }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@sa/uno-preset", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "exports": { | ||||
|     ".": "./src/index.ts" | ||||
|   }, | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@sa/utils", | ||||
|   "version": "1.3.0", | ||||
|   "version": "1.3.2", | ||||
|   "exports": { | ||||
|     ".": "./src/index.ts" | ||||
|   }, | ||||
|   | ||||
							
								
								
									
										1877
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1877
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										18
									
								
								src/App.vue
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								src/App.vue
									
									
									
									
									
								
							| @@ -1,6 +1,7 @@ | ||||
| <script setup lang="ts"> | ||||
| import { computed } from 'vue'; | ||||
| import { NConfigProvider, darkTheme } from 'naive-ui'; | ||||
| import type { WatermarkProps } from 'naive-ui'; | ||||
| import { useAppStore } from './store/modules/app'; | ||||
| import { useThemeStore } from './store/modules/theme'; | ||||
| import { naiveDateLocales, naiveLocales } from './locales/naive'; | ||||
| @@ -21,6 +22,22 @@ const naiveLocale = computed(() => { | ||||
| const naiveDateLocale = computed(() => { | ||||
|   return naiveDateLocales[appStore.locale]; | ||||
| }); | ||||
|  | ||||
| const watermarkProps = computed<WatermarkProps>(() => { | ||||
|   return { | ||||
|     content: themeStore.watermark.text, | ||||
|     cross: true, | ||||
|     fullscreen: true, | ||||
|     fontSize: 16, | ||||
|     lineHeight: 16, | ||||
|     width: 384, | ||||
|     height: 384, | ||||
|     xOffset: 12, | ||||
|     yOffset: 60, | ||||
|     rotate: -15, | ||||
|     zIndex: 9999 | ||||
|   }; | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <template> | ||||
| @@ -33,6 +50,7 @@ const naiveDateLocale = computed(() => { | ||||
|   > | ||||
|     <AppProvider> | ||||
|       <RouterView class="bg-layout" /> | ||||
|       <NWatermark v-if="themeStore.watermark.visible" v-bind="watermarkProps" /> | ||||
|     </AppProvider> | ||||
|   </NConfigProvider> | ||||
| </template> | ||||
|   | ||||
| @@ -85,8 +85,13 @@ function getSiderWidth() { | ||||
| } | ||||
|  | ||||
| function getSiderCollapsedWidth() { | ||||
|   const { reverseHorizontalMix } = themeStore.layout; | ||||
|   const { collapsedWidth, mixCollapsedWidth, mixChildMenuWidth } = themeStore.sider; | ||||
|  | ||||
|   if (isHorizontalMix.value && reverseHorizontalMix) { | ||||
|     return isActiveFirstLevelMenuHasChildren.value ? collapsedWidth : 0; | ||||
|   } | ||||
|  | ||||
|   let w = isVerticalMix.value || isHorizontalMix.value ? mixCollapsedWidth : collapsedWidth; | ||||
|  | ||||
|   if (isVerticalMix.value && appStore.mixSiderFixed && childLevelMenus.value.length) { | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| <script setup lang="ts"> | ||||
| import { computed } from 'vue'; | ||||
| import type { Component } from 'vue'; | ||||
| import { useAppStore } from '@/store/modules/app'; | ||||
| import { useThemeStore } from '@/store/modules/theme'; | ||||
| import VerticalMenu from './modules/vertical-menu.vue'; | ||||
| import VerticalMixMenu from './modules/vertical-mix-menu.vue'; | ||||
| @@ -12,6 +13,7 @@ defineOptions({ | ||||
|   name: 'GlobalMenu' | ||||
| }); | ||||
|  | ||||
| const appStore = useAppStore(); | ||||
| const themeStore = useThemeStore(); | ||||
|  | ||||
| const activeMenu = computed(() => { | ||||
| @@ -24,10 +26,12 @@ const activeMenu = computed(() => { | ||||
|  | ||||
|   return menuMap[themeStore.layout.mode]; | ||||
| }); | ||||
|  | ||||
| const reRenderVertical = computed(() => themeStore.layout.mode === 'vertical' && appStore.isMobile); | ||||
| </script> | ||||
|  | ||||
| <template> | ||||
|   <component :is="activeMenu" /> | ||||
|   <component :is="activeMenu" :key="reRenderVertical" /> | ||||
| </template> | ||||
|  | ||||
| <style scoped></style> | ||||
|   | ||||
| @@ -18,8 +18,6 @@ const themeStore = useThemeStore(); | ||||
| const { allMenus, childLevelMenus, activeFirstLevelMenuKey, setActiveFirstLevelMenuKey } = useMixMenuContext(); | ||||
| const { routerPushByKeyWithMetaQuery } = useRouterPush(); | ||||
|  | ||||
| const inverted = computed(() => !themeStore.darkMode && themeStore.sider.inverted); | ||||
|  | ||||
| const selectedKey = computed(() => { | ||||
|   const { hideInMenu, activeMenu } = route.meta; | ||||
|   const name = route.name as string; | ||||
| @@ -53,7 +51,6 @@ function handleSelectMixMenu(menu: App.Global.Menu) { | ||||
|     <FirstLevelMenu | ||||
|       :menus="allMenus" | ||||
|       :active-menu-key="activeFirstLevelMenuKey" | ||||
|       :inverted="inverted" | ||||
|       :sider-collapse="appStore.siderCollapse" | ||||
|       :dark-mode="themeStore.darkMode" | ||||
|       :theme-color="themeStore.themeColor" | ||||
|   | ||||
| @@ -27,8 +27,6 @@ const { | ||||
| } = useMixMenuContext(); | ||||
| const { routerPushByKeyWithMetaQuery } = useRouterPush(); | ||||
|  | ||||
| const inverted = computed(() => !themeStore.darkMode && themeStore.sider.inverted); | ||||
|  | ||||
| const selectedKey = computed(() => { | ||||
|   const { hideInMenu, activeMenu } = route.meta; | ||||
|   const name = route.name as string; | ||||
| @@ -86,7 +84,6 @@ watch( | ||||
|         :collapsed-width="themeStore.sider.collapsedWidth" | ||||
|         :collapsed-icon-size="22" | ||||
|         :options="childLevelMenus" | ||||
|         :inverted="inverted" | ||||
|         :indent="18" | ||||
|         @update:value="routerPushByKeyWithMetaQuery" | ||||
|       /> | ||||
|   | ||||
| @@ -117,6 +117,7 @@ watch( | ||||
|             <NMenu | ||||
|               v-model:expanded-keys="expandedKeys" | ||||
|               mode="vertical" | ||||
|               :value="selectedKey" | ||||
|               :options="childLevelMenus" | ||||
|               :collapsed="appStore.siderCollapse" | ||||
|               :collapsed-width="themeStore.sider.collapsedWidth" | ||||
|   | ||||
| @@ -25,6 +25,10 @@ function handleGrayscaleChange(value: boolean) { | ||||
|   themeStore.setGrayscale(value); | ||||
| } | ||||
|  | ||||
| function handleColourWeaknessChange(value: boolean) { | ||||
|   themeStore.setColourWeakness(value); | ||||
| } | ||||
|  | ||||
| const showSiderInverted = computed(() => !themeStore.darkMode && themeStore.layout.mode.includes('vertical')); | ||||
| </script> | ||||
|  | ||||
| @@ -53,6 +57,9 @@ const showSiderInverted = computed(() => !themeStore.darkMode && themeStore.layo | ||||
|     <SettingItem :label="$t('theme.grayscale')"> | ||||
|       <NSwitch :value="themeStore.grayscale" @update:value="handleGrayscaleChange" /> | ||||
|     </SettingItem> | ||||
|     <SettingItem :label="$t('theme.colourWeakness')"> | ||||
|       <NSwitch :value="themeStore.colourWeakness" @update:value="handleColourWeaknessChange" /> | ||||
|     </SettingItem> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -101,6 +101,19 @@ const isWrapperScrollMode = computed(() => themeStore.layout.scrollMode === 'wra | ||||
|     > | ||||
|       <NSwitch v-model:value="themeStore.footer.right" /> | ||||
|     </SettingItem> | ||||
|     <SettingItem key="8" :label="$t('theme.watermark.visible')"> | ||||
|       <NSwitch v-model:value="themeStore.watermark.visible" /> | ||||
|     </SettingItem> | ||||
|     <SettingItem v-if="themeStore.watermark.visible" key="8-1" :label="$t('theme.watermark.text')"> | ||||
|       <NInput | ||||
|         v-model:value="themeStore.watermark.text" | ||||
|         autosize | ||||
|         type="text" | ||||
|         size="small" | ||||
|         class="w-120px" | ||||
|         placeholder="SoybeanAdmin" | ||||
|       /> | ||||
|     </SettingItem> | ||||
|   </TransitionGroup> | ||||
| </template> | ||||
|  | ||||
|   | ||||
| @@ -65,6 +65,7 @@ const local: App.I18n.Schema = { | ||||
|       auto: 'Follow System' | ||||
|     }, | ||||
|     grayscale: 'Grayscale', | ||||
|     colourWeakness: 'Colour Weakness', | ||||
|     layoutMode: { | ||||
|       title: 'Layout Mode', | ||||
|       vertical: 'Vertical Menu Mode', | ||||
| @@ -134,6 +135,10 @@ const local: App.I18n.Schema = { | ||||
|       height: 'Footer Height', | ||||
|       right: 'Right Footer' | ||||
|     }, | ||||
|     watermark: { | ||||
|       visible: 'Watermark Full Screen Visible', | ||||
|       text: 'Watermark Text' | ||||
|     }, | ||||
|     themeDrawerTitle: 'Theme Configuration', | ||||
|     pageFunTitle: 'Page Function', | ||||
|     configOperation: { | ||||
|   | ||||
| @@ -64,7 +64,8 @@ const local: App.I18n.Schema = { | ||||
|       dark: '暗黑模式', | ||||
|       auto: '跟随系统' | ||||
|     }, | ||||
|     grayscale: '灰度模式', | ||||
|     grayscale: '灰色模式', | ||||
|     colourWeakness: '色弱模式', | ||||
|     layoutMode: { | ||||
|       title: '布局模式', | ||||
|       vertical: '左侧菜单模式', | ||||
| @@ -134,6 +135,10 @@ const local: App.I18n.Schema = { | ||||
|       height: '底部高度', | ||||
|       right: '底部局右' | ||||
|     }, | ||||
|     watermark: { | ||||
|       visible: '显示全屏水印', | ||||
|       text: '水印文本' | ||||
|     }, | ||||
|     themeDrawerTitle: '主题配置', | ||||
|     pageFunTitle: '页面功能', | ||||
|     configOperation: { | ||||
|   | ||||
| @@ -35,6 +35,7 @@ export const request = createFlatRequest<App.Service.Response, RequestInstanceSt | ||||
|     }, | ||||
|     async onBackendFail(response, instance) { | ||||
|       const authStore = useAuthStore(); | ||||
|       const responseCode = String(response.data.code); | ||||
|  | ||||
|       function handleLogout() { | ||||
|         authStore.resetStore(); | ||||
| @@ -49,14 +50,14 @@ export const request = createFlatRequest<App.Service.Response, RequestInstanceSt | ||||
|  | ||||
|       // when the backend response code is in `logoutCodes`, it means the user will be logged out and redirected to login page | ||||
|       const logoutCodes = import.meta.env.VITE_SERVICE_LOGOUT_CODES?.split(',') || []; | ||||
|       if (logoutCodes.includes(response.data.code)) { | ||||
|       if (logoutCodes.includes(responseCode)) { | ||||
|         handleLogout(); | ||||
|         return null; | ||||
|       } | ||||
|  | ||||
|       // when the backend response code is in `modalLogoutCodes`, it means the user will be logged out by displaying a modal | ||||
|       const modalLogoutCodes = import.meta.env.VITE_SERVICE_MODAL_LOGOUT_CODES?.split(',') || []; | ||||
|       if (modalLogoutCodes.includes(response.data.code) && !request.state.errMsgStack?.includes(response.data.msg)) { | ||||
|       if (modalLogoutCodes.includes(responseCode) && !request.state.errMsgStack?.includes(response.data.msg)) { | ||||
|         request.state.errMsgStack = [...(request.state.errMsgStack || []), response.data.msg]; | ||||
|  | ||||
|         // prevent the user from refreshing the page | ||||
| @@ -82,7 +83,7 @@ export const request = createFlatRequest<App.Service.Response, RequestInstanceSt | ||||
|       // when the backend response code is in `expiredTokenCodes`, it means the token is expired, and refresh token | ||||
|       // the api `refreshToken` can not return error code in `expiredTokenCodes`, otherwise it will be a dead loop, should return `logoutCodes` or `modalLogoutCodes` | ||||
|       const expiredTokenCodes = import.meta.env.VITE_SERVICE_EXPIRED_TOKEN_CODES?.split(',') || []; | ||||
|       if (expiredTokenCodes.includes(response.data.code) && !request.state.isRefreshingToken) { | ||||
|       if (expiredTokenCodes.includes(responseCode) && !request.state.isRefreshingToken) { | ||||
|         request.state.isRefreshingToken = true; | ||||
|  | ||||
|         const refreshConfig = await handleRefreshToken(response.config); | ||||
| @@ -108,7 +109,7 @@ export const request = createFlatRequest<App.Service.Response, RequestInstanceSt | ||||
|       // get backend error message and code | ||||
|       if (error.code === BACKEND_ERROR_CODE) { | ||||
|         message = error.response?.data?.msg || message; | ||||
|         backendErrorCode = error.response?.data?.code || ''; | ||||
|         backendErrorCode = String(error.response?.data?.code || ''); | ||||
|       } | ||||
|  | ||||
|       // the error message is displayed in the modal | ||||
|   | ||||
| @@ -10,8 +10,8 @@ import { | ||||
|   createThemeToken, | ||||
|   getNaiveTheme, | ||||
|   initThemeSettings, | ||||
|   toggleCssDarkMode, | ||||
|   toggleGrayscaleMode | ||||
|   toggleAuxiliaryColorModes, | ||||
|   toggleCssDarkMode | ||||
| } from './shared'; | ||||
|  | ||||
| /** Theme store */ | ||||
| @@ -33,6 +33,9 @@ export const useThemeStore = defineStore(SetupStoreId.Theme, () => { | ||||
|   /** grayscale mode */ | ||||
|   const grayscaleMode = computed(() => settings.value.grayscale); | ||||
|  | ||||
|   /** colourWeakness mode */ | ||||
|   const colourWeaknessMode = computed(() => settings.value.colourWeakness); | ||||
|  | ||||
|   /** Theme colors */ | ||||
|   const themeColors = computed(() => { | ||||
|     const { themeColor, otherColor, isInfoFollowPrimary } = settings.value; | ||||
| @@ -79,6 +82,15 @@ export const useThemeStore = defineStore(SetupStoreId.Theme, () => { | ||||
|     settings.value.grayscale = isGrayscale; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Set colourWeakness value | ||||
|    * | ||||
|    * @param isColourWeakness | ||||
|    */ | ||||
|   function setColourWeakness(isColourWeakness: boolean) { | ||||
|     settings.value.colourWeakness = isColourWeakness; | ||||
|   } | ||||
|  | ||||
|   /** Toggle theme scheme */ | ||||
|   function toggleThemeScheme() { | ||||
|     const themeSchemes: UnionKey.ThemeScheme[] = ['light', 'dark', 'auto']; | ||||
| @@ -167,9 +179,9 @@ export const useThemeStore = defineStore(SetupStoreId.Theme, () => { | ||||
|     ); | ||||
|  | ||||
|     watch( | ||||
|       grayscaleMode, | ||||
|       [grayscaleMode, colourWeaknessMode], | ||||
|       val => { | ||||
|         toggleGrayscaleMode(val); | ||||
|         toggleAuxiliaryColorModes(val[0], val[1]); | ||||
|       }, | ||||
|       { immediate: true } | ||||
|     ); | ||||
| @@ -197,6 +209,7 @@ export const useThemeStore = defineStore(SetupStoreId.Theme, () => { | ||||
|     naiveTheme, | ||||
|     settingsJson, | ||||
|     setGrayscale, | ||||
|     setColourWeakness, | ||||
|     resetStore, | ||||
|     setThemeScheme, | ||||
|     toggleThemeScheme, | ||||
|   | ||||
| @@ -180,20 +180,16 @@ export function toggleCssDarkMode(darkMode = false) { | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Toggle grayscale mode | ||||
|  * Toggle auxiliary color modes | ||||
|  * | ||||
|  * @param grayscaleMode Is grayscale mode | ||||
|  * @param grayscaleMode | ||||
|  * @param colourWeakness | ||||
|  */ | ||||
| export function toggleGrayscaleMode(grayscaleMode = false) { | ||||
|   const GRAYSCALE_CLASS = 'grayscale'; | ||||
|  | ||||
|   const { add, remove } = toggleHtmlClass(GRAYSCALE_CLASS); | ||||
|  | ||||
|   if (grayscaleMode) { | ||||
|     add(); | ||||
|   } else { | ||||
|     remove(); | ||||
|   } | ||||
| export function toggleAuxiliaryColorModes(grayscaleMode = false, colourWeakness = false) { | ||||
|   const htmlElement = document.documentElement; | ||||
|   htmlElement.style.filter = [grayscaleMode ? 'grayscale(100%)' : '', colourWeakness ? 'invert(80%)' : ''] | ||||
|     .filter(Boolean) | ||||
|     .join(' '); | ||||
| } | ||||
|  | ||||
| type NaiveColorScene = '' | 'Suppl' | 'Hover' | 'Pressed' | 'Active'; | ||||
|   | ||||
| @@ -11,7 +11,3 @@ body, | ||||
| html { | ||||
|   overflow-x: hidden; | ||||
| } | ||||
|  | ||||
| html.grayscale { | ||||
|   filter: grayscale(100%); | ||||
| } | ||||
|   | ||||
| @@ -2,6 +2,7 @@ | ||||
| export const themeSettings: App.Theme.ThemeSetting = { | ||||
|   themeScheme: 'light', | ||||
|   grayscale: false, | ||||
|   colourWeakness: false, | ||||
|   recommendColor: false, | ||||
|   themeColor: '#646cff', | ||||
|   otherColor: { | ||||
| @@ -48,6 +49,10 @@ export const themeSettings: App.Theme.ThemeSetting = { | ||||
|     height: 48, | ||||
|     right: true | ||||
|   }, | ||||
|   watermark: { | ||||
|     visible: false, | ||||
|     text: 'SoybeanAdmin' | ||||
|   }, | ||||
|   tokens: { | ||||
|     light: { | ||||
|       colors: { | ||||
|   | ||||
							
								
								
									
										138
									
								
								src/typings/api.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										138
									
								
								src/typings/api.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -81,142 +81,4 @@ declare namespace Api { | ||||
|       home: import('@elegant-router/types').LastLevelRouteKey; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * namespace SystemManage | ||||
|    * | ||||
|    * backend api module: "systemManage" | ||||
|    */ | ||||
|   namespace SystemManage { | ||||
|     type CommonSearchParams = Pick<Common.PaginatingCommonParams, 'current' | 'size'>; | ||||
|  | ||||
|     /** role */ | ||||
|     type Role = Common.CommonRecord<{ | ||||
|       /** role name */ | ||||
|       roleName: string; | ||||
|       /** role code */ | ||||
|       roleCode: string; | ||||
|       /** role description */ | ||||
|       roleDesc: string; | ||||
|     }>; | ||||
|  | ||||
|     /** role search params */ | ||||
|     type RoleSearchParams = CommonType.RecordNullable< | ||||
|       Pick<Api.SystemManage.Role, 'roleName' | 'roleCode' | 'status'> & CommonSearchParams | ||||
|     >; | ||||
|  | ||||
|     /** role list */ | ||||
|     type RoleList = Common.PaginatingQueryRecord<Role>; | ||||
|  | ||||
|     /** all role */ | ||||
|     type AllRole = Pick<Role, 'id' | 'roleName' | 'roleCode'>; | ||||
|  | ||||
|     /** | ||||
|      * user gender | ||||
|      * | ||||
|      * - "1": "male" | ||||
|      * - "2": "female" | ||||
|      */ | ||||
|     type UserGender = '1' | '2'; | ||||
|  | ||||
|     /** user */ | ||||
|     type User = Common.CommonRecord<{ | ||||
|       /** user name */ | ||||
|       userName: string; | ||||
|       /** user gender */ | ||||
|       userGender: UserGender | null; | ||||
|       /** user nick name */ | ||||
|       nickName: string; | ||||
|       /** user phone */ | ||||
|       userPhone: string; | ||||
|       /** user email */ | ||||
|       userEmail: string; | ||||
|       /** user role code collection */ | ||||
|       userRoles: string[]; | ||||
|     }>; | ||||
|  | ||||
|     /** user search params */ | ||||
|     type UserSearchParams = CommonType.RecordNullable< | ||||
|       Pick<Api.SystemManage.User, 'userName' | 'userGender' | 'nickName' | 'userPhone' | 'userEmail' | 'status'> & | ||||
|         CommonSearchParams | ||||
|     >; | ||||
|  | ||||
|     /** user list */ | ||||
|     type UserList = Common.PaginatingQueryRecord<User>; | ||||
|  | ||||
|     /** | ||||
|      * menu type | ||||
|      * | ||||
|      * - "1": directory | ||||
|      * - "2": menu | ||||
|      */ | ||||
|     type MenuType = '1' | '2'; | ||||
|  | ||||
|     type MenuButton = { | ||||
|       /** | ||||
|        * button code | ||||
|        * | ||||
|        * it can be used to control the button permission | ||||
|        */ | ||||
|       code: string; | ||||
|       /** button description */ | ||||
|       desc: string; | ||||
|     }; | ||||
|  | ||||
|     /** | ||||
|      * icon type | ||||
|      * | ||||
|      * - "1": iconify icon | ||||
|      * - "2": local icon | ||||
|      */ | ||||
|     type IconType = '1' | '2'; | ||||
|  | ||||
|     type MenuPropsOfRoute = Pick< | ||||
|       import('vue-router').RouteMeta, | ||||
|       | 'i18nKey' | ||||
|       | 'keepAlive' | ||||
|       | 'constant' | ||||
|       | 'order' | ||||
|       | 'href' | ||||
|       | 'hideInMenu' | ||||
|       | 'activeMenu' | ||||
|       | 'multiTab' | ||||
|       | 'fixedIndexInTab' | ||||
|       | 'query' | ||||
|     >; | ||||
|  | ||||
|     type Menu = Common.CommonRecord<{ | ||||
|       /** parent menu id */ | ||||
|       parentId: number; | ||||
|       /** menu type */ | ||||
|       menuType: MenuType; | ||||
|       /** menu name */ | ||||
|       menuName: string; | ||||
|       /** route name */ | ||||
|       routeName: string; | ||||
|       /** route path */ | ||||
|       routePath: string; | ||||
|       /** component */ | ||||
|       component?: string; | ||||
|       /** iconify icon name or local icon name */ | ||||
|       icon: string; | ||||
|       /** icon type */ | ||||
|       iconType: IconType; | ||||
|       /** buttons */ | ||||
|       buttons?: MenuButton[] | null; | ||||
|       /** children menu */ | ||||
|       children?: Menu[] | null; | ||||
|     }> & | ||||
|       MenuPropsOfRoute; | ||||
|  | ||||
|     /** menu list */ | ||||
|     type MenuList = Common.PaginatingQueryRecord<Menu>; | ||||
|  | ||||
|     type MenuTree = { | ||||
|       id: number; | ||||
|       label: string; | ||||
|       pId: number; | ||||
|       children?: MenuTree[]; | ||||
|     }; | ||||
|   } | ||||
| } | ||||
|   | ||||
							
								
								
									
										14
									
								
								src/typings/app.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								src/typings/app.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -10,6 +10,8 @@ declare namespace App { | ||||
|       themeScheme: UnionKey.ThemeScheme; | ||||
|       /** grayscale mode */ | ||||
|       grayscale: boolean; | ||||
|       /** colour weakness mode */ | ||||
|       colourWeakness: boolean; | ||||
|       /** Whether to recommend color */ | ||||
|       recommendColor: boolean; | ||||
|       /** Theme color */ | ||||
| @@ -93,6 +95,13 @@ declare namespace App { | ||||
|         /** Whether float the footer to the right when the layout is 'horizontal-mix' */ | ||||
|         right: boolean; | ||||
|       }; | ||||
|       /** Watermark */ | ||||
|       watermark: { | ||||
|         /** Whether to show the watermark */ | ||||
|         visible: boolean; | ||||
|         /** Watermark text */ | ||||
|         text: string; | ||||
|       }; | ||||
|       /** define some theme settings tokens, will transform to css variables */ | ||||
|       tokens: { | ||||
|         light: ThemeSettingToken; | ||||
| @@ -332,6 +341,7 @@ declare namespace App { | ||||
|       theme: { | ||||
|         themeSchema: { title: string } & Record<UnionKey.ThemeScheme, string>; | ||||
|         grayscale: string; | ||||
|         colourWeakness: string; | ||||
|         layoutMode: { title: string; reverseHorizontalMix: string } & Record<UnionKey.ThemeLayoutMode, string>; | ||||
|         recommendColor: string; | ||||
|         recommendColorDesc: string; | ||||
| @@ -372,6 +382,10 @@ declare namespace App { | ||||
|           height: string; | ||||
|           right: string; | ||||
|         }; | ||||
|         watermark: { | ||||
|           visible: string; | ||||
|           text: string; | ||||
|         }; | ||||
|         themeDrawerTitle: string; | ||||
|         pageFunTitle: string; | ||||
|         configOperation: { | ||||
|   | ||||
							
								
								
									
										1
									
								
								src/typings/components.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								src/typings/components.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -84,6 +84,7 @@ declare module 'vue' { | ||||
|     NThing: typeof import('naive-ui')['NThing'] | ||||
|     NTooltip: typeof import('naive-ui')['NTooltip'] | ||||
|     NTree: typeof import('naive-ui')['NTree'] | ||||
|     NWatermark: typeof import('naive-ui')['NWatermark'] | ||||
|     PinToggler: typeof import('./../components/common/pin-toggler.vue')['default'] | ||||
|     ReloadButton: typeof import('./../components/common/reload-button.vue')['default'] | ||||
|     RouterLink: typeof import('vue-router')['RouterLink'] | ||||
|   | ||||
| @@ -15,7 +15,7 @@ const gap = computed(() => (appStore.isMobile ? 0 : 16)); | ||||
|  | ||||
| <template> | ||||
|   <NSpace vertical :size="16"> | ||||
|     <NAlert :title="$t('common.warning')" type="warning" closable> | ||||
|     <NAlert :title="$t('common.warning')" type="warning"> | ||||
|       {{ $t('page.home.branchDesc') }} | ||||
|     </NAlert> | ||||
|     <HeaderBanner /> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user