mirror of
				https://ghproxy.com/https://github.com/StreakingMan/solvable-sheep-game
				synced 2025-10-26 05:26:07 +08:00 
			
		
		
		
	feat: 根据路径区分主题
This commit is contained in:
		
							parent
							
								
									982a2bd342
								
							
						
					
					
						commit
						b687d53733
					
				|  | @ -24,5 +24,6 @@ module.exports = { | ||||||
|     ], |     ], | ||||||
|     rules: { |     rules: { | ||||||
|         'prettier/prettier': 'error', |         'prettier/prettier': 'error', | ||||||
|  |         '@typescript-eslint/no-explicit-any': 0, | ||||||
|     }, |     }, | ||||||
| }; | }; | ||||||
|  |  | ||||||
							
								
								
									
										28
									
								
								src/App.tsx
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								src/App.tsx
									
									
									
									
									
								
							|  | @ -7,20 +7,20 @@ import React, { | ||||||
| } from 'react'; | } from 'react'; | ||||||
| 
 | 
 | ||||||
| import './App.css'; | import './App.css'; | ||||||
| import { GithubIcon } from './GithubIcon'; | import { GithubIcon } from './components/GithubIcon'; | ||||||
| import { randomString, waitTimeout } from './utils'; | import { parseThemePath, randomString, waitTimeout } from './utils'; | ||||||
| import { defaultTheme } from './themes/default'; | import { defaultTheme } from './themes/default'; | ||||||
| import { Icon, Theme } from './themes/interface'; | import { Icon, Theme } from './themes/interface'; | ||||||
| import { fishermanTheme } from './themes/fisherman'; | import { fishermanTheme } from './themes/fisherman'; | ||||||
| import { jinlunTheme } from './themes/jinlun'; | import { jinlunTheme } from './themes/jinlun'; | ||||||
| import { ikunTheme } from './themes/ikun'; | import { ikunTheme } from './themes/ikun'; | ||||||
| import { pddTheme } from './themes/pdd'; | import { pddTheme } from './themes/pdd'; | ||||||
| import { BeiAn } from './BeiAn'; | import { BeiAn } from './components/BeiAn'; | ||||||
| import { Info } from './Info'; | import { Info } from './components/Info'; | ||||||
| import { owTheme } from './themes/ow'; | import { owTheme } from './themes/ow'; | ||||||
| 
 | 
 | ||||||
| // 主题
 | // 主题
 | ||||||
| const themes = [ | const themes: Theme<any>[] = [ | ||||||
|     defaultTheme, |     defaultTheme, | ||||||
|     fishermanTheme, |     fishermanTheme, | ||||||
|     jinlunTheme, |     jinlunTheme, | ||||||
|  | @ -165,8 +165,14 @@ const Symbol: FC<SymbolProps> = ({ x, y, icon, isCover, status, onClick }) => { | ||||||
|     ); |     ); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | // 从url初始化主题
 | ||||||
|  | const themeFromPath: string = parseThemePath(location.href); | ||||||
|  | 
 | ||||||
| const App: FC = () => { | const App: FC = () => { | ||||||
|     const [curTheme, setCurTheme] = useState<Theme<any>>(defaultTheme); |     const [curTheme, setCurTheme] = useState<Theme<any>>( | ||||||
|  |         themes.find((theme) => theme.name === themeFromPath) ?? defaultTheme | ||||||
|  |     ); | ||||||
|  | 
 | ||||||
|     const [scene, setScene] = useState<Scene>(makeScene(1, curTheme.icons)); |     const [scene, setScene] = useState<Scene>(makeScene(1, curTheme.icons)); | ||||||
|     const [level, setLevel] = useState<number>(1); |     const [level, setLevel] = useState<number>(1); | ||||||
|     const [queue, setQueue] = useState<MySymbol[]>([]); |     const [queue, setQueue] = useState<MySymbol[]>([]); | ||||||
|  | @ -204,6 +210,12 @@ const App: FC = () => { | ||||||
|             }, 300); |             }, 300); | ||||||
|         } |         } | ||||||
|         restart(); |         restart(); | ||||||
|  |         // 更改路径
 | ||||||
|  |         history.pushState( | ||||||
|  |             {}, | ||||||
|  |             curTheme.title, | ||||||
|  |             `/?theme=${encodeURIComponent(curTheme.name)}` | ||||||
|  |         ); | ||||||
|     }, [curTheme]); |     }, [curTheme]); | ||||||
| 
 | 
 | ||||||
|     // 队列区排序
 |     // 队列区排序
 | ||||||
|  | @ -416,7 +428,11 @@ const App: FC = () => { | ||||||
|             </h6> |             </h6> | ||||||
|             <h3 className="flex-container flex-center"> |             <h3 className="flex-container flex-center"> | ||||||
|                 主题: |                 主题: | ||||||
|  |                 {/*TODO themes维护方式调整*/} | ||||||
|                 <select |                 <select | ||||||
|  |                     value={themes.findIndex( | ||||||
|  |                         (theme) => theme.name === curTheme.name | ||||||
|  |                     )} | ||||||
|                     onChange={(e) => |                     onChange={(e) => | ||||||
|                         setCurTheme(themes[Number(e.target.value)]) |                         setCurTheme(themes[Number(e.target.value)]) | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|  | @ -15,3 +15,9 @@ export const waitTimeout: (timeout: number) => Promise<void> = (timeout) => { | ||||||
|         }, timeout); |         }, timeout); | ||||||
|     }); |     }); | ||||||
| }; | }; | ||||||
|  | 
 | ||||||
|  | export const parseThemePath: (url: string) => string = (url) => { | ||||||
|  |     const urlObj = new URL(url); | ||||||
|  |     const params = urlObj.searchParams; | ||||||
|  |     return decodeURIComponent(params.get('theme') || '默认'); | ||||||
|  | }; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 streakingman
						streakingman