mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 18:14:50 +00:00 
			
		
		
		
	create theme-switch component
This commit is contained in:
		
							parent
							
								
									dfaa1c969b
								
							
						
					
					
						commit
						f82ea690b9
					
				
					 1 changed files with 58 additions and 0 deletions
				
			
		
							
								
								
									
										58
									
								
								web/html/xui/component/themeSwitch.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								web/html/xui/component/themeSwitch.html
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,58 @@ | |||
| {{define "component/themeSwitchTemplate"}} | ||||
| <template> | ||||
|   <a-switch :default-checked="themeSwitcher.isDarkTheme" | ||||
|             checked-children="☀" | ||||
|             un-checked-children="🌙" | ||||
|             @change="themeSwitcher.toggleTheme()"> | ||||
|   </a-switch> | ||||
| </template> | ||||
| {{end}} | ||||
| 
 | ||||
| {{define "component/themeSwitcher"}} | ||||
| <script> | ||||
|   const colors = { | ||||
|     dark: { | ||||
|       bg: "#242c3a", | ||||
|       text: "hsla(0,0%,100%,.65)" | ||||
|     }, | ||||
|     light: { | ||||
|       bg: '#fff', | ||||
|       text: "rgba(0, 0, 0, 0.7)", | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   function createThemeSwitcher() { | ||||
|     const isDarkTheme = localStorage.getItem('dark-mode') === 'true'; | ||||
|     const theme = isDarkTheme ? 'dark' : 'light'; | ||||
|     return { | ||||
|       isDarkTheme, | ||||
|       bgStyle: `background: ${colors[theme].bg};`, | ||||
|       textStyle: `color: ${colors[theme].text};`, | ||||
|       darkClass: isDarkTheme ? 'ant-card-dark' : '', | ||||
|       darkCardClass: isDarkTheme ? 'ant-card-dark' : '', | ||||
|       darkDrawerClass: isDarkTheme ? 'ant-drawer-dark' : '', | ||||
|       get currentTheme() { | ||||
|         return this.isDarkTheme ? 'dark' : 'light'; | ||||
|       }, | ||||
|       toggleTheme() { | ||||
|         this.isDarkTheme = !this.isDarkTheme; | ||||
|         this.theme = this.isDarkTheme ? 'dark' : 'light'; | ||||
|         localStorage.setItem('dark-mode', this.isDarkTheme); | ||||
|         this.bgStyle = `background: ${colors[this.theme].bg};`; | ||||
|         this.textStyle = `color: ${colors[this.theme].text};`; | ||||
|         this.darkClass = this.isDarkTheme ? 'ant-card-dark' : ''; | ||||
|         this.darkCardClass = this.isDarkTheme ? 'ant-card-dark' : ''; | ||||
|         this.darkDrawerClass = this.isDarkTheme ? 'ant-drawer-dark' : ''; | ||||
|       }, | ||||
|     }; | ||||
|   } | ||||
| 
 | ||||
|   const themeSwitcher = createThemeSwitcher(); | ||||
| 
 | ||||
|   Vue.component('theme-switch', { | ||||
|     props: [], | ||||
|     template: `{{template "component/themeSwitchTemplate"}}`, | ||||
|     data: () => ({ themeSwitcher }), | ||||
|   }); | ||||
| </script> | ||||
| {{end}} | ||||
		Loading…
	
		Reference in a new issue
	
	 Hamidreza Ghavami
						Hamidreza Ghavami