mirror of
				https://github.com/Investigamer/cardconjurer.git
				synced 2025-10-26 04:40:41 -05:00 
			
		
		
		
	theme editor
This commit is contained in:
		
							
								
								
									
										20
									
								
								js/themeEditor.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								js/themeEditor.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| document.querySelector('#hue-rotate').value = theme.huerotate; | ||||
| document.querySelector('#hue-rotate-auto').value = theme.rainbow; | ||||
| document.querySelector('#readable-brightness').value = theme.readablebrightness; | ||||
|  | ||||
| var updateCSSTimer; | ||||
| var canUpdateCSS = true; | ||||
|  | ||||
| function changeThemeVar(input, destination) { | ||||
| 	theme[destination] = input; | ||||
| 	localStorage.setItem('theme', JSON.stringify(theme)); | ||||
| 	// if (canUpdateCSS) { | ||||
| 		updateCSS(); | ||||
| 	// 	canUpdateCSS = false; | ||||
| 	// 	updateCSSTimer = setTimeout(resetCSSTimer, 50); | ||||
| 	// } | ||||
| } | ||||
|  | ||||
| function resetCSSTimer() { | ||||
| 	canUpdateCSS = true; | ||||
| } | ||||
							
								
								
									
										44
									
								
								js/themes.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								js/themes.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| var theme, rainbowTimer; | ||||
| const root = document.documentElement.style; | ||||
|  | ||||
| if (localStorage.getItem('theme')) { | ||||
| 	theme = JSON.parse(localStorage.getItem('theme')); | ||||
| 	updateCSS(); | ||||
| } else { | ||||
| 	resetTheme(); | ||||
| } | ||||
|  | ||||
| function updateCSS() { | ||||
| 	if (!root.getPropertyValue('--site-background').includes(theme.background)) { | ||||
| 		root.setProperty('--site-background', 'url("' + (theme.background || '/img/lowpolyBackground.svg') + '")'); | ||||
| 	} | ||||
| 	// root.setProperty("--color-primary", theme.SOMETHING); | ||||
| 	// root.setProperty("--color-selected", theme.SOMETHING); | ||||
| 	// root.setProperty("--color-highlighted", theme.SOMETHING); | ||||
| 	// root.setProperty("--font-color", theme.SOMETHING); | ||||
| 	// root.setProperty("--font-color-2", theme.SOMETHING); | ||||
| 	// root.setProperty("--input-background", theme.SOMETHING); | ||||
| 	// root.setProperty("--input-background-selected", theme.SOMETHING); | ||||
| 	if (theme.rainbow > 0) { | ||||
| 		clearInterval(rainbowTimer); | ||||
| 		rainbowTimer = setInterval(rainbowMode, (theme.rainbow)); | ||||
| 	} else { | ||||
| 		clearInterval(rainbowTimer); | ||||
| 		root.setProperty('--regular-backdrop-filter', 'hue-rotate(' + (theme.huerotate || 0) + 'deg)'); | ||||
| 	} | ||||
| 	root.setProperty('--darkened-backdrop-filter', 'grayscale(1) brightness(' + (theme.readablebrightness || 0) + ')'); | ||||
| } | ||||
|  | ||||
| function rainbowMode() { | ||||
| 	theme.huerotate += 1; | ||||
| 	if (theme.huerotate >= 360) { | ||||
| 		theme.huerotate = 0 | ||||
| 	} | ||||
| 	root.setProperty('--regular-backdrop-filter', 'hue-rotate(' + theme.huerotate + 'deg)'); | ||||
| } | ||||
|  | ||||
| function resetTheme() { | ||||
| 	theme = {huerotate:0, background:'/img/lowpolyBackground.svg', readablebrightness:0.3, rainbow:0}; | ||||
| 	localStorage.setItem('theme', JSON.stringify(theme)); | ||||
| 	updateCSS(); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Kyle
					Kyle