mirror of
				https://github.com/soybeanjs/soybean-admin.git
				synced 2025-10-27 03:43:44 +08:00 
			
		
		
		
	Compare commits
	
		
			20 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 376e2f7d84 | ||
|  | 069fa8a817 | ||
|  | b5a723cb5f | ||
|  | 79e85bc6b5 | ||
|  | bf7183747b | ||
|  | aabb2a49c4 | ||
|  | 7026126a57 | ||
|  | c212565248 | ||
|  | 813d8ce4c7 | ||
|  | 20a8127434 | ||
|  | ec8cadd183 | ||
|  | 4470cb4e8c | ||
|  | 8f9a70505c | ||
|  | 9094b21cbb | ||
|  | 6259287240 | ||
|  | 22004ff4dc | ||
|  | 08827a42a3 | ||
|  | 6a6eb9afd6 | ||
|  | ff51b72dac | ||
|  | fe06b8c499 | 
							
								
								
									
										77
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										77
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,6 +1,83 @@ | |||||||
| # Changelog | # Changelog | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## [v1.2.4](https://github.com/soybeanjs/soybean-admin/compare/v1.2.3...v1.2.4) (2024-06-14) | ||||||
|  |  | ||||||
|  | ###    🛠 Optimizations | ||||||
|  |  | ||||||
|  | - **projects**: | ||||||
|  |   - optimize `setupAppVersionNotification`  -  by @soybeanjs [<samp>(b5a72)</samp>](https://github.com/soybeanjs/soybean-admin/commit/b5a723c) | ||||||
|  |   - get buildTime with timezone 'Asia/Shanghai'  -  by @soybeanjs [<samp>(069fa)</samp>](https://github.com/soybeanjs/soybean-admin/commit/069fa8a) | ||||||
|  |  | ||||||
|  | ###    ❤️ Contributors | ||||||
|  |  | ||||||
|  | [](https://github.com/soybeanjs)   | ||||||
|  |  | ||||||
|  | ## [v1.2.3](https://github.com/soybeanjs/soybean-admin/compare/v1.2.2...v1.2.3) (2024-06-13) | ||||||
|  |  | ||||||
|  | ###    🐞 Bug Fixes | ||||||
|  |  | ||||||
|  | - **projects**: | ||||||
|  |   - fix mobile browser theme issue by adding color-scheme meta tag to index.html  -  by @KickCashew in https://github.com/soybeanjs/soybean-admin/issues/488 [<samp>(c2125)</samp>](https://github.com/soybeanjs/soybean-admin/commit/c212565) | ||||||
|  |   - Fix secondary directory components is empty  -  by @paynezhuang in https://github.com/soybeanjs/soybean-admin/issues/491 [<samp>(aabb2)</samp>](https://github.com/soybeanjs/soybean-admin/commit/aabb2a4) | ||||||
|  |  | ||||||
|  | ###    📖 Documentation | ||||||
|  |  | ||||||
|  | - **projects**: | ||||||
|  |   - Fixed the hyperlink pointing error  -  by **Azir** [<samp>(20a81)</samp>](https://github.com/soybeanjs/soybean-admin/commit/20a8127) | ||||||
|  |   - update README  -  by @soybeanjs [<samp>(70261)</samp>](https://github.com/soybeanjs/soybean-admin/commit/7026126) | ||||||
|  |  | ||||||
|  | ###    🏡 Chore | ||||||
|  |  | ||||||
|  | - **deps**: | ||||||
|  |   - update deps  -  by @soybeanjs [<samp>(813d8)</samp>](https://github.com/soybeanjs/soybean-admin/commit/813d8ce) | ||||||
|  |   - update deps  -  by @soybeanjs [<samp>(bf718)</samp>](https://github.com/soybeanjs/soybean-admin/commit/bf71837) | ||||||
|  |  | ||||||
|  | ###    ❤️ Contributors | ||||||
|  |  | ||||||
|  | [](https://github.com/soybeanjs)  [](https://github.com/paynezhuang)  [](https://github.com/KickCashew)   | ||||||
|  | [Azir](mailto:2075125282@qq.com) | ||||||
|  |  | ||||||
|  | ## [v1.2.2](https://github.com/honghuangdc/soybean-admin/compare/v1.2.1...v1.2.2) (2024-06-12) | ||||||
|  |  | ||||||
|  | ###    🚀 Features | ||||||
|  |  | ||||||
|  | - **projects**: reset scroll position when tab change  -  by @soybeanjs [<samp>(9094b)</samp>](https://github.com/honghuangdc/soybean-admin/commit/9094b21) | ||||||
|  |  | ||||||
|  | ###    🐞 Bug Fixes | ||||||
|  |  | ||||||
|  | - **projects**: | ||||||
|  |   - hide AppVersionNotification in DEV mode  -  by @sigma-plus in https://github.com/honghuangdc/soybean-admin/issues/482 [<samp>(62592)</samp>](https://github.com/honghuangdc/soybean-admin/commit/6259287) | ||||||
|  |   - fix menu-toggler hidden in mobile layout. fixed #483  -  by @soybeanjs in https://github.com/honghuangdc/soybean-admin/issues/483 [<samp>(4470c)</samp>](https://github.com/honghuangdc/soybean-admin/commit/4470cb4) | ||||||
|  |  | ||||||
|  | ###    📖 Documentation | ||||||
|  |  | ||||||
|  | - **projects**: update README  -  by @soybeanjs [<samp>(8f9a7)</samp>](https://github.com/honghuangdc/soybean-admin/commit/8f9a705) | ||||||
|  |  | ||||||
|  | ###    ❤️ Contributors | ||||||
|  |  | ||||||
|  | [](https://github.com/soybeanjs)  [](https://github.com/sigma-plus)   | ||||||
|  |  | ||||||
|  | ## [v1.2.1](https://github.com/honghuangdc/soybean-admin/compare/v1.2.0...v1.2.1) (2024-06-07) | ||||||
|  |  | ||||||
|  | ###    🐞 Bug Fixes | ||||||
|  |  | ||||||
|  | - **projects**: | ||||||
|  |   - fix get user info when page reload  -  by @soybeanjs [<samp>(ff51b)</samp>](https://github.com/honghuangdc/soybean-admin/commit/ff51b72) | ||||||
|  |   - fix setupAppVersionNotification render  -  by @soybeanjs [<samp>(6a6eb)</samp>](https://github.com/honghuangdc/soybean-admin/commit/6a6eb9a) | ||||||
|  |  | ||||||
|  | ###    📖 Documentation | ||||||
|  |  | ||||||
|  | - **projects**: update CHANGELOG  -  by @soybeanjs [<samp>(fe06b)</samp>](https://github.com/honghuangdc/soybean-admin/commit/fe06b8c) | ||||||
|  |  | ||||||
|  | ###    🏡 Chore | ||||||
|  |  | ||||||
|  | - **deps**: update deps  -  by @soybeanjs [<samp>(08827)</samp>](https://github.com/honghuangdc/soybean-admin/commit/08827a4) | ||||||
|  |  | ||||||
|  | ###    ❤️ Contributors | ||||||
|  |  | ||||||
|  | [](https://github.com/soybeanjs)   | ||||||
|  |  | ||||||
| ## [v1.2.0](https://github.com/soybeanjs/soybean-admin/compare/v1.1.5...v1.2.0) (2024-06-06) | ## [v1.2.0](https://github.com/soybeanjs/soybean-admin/compare/v1.1.5...v1.2.0) (2024-06-06) | ||||||
|  |  | ||||||
| ###    🚀 Features | ###    🚀 Features | ||||||
|   | |||||||
| @@ -1,5 +1,22 @@ | |||||||
| # 更新日志 | # 更新日志 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## [v1.2.0](https://github.com/soybeanjs/soybean-admin/compare/v1.1.5...v1.2.0) (2024-06-06) | ||||||
|  |  | ||||||
|  | ###    🚀 功能 | ||||||
|  |  | ||||||
|  | - **项目**: | ||||||
|  |   - 支持系统新版本更新通知。关闭 #420  -  由 @soybeanjs 在 https://github.com/soybeanjs/soybean-admin/issues/420 [<samp>(584cd)</samp>](https://github.com/soybeanjs/soybean-admin/commit/584cd54) | ||||||
|  |   - 在路由守卫中获取用户信息并从localStorage中移除。关闭 #459  -  由 @soybeanjs 在 https://github.com/soybeanjs/soybean-admin/issues/459 [<samp>(5531a)</samp>](https://github.com/soybeanjs/soybean-admin/commit/5531a68) | ||||||
|  |  | ||||||
|  | ###    📖 文档 | ||||||
|  |  | ||||||
|  | - **项目**: 更新CHANGELOG  -  由 @soybeanjs [<samp>(2bec8)</samp>](https://github.com/soybeanjs/soybean-admin/commit/2bec899) | ||||||
|  |  | ||||||
|  | ###    ❤️ 贡献者 | ||||||
|  |  | ||||||
|  | [](https://github.com/soybeanjs)   | ||||||
|  |  | ||||||
| ## [v1.1.5](https://github.com/soybeanjs/soybean-admin/compare/v1.1.4...v1.1.5) (2024-06-06) | ## [v1.1.5](https://github.com/soybeanjs/soybean-admin/compare/v1.1.4...v1.1.5) (2024-06-06) | ||||||
|  |  | ||||||
| ###    🐞 错误修复 | ###    🐞 错误修复 | ||||||
|   | |||||||
| @@ -11,6 +11,9 @@ | |||||||
| [](https://github.com/soybeanjs/soybean-admin) | [](https://github.com/soybeanjs/soybean-admin) | ||||||
| [](https://gitee.com/honghuangdc/soybean-admin) | [](https://gitee.com/honghuangdc/soybean-admin) | ||||||
|  |  | ||||||
|  | <a href="https://hellogithub.com/repository/1298f27d5fe54959a16cf9686516ddb3" target="_blank"><img src="https://abroad.hellogithub.com/v1/widgets/recommend.svg?rid=1298f27d5fe54959a16cf9686516ddb3&claim_uid=IiDXWmP4TEntjbV" alt="Featured|HelloGitHub" style="width: 250px; height: 54px;" width="250" height="54" /></a> | ||||||
|  |  | ||||||
|  |  | ||||||
| > [!NOTE] | > [!NOTE] | ||||||
| > If you think `SoybeanAdmin` is helpful to you, or you like our project, please give us a ⭐️ on GitHub. Your support is the driving force for us to continue to improve and add new features! Thank you for your support! | > If you think `SoybeanAdmin` is helpful to you, or you like our project, please give us a ⭐️ on GitHub. Your support is the driving force for us to continue to improve and add new features! Thank you for your support! | ||||||
|  |  | ||||||
| @@ -154,10 +157,10 @@ Thanks the following people for their contributions. If you want to contribute t | |||||||
|   	<p>QQ Group</p> |   	<p>QQ Group</p> | ||||||
|     <img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/qq-soybean-admin-2.jpg" style="width:200px" /> |     <img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/qq-soybean-admin-2.jpg" style="width:200px" /> | ||||||
|   </div> |   </div> | ||||||
| 	<!-- <div> | 	<div> | ||||||
| 		<p>WeChat Group</p> | 		<p>WeChat Group</p> | ||||||
| 		<img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/wechat-0402.jpg" style="width:200px" /> | 		<img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/picgo/soybean-admin-wechat-0620.jpg" style="width:200px" /> | ||||||
| 	</div> --> | 	</div> | ||||||
| 	<div> | 	<div> | ||||||
| 		<p>Add the following WeChat to invite to the WeChat group</p> | 		<p>Add the following WeChat to invite to the WeChat group</p> | ||||||
| 		<img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/wechat-soybeanjs.jpg" style="width:200px" /> | 		<img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/wechat-soybeanjs.jpg" style="width:200px" /> | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| <div align="center"> | <div align="center"> | ||||||
| 	<img src="./public/favicon.svg" width="160" /> | 	<img src="./public/favicon.svg" width="160" /> | ||||||
| 	<h1>SoybeanAdmin</h1> | 	<h1>SoybeanAdmin</h1> | ||||||
|   <span><a href="./README.zh_CN.md">English</a> | 中文</span> |   <span><a href="./README.md">English</a> | 中文</span> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
| --- | --- | ||||||
| @@ -11,6 +11,8 @@ | |||||||
| [](https://github.com/soybeanjs/soybean-admin) | [](https://github.com/soybeanjs/soybean-admin) | ||||||
| [](https://gitee.com/honghuangdc/soybean-admin) | [](https://gitee.com/honghuangdc/soybean-admin) | ||||||
|  |  | ||||||
|  | <a href="https://hellogithub.com/repository/1298f27d5fe54959a16cf9686516ddb3" target="_blank"><img src="https://abroad.hellogithub.com/v1/widgets/recommend.svg?rid=1298f27d5fe54959a16cf9686516ddb3&claim_uid=IiDXWmP4TEntjbV" alt="Featured|HelloGitHub" style="width: 250px; height: 54px;" width="250" height="54" /></a> | ||||||
|  |  | ||||||
| > [!NOTE] | > [!NOTE] | ||||||
| > 如果您觉得 `SoybeanAdmin`对您有所帮助,或者您喜欢我们的项目,请在 GitHub 上给我们一个 ⭐️。您的支持是我们持续改进和增加新功能的动力!感谢您的支持! | > 如果您觉得 `SoybeanAdmin`对您有所帮助,或者您喜欢我们的项目,请在 GitHub 上给我们一个 ⭐️。您的支持是我们持续改进和增加新功能的动力!感谢您的支持! | ||||||
|  |  | ||||||
| @@ -155,10 +157,10 @@ pnpm build | |||||||
|   	<p>QQ交流群</p> |   	<p>QQ交流群</p> | ||||||
|     <img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/qq-soybean-admin-2.jpg" style="width:200px" /> |     <img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/qq-soybean-admin-2.jpg" style="width:200px" /> | ||||||
|   </div> |   </div> | ||||||
| 	<!-- <div> | 	<div> | ||||||
| 		<p>微信群</p> | 		<p>微信群</p> | ||||||
| 		<img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/wechat-0402.jpg" style="width:200px" /> | 		<img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/picgo/soybean-admin-wechat-0620.jpg" style="width:200px" /> | ||||||
| 	</div> --> | 	</div> | ||||||
| 	<div> | 	<div> | ||||||
| 		<p>添加下面微信邀请进微信群</p> | 		<p>添加下面微信邀请进微信群</p> | ||||||
| 		<img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/wechat-soybeanjs.jpg" style="width:200px" /> | 		<img src="https://soybeanjs-1300612522.cos.ap-guangzhou.myqcloud.com/uPic/wechat-soybeanjs.jpg" style="width:200px" /> | ||||||
|   | |||||||
| @@ -1 +1,2 @@ | |||||||
| export * from './proxy'; | export * from './proxy'; | ||||||
|  | export * from './time'; | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								build/config/time.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								build/config/time.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | import dayjs from 'dayjs'; | ||||||
|  | import utc from 'dayjs/plugin/utc'; | ||||||
|  | import timezone from 'dayjs/plugin/timezone'; | ||||||
|  |  | ||||||
|  | export function getBuildTime() { | ||||||
|  |   dayjs.extend(utc); | ||||||
|  |   dayjs.extend(timezone); | ||||||
|  |  | ||||||
|  |   const buildTime = dayjs.tz(Date.now(), 'Asia/Shanghai').format('YYYY-MM-DD HH:mm:ss'); | ||||||
|  |  | ||||||
|  |   return buildTime; | ||||||
|  | } | ||||||
| @@ -4,6 +4,7 @@ | |||||||
|     <meta charset="UTF-8" /> |     <meta charset="UTF-8" /> | ||||||
|     <link rel="icon" href="/favicon.svg" /> |     <link rel="icon" href="/favicon.svg" /> | ||||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0" /> |     <meta name="viewport" content="width=device-width, initial-scale=1.0" /> | ||||||
|  |     <meta name="color-scheme" content="light dark" /> | ||||||
|     <title>%VITE_APP_TITLE%</title> |     <title>%VITE_APP_TITLE%</title> | ||||||
|   </head> |   </head> | ||||||
|   <body> |   <body> | ||||||
|   | |||||||
							
								
								
									
										32
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | |||||||
| { | { | ||||||
|   "name": "soybean-admin", |   "name": "soybean-admin", | ||||||
|   "type": "module", |   "type": "module", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "description": "A fresh and elegant admin template, based on Vue3、Vite3、TypeScript、NaiveUI and UnoCSS. 一个基于Vue3、Vite3、TypeScript、NaiveUI and UnoCSS的清新优雅的中后台模版。", |   "description": "A fresh and elegant admin template, based on Vue3、Vite3、TypeScript、NaiveUI and UnoCSS. 一个基于Vue3、Vite3、TypeScript、NaiveUI and UnoCSS的清新优雅的中后台模版。", | ||||||
|   "author": { |   "author": { | ||||||
|     "name": "Soybean", |     "name": "Soybean", | ||||||
| @@ -53,7 +53,7 @@ | |||||||
|     "@sa/hooks": "workspace:*", |     "@sa/hooks": "workspace:*", | ||||||
|     "@sa/materials": "workspace:*", |     "@sa/materials": "workspace:*", | ||||||
|     "@sa/utils": "workspace:*", |     "@sa/utils": "workspace:*", | ||||||
|     "@vueuse/core": "10.10.0", |     "@vueuse/core": "10.11.0", | ||||||
|     "clipboard": "2.0.11", |     "clipboard": "2.0.11", | ||||||
|     "dayjs": "1.11.11", |     "dayjs": "1.11.11", | ||||||
|     "echarts": "5.5.0", |     "echarts": "5.5.0", | ||||||
| @@ -61,44 +61,44 @@ | |||||||
|     "naive-ui": "2.38.2", |     "naive-ui": "2.38.2", | ||||||
|     "nprogress": "0.2.0", |     "nprogress": "0.2.0", | ||||||
|     "pinia": "2.1.7", |     "pinia": "2.1.7", | ||||||
|     "tailwind-merge": "^2.3.0", |     "tailwind-merge": "2.3.0", | ||||||
|     "vue": "3.4.27", |     "vue": "3.4.27", | ||||||
|     "vue-draggable-plus": "0.5.0", |     "vue-draggable-plus": "0.5.0", | ||||||
|     "vue-i18n": "9.13.1", |     "vue-i18n": "9.13.1", | ||||||
|     "vue-router": "4.3.2" |     "vue-router": "4.3.3" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@elegant-router/vue": "0.3.7", |     "@elegant-router/vue": "0.3.7", | ||||||
|     "@iconify/json": "2.2.216", |     "@iconify/json": "2.2.218", | ||||||
|     "@sa/scripts": "workspace:*", |     "@sa/scripts": "workspace:*", | ||||||
|     "@sa/uno-preset": "workspace:*", |     "@sa/uno-preset": "workspace:*", | ||||||
|     "@soybeanjs/eslint-config": "1.3.6", |     "@soybeanjs/eslint-config": "1.3.6", | ||||||
|     "@types/lodash-es": "4.17.12", |     "@types/lodash-es": "4.17.12", | ||||||
|     "@types/node": "20.14.2", |     "@types/node": "20.14.2", | ||||||
|     "@types/nprogress": "0.2.3", |     "@types/nprogress": "0.2.3", | ||||||
|     "@unocss/eslint-config": "0.60.4", |     "@unocss/eslint-config": "0.61.0", | ||||||
|     "@unocss/preset-icons": "0.60.4", |     "@unocss/preset-icons": "0.61.0", | ||||||
|     "@unocss/preset-uno": "0.60.4", |     "@unocss/preset-uno": "0.61.0", | ||||||
|     "@unocss/transformer-directives": "0.60.4", |     "@unocss/transformer-directives": "0.61.0", | ||||||
|     "@unocss/transformer-variant-group": "0.60.4", |     "@unocss/transformer-variant-group": "0.61.0", | ||||||
|     "@unocss/vite": "0.60.4", |     "@unocss/vite": "0.61.0", | ||||||
|     "@vitejs/plugin-vue": "5.0.5", |     "@vitejs/plugin-vue": "5.0.5", | ||||||
|     "@vitejs/plugin-vue-jsx": "4.0.0", |     "@vitejs/plugin-vue-jsx": "4.0.0", | ||||||
|     "eslint": "9.4.0", |     "eslint": "9.4.0", | ||||||
|     "eslint-plugin-vue": "9.26.0", |     "eslint-plugin-vue": "9.26.0", | ||||||
|     "lint-staged": "15.2.5", |     "lint-staged": "15.2.7", | ||||||
|     "sass": "1.77.4", |     "sass": "1.77.5", | ||||||
|     "simple-git-hooks": "2.11.1", |     "simple-git-hooks": "2.11.1", | ||||||
|     "tsx": "4.12.0", |     "tsx": "4.15.4", | ||||||
|     "typescript": "5.4.5", |     "typescript": "5.4.5", | ||||||
|     "unplugin-icons": "0.19.0", |     "unplugin-icons": "0.19.0", | ||||||
|     "unplugin-vue-components": "0.27.0", |     "unplugin-vue-components": "0.27.0", | ||||||
|     "vite": "5.2.12", |     "vite": "5.3.0", | ||||||
|     "vite-plugin-progress": "0.0.7", |     "vite-plugin-progress": "0.0.7", | ||||||
|     "vite-plugin-svg-icons": "2.0.1", |     "vite-plugin-svg-icons": "2.0.1", | ||||||
|     "vite-plugin-vue-devtools": "7.2.1", |     "vite-plugin-vue-devtools": "7.2.1", | ||||||
|     "vue-eslint-parser": "9.4.3", |     "vue-eslint-parser": "9.4.3", | ||||||
|     "vue-tsc": "2.0.19" |     "vue-tsc": "2.0.21" | ||||||
|   }, |   }, | ||||||
|   "simple-git-hooks": { |   "simple-git-hooks": { | ||||||
|     "commit-msg": "pnpm sa git-commit-verify", |     "commit-msg": "pnpm sa git-commit-verify", | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@sa/axios", |   "name": "@sa/axios", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "exports": { |   "exports": { | ||||||
|     ".": "./src/index.ts" |     ".": "./src/index.ts" | ||||||
|   }, |   }, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@sa/color", |   "name": "@sa/color", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "exports": { |   "exports": { | ||||||
|     ".": "./src/index.ts" |     ".": "./src/index.ts" | ||||||
|   }, |   }, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@sa/hooks", |   "name": "@sa/hooks", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "exports": { |   "exports": { | ||||||
|     ".": "./src/index.ts" |     ".": "./src/index.ts" | ||||||
|   }, |   }, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@sa/materials", |   "name": "@sa/materials", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "exports": { |   "exports": { | ||||||
|     ".": "./src/index.ts" |     ".": "./src/index.ts" | ||||||
|   }, |   }, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@sa/fetch", |   "name": "@sa/fetch", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "exports": { |   "exports": { | ||||||
|     ".": "./src/index.ts" |     ".": "./src/index.ts" | ||||||
|   }, |   }, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@sa/scripts", |   "name": "@sa/scripts", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "bin": { |   "bin": { | ||||||
|     "sa": "./bin.ts" |     "sa": "./bin.ts" | ||||||
|   }, |   }, | ||||||
| @@ -19,7 +19,7 @@ | |||||||
|     "cac": "6.7.14", |     "cac": "6.7.14", | ||||||
|     "consola": "3.2.3", |     "consola": "3.2.3", | ||||||
|     "enquirer": "2.4.1", |     "enquirer": "2.4.1", | ||||||
|     "execa": "9.1.0", |     "execa": "9.2.0", | ||||||
|     "kolorist": "1.8.0", |     "kolorist": "1.8.0", | ||||||
|     "npm-check-updates": "16.14.20", |     "npm-check-updates": "16.14.20", | ||||||
|     "rimraf": "5.0.7" |     "rimraf": "5.0.7" | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@sa/uno-preset", |   "name": "@sa/uno-preset", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "exports": { |   "exports": { | ||||||
|     ".": "./src/index.ts" |     ".": "./src/index.ts" | ||||||
|   }, |   }, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@sa/utils", |   "name": "@sa/utils", | ||||||
|   "version": "1.2.0", |   "version": "1.2.4", | ||||||
|   "exports": { |   "exports": { | ||||||
|     ".": "./src/index.ts" |     ".": "./src/index.ts" | ||||||
|   }, |   }, | ||||||
|   | |||||||
							
								
								
									
										762
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										762
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -41,6 +41,7 @@ const icon = computed(() => { | |||||||
|  |  | ||||||
| <template> | <template> | ||||||
|   <ButtonIcon |   <ButtonIcon | ||||||
|  |     :key="String(collapsed)" | ||||||
|     :tooltip-content="collapsed ? $t('icon.expand') : $t('icon.collapse')" |     :tooltip-content="collapsed ? $t('icon.expand') : $t('icon.collapse')" | ||||||
|     tooltip-placement="bottom-start" |     tooltip-placement="bottom-start" | ||||||
|     :z-index="zIndex" |     :z-index="zIndex" | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| <script setup lang="ts"> | <script setup lang="ts"> | ||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  | import { LAYOUT_SCROLL_EL_ID } from '@sa/materials'; | ||||||
| import { useAppStore } from '@/store/modules/app'; | import { useAppStore } from '@/store/modules/app'; | ||||||
| import { useThemeStore } from '@/store/modules/theme'; | import { useThemeStore } from '@/store/modules/theme'; | ||||||
| import { useRouteStore } from '@/store/modules/route'; | import { useRouteStore } from '@/store/modules/route'; | ||||||
| @@ -24,6 +25,12 @@ const routeStore = useRouteStore(); | |||||||
| const tabStore = useTabStore(); | const tabStore = useTabStore(); | ||||||
|  |  | ||||||
| const transitionName = computed(() => (themeStore.page.animate ? themeStore.page.animateMode : '')); | const transitionName = computed(() => (themeStore.page.animate ? themeStore.page.animateMode : '')); | ||||||
|  |  | ||||||
|  | function resetScroll() { | ||||||
|  |   const el = document.querySelector(`#${LAYOUT_SCROLL_EL_ID}`); | ||||||
|  |  | ||||||
|  |   el?.scrollTo({ left: 0, top: 0 }); | ||||||
|  | } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <template> | <template> | ||||||
| @@ -32,6 +39,7 @@ const transitionName = computed(() => (themeStore.page.animate ? themeStore.page | |||||||
|       :name="transitionName" |       :name="transitionName" | ||||||
|       mode="out-in" |       mode="out-in" | ||||||
|       @before-leave="appStore.setContentXScrollable(true)" |       @before-leave="appStore.setContentXScrollable(true)" | ||||||
|  |       @after-leave="resetScroll" | ||||||
|       @after-enter="appStore.setContentXScrollable(false)" |       @after-enter="appStore.setContentXScrollable(false)" | ||||||
|     > |     > | ||||||
|       <KeepAlive :include="routeStore.cacheRoutes"> |       <KeepAlive :include="routeStore.cacheRoutes"> | ||||||
|   | |||||||
| @@ -3,10 +3,18 @@ import { NButton } from 'naive-ui'; | |||||||
| import { $t } from '../locales'; | import { $t } from '../locales'; | ||||||
|  |  | ||||||
| export function setupAppVersionNotification() { | export function setupAppVersionNotification() { | ||||||
|  |   let isShow = false; | ||||||
|  |  | ||||||
|   document.addEventListener('visibilitychange', async () => { |   document.addEventListener('visibilitychange', async () => { | ||||||
|  |     const preConditions = [!isShow, document.visibilityState === 'visible', !import.meta.env.DEV]; | ||||||
|  |  | ||||||
|  |     if (!preConditions.every(Boolean)) return; | ||||||
|  |  | ||||||
|     const buildTime = await getHtmlBuildTime(); |     const buildTime = await getHtmlBuildTime(); | ||||||
|  |  | ||||||
|     if (buildTime !== BUILD_TIME && document.visibilityState === 'visible') { |     if (buildTime !== BUILD_TIME) { | ||||||
|  |       isShow = true; | ||||||
|  |  | ||||||
|       const n = window.$notification?.create({ |       const n = window.$notification?.create({ | ||||||
|         title: $t('system.updateTitle'), |         title: $t('system.updateTitle'), | ||||||
|         content: $t('system.updateContent'), |         content: $t('system.updateContent'), | ||||||
| @@ -19,7 +27,7 @@ export function setupAppVersionNotification() { | |||||||
|                   n?.destroy(); |                   n?.destroy(); | ||||||
|                 } |                 } | ||||||
|               }, |               }, | ||||||
|               $t('system.updateCancel') |               () => $t('system.updateCancel') | ||||||
|             ), |             ), | ||||||
|             h( |             h( | ||||||
|               NButton, |               NButton, | ||||||
| @@ -29,9 +37,12 @@ export function setupAppVersionNotification() { | |||||||
|                   location.reload(); |                   location.reload(); | ||||||
|                 } |                 } | ||||||
|               }, |               }, | ||||||
|               $t('system.updateConfirm') |               () => $t('system.updateConfirm') | ||||||
|             ) |             ) | ||||||
|           ]); |           ]); | ||||||
|  |         }, | ||||||
|  |         onClose() { | ||||||
|  |           isShow = false; | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -126,9 +126,6 @@ async function initRoute(to: RouteLocationNormalized): Promise<RouteLocationRaw | |||||||
|   // the auth route is initialized |   // the auth route is initialized | ||||||
|   // it is not the "not-found" route, then it is allowed to access |   // it is not the "not-found" route, then it is allowed to access | ||||||
|   if (routeStore.isInitAuthRoute && !isNotFoundRoute) { |   if (routeStore.isInitAuthRoute && !isNotFoundRoute) { | ||||||
|     // update user info |  | ||||||
|     await authStore.updateUserInfo(); |  | ||||||
|  |  | ||||||
|     return null; |     return null; | ||||||
|   } |   } | ||||||
|   // it is captured by the "not-found" route, then check whether the route exists |   // it is captured by the "not-found" route, then check whether the route exists | ||||||
| @@ -164,6 +161,8 @@ async function initRoute(to: RouteLocationNormalized): Promise<RouteLocationRaw | |||||||
|     return location; |     return location; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   await authStore.initUserInfo(); | ||||||
|  |  | ||||||
|   // initialize the auth route |   // initialize the auth route | ||||||
|   await routeStore.initAuthRoute(); |   await routeStore.initAuthRoute(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -92,8 +92,8 @@ export const useAuthStore = defineStore(SetupStoreId.Auth, () => { | |||||||
|     localStg.set('token', loginToken.token); |     localStg.set('token', loginToken.token); | ||||||
|     localStg.set('refreshToken', loginToken.refreshToken); |     localStg.set('refreshToken', loginToken.refreshToken); | ||||||
|  |  | ||||||
|     // 2. get user info and update store |     // 2. get user info | ||||||
|     const pass = await updateUserInfo(); |     const pass = await getUserInfo(); | ||||||
|  |  | ||||||
|     if (pass) { |     if (pass) { | ||||||
|       token.value = loginToken.token; |       token.value = loginToken.token; | ||||||
| @@ -104,7 +104,7 @@ export const useAuthStore = defineStore(SetupStoreId.Auth, () => { | |||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   async function updateUserInfo() { |   async function getUserInfo() { | ||||||
|     const { data: info, error } = await fetchGetUserInfo(); |     const { data: info, error } = await fetchGetUserInfo(); | ||||||
|  |  | ||||||
|     if (!error) { |     if (!error) { | ||||||
| @@ -117,6 +117,18 @@ export const useAuthStore = defineStore(SetupStoreId.Auth, () => { | |||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   async function initUserInfo() { | ||||||
|  |     const hasToken = getToken(); | ||||||
|  |  | ||||||
|  |     if (hasToken) { | ||||||
|  |       const pass = await getUserInfo(); | ||||||
|  |  | ||||||
|  |       if (!pass) { | ||||||
|  |         resetStore(); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|   return { |   return { | ||||||
|     token, |     token, | ||||||
|     userInfo, |     userInfo, | ||||||
| @@ -125,6 +137,6 @@ export const useAuthStore = defineStore(SetupStoreId.Auth, () => { | |||||||
|     loginLoading, |     loginLoading, | ||||||
|     resetStore, |     resetStore, | ||||||
|     login, |     login, | ||||||
|     updateUserInfo |     initUserInfo | ||||||
|   }; |   }; | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ export function getLayoutAndPage(component?: string | null) { | |||||||
|   let layout = ''; |   let layout = ''; | ||||||
|   let page = ''; |   let page = ''; | ||||||
|  |  | ||||||
|   const [layoutOrPage, pageItem] = component?.split(FIRST_LEVEL_ROUTE_COMPONENT_SPLIT) || []; |   const [layoutOrPage = '', pageItem = ''] = component?.split(FIRST_LEVEL_ROUTE_COMPONENT_SPLIT) || []; | ||||||
|  |  | ||||||
|   layout = getLayout(layoutOrPage); |   layout = getLayout(layoutOrPage); | ||||||
|   page = getPage(pageItem || layoutOrPage); |   page = getPage(pageItem || layoutOrPage); | ||||||
|   | |||||||
| @@ -1,14 +1,13 @@ | |||||||
| import process from 'node:process'; | import process from 'node:process'; | ||||||
| import { URL, fileURLToPath } from 'node:url'; | import { URL, fileURLToPath } from 'node:url'; | ||||||
| import { defineConfig, loadEnv } from 'vite'; | import { defineConfig, loadEnv } from 'vite'; | ||||||
| import dayjs from 'dayjs'; |  | ||||||
| import { setupVitePlugins } from './build/plugins'; | import { setupVitePlugins } from './build/plugins'; | ||||||
| import { createViteProxy } from './build/config'; | import { createViteProxy, getBuildTime } from './build/config'; | ||||||
|  |  | ||||||
| export default defineConfig(configEnv => { | export default defineConfig(configEnv => { | ||||||
|   const viteEnv = loadEnv(configEnv.mode, process.cwd()) as unknown as Env.ImportMeta; |   const viteEnv = loadEnv(configEnv.mode, process.cwd()) as unknown as Env.ImportMeta; | ||||||
|  |  | ||||||
|   const buildTime = dayjs().format('YYYY-MM-DD HH:mm:ss'); |   const buildTime = getBuildTime(); | ||||||
|  |  | ||||||
|   return { |   return { | ||||||
|     base: viteEnv.VITE_BASE_URL, |     base: viteEnv.VITE_BASE_URL, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user