Compare commits
	
		
			4 Commits
		
	
	
		
			198e171838
			...
			7392b61e3e
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 7392b61e3e | |||
| 19d97c947f | |||
| b16c8a91e6 | |||
| 3205bb6dc1 | 
							
								
								
									
										13
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										13
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -29,6 +29,7 @@ | |||||||
| 				"svelte": "^4.0.5", | 				"svelte": "^4.0.5", | ||||||
| 				"svelte-check": "^3.4.3", | 				"svelte-check": "^3.4.3", | ||||||
| 				"svelte-heros-v2": "^0.9.3", | 				"svelte-heros-v2": "^0.9.3", | ||||||
|  | 				"svelte-local-storage-store": "^0.6.0", | ||||||
| 				"svelte-multicssclass": "^2.1.1", | 				"svelte-multicssclass": "^2.1.1", | ||||||
| 				"tailwindcss": "^3.3.3", | 				"tailwindcss": "^3.3.3", | ||||||
| 				"tslib": "^2.4.1", | 				"tslib": "^2.4.1", | ||||||
| @@ -4871,6 +4872,18 @@ | |||||||
| 				"svelte": "^3.19.0 || ^4.0.0-next.0" | 				"svelte": "^3.19.0 || ^4.0.0-next.0" | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
|  | 		"node_modules/svelte-local-storage-store": { | ||||||
|  | 			"version": "0.6.0", | ||||||
|  | 			"resolved": "https://registry.npmjs.org/svelte-local-storage-store/-/svelte-local-storage-store-0.6.0.tgz", | ||||||
|  | 			"integrity": "sha512-UbCY/yT/YUadU5IX/gZkoRQnA+ebFZHKKQjlJvfWHnBj3CPe9sNn8ndxYz/xy4LUzGjuBLq8+wH5RYK54ba3wA==", | ||||||
|  | 			"dev": true, | ||||||
|  | 			"engines": { | ||||||
|  | 				"node": ">=0.14" | ||||||
|  | 			}, | ||||||
|  | 			"peerDependencies": { | ||||||
|  | 				"svelte": "^3.48.0 || ^4.0.0" | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
| 		"node_modules/svelte-multicssclass": { | 		"node_modules/svelte-multicssclass": { | ||||||
| 			"version": "2.1.1", | 			"version": "2.1.1", | ||||||
| 			"resolved": "https://registry.npmjs.org/svelte-multicssclass/-/svelte-multicssclass-2.1.1.tgz", | 			"resolved": "https://registry.npmjs.org/svelte-multicssclass/-/svelte-multicssclass-2.1.1.tgz", | ||||||
|   | |||||||
| @@ -28,6 +28,7 @@ | |||||||
| 		"svelte": "^4.0.5", | 		"svelte": "^4.0.5", | ||||||
| 		"svelte-check": "^3.4.3", | 		"svelte-check": "^3.4.3", | ||||||
| 		"svelte-heros-v2": "^0.9.3", | 		"svelte-heros-v2": "^0.9.3", | ||||||
|  | 		"svelte-local-storage-store": "^0.6.0", | ||||||
| 		"svelte-multicssclass": "^2.1.1", | 		"svelte-multicssclass": "^2.1.1", | ||||||
| 		"tailwindcss": "^3.3.3", | 		"tailwindcss": "^3.3.3", | ||||||
| 		"tslib": "^2.4.1", | 		"tslib": "^2.4.1", | ||||||
|   | |||||||
| @@ -1,5 +1,4 @@ | |||||||
| import { type Writable, writable } from 'svelte/store'; | import { persisted } from 'svelte-local-storage-store'; | ||||||
|  | import type { Writable } from 'svelte/store'; | ||||||
|  |  | ||||||
| export const registered: Writable<{ | export const playAudio: Writable<boolean> = persisted('playAudio', false); | ||||||
| 	username: string; |  | ||||||
| } | null> = writable(null); |  | ||||||
|   | |||||||
| @@ -1,6 +1,9 @@ | |||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| 	import '../app.css'; | 	import '../app.css'; | ||||||
| 	import { env } from '$env/dynamic/public'; | 	import { env } from '$env/dynamic/public'; | ||||||
|  | 	import { goto } from '$app/navigation'; | ||||||
|  | 	import Settings from './Settings.svelte'; | ||||||
|  | 	import { playAudio } from '$lib/stores'; | ||||||
|  |  | ||||||
| 	let navPaths = [ | 	let navPaths = [ | ||||||
| 		{ | 		{ | ||||||
| @@ -28,18 +31,18 @@ | |||||||
| 	function onMenuButtonScroll(e: WheelEvent) { | 	function onMenuButtonScroll(e: WheelEvent) { | ||||||
| 		if (menuButtonScrollIndex == null) { | 		if (menuButtonScrollIndex == null) { | ||||||
| 			if (e.deltaY < 0) { | 			if (e.deltaY < 0) { | ||||||
| 				menuButtonScrollIndex = 0; |  | ||||||
| 			} else if (e.deltaY > 0) { |  | ||||||
| 				menuButtonScrollIndex = navPaths.length - 1; | 				menuButtonScrollIndex = navPaths.length - 1; | ||||||
| 			} else { | 			} else if (e.deltaY > 0) { | ||||||
| 				menuButtonScrollIndex = 0; | 				menuButtonScrollIndex = 0; | ||||||
|  | 			} else { | ||||||
|  | 				menuButtonScrollIndex = navPaths.length - 1; | ||||||
| 			} | 			} | ||||||
| 		} else { | 		} else { | ||||||
| 			navPaths[menuButtonScrollIndex].active = false; | 			navPaths[menuButtonScrollIndex].active = false; | ||||||
|  |  | ||||||
| 			if (e.deltaY < 0) { | 			if (e.deltaY > 0) { | ||||||
| 				menuButtonScrollIndex++; | 				menuButtonScrollIndex++; | ||||||
| 			} else if (e.deltaY > 0) { | 			} else if (e.deltaY < 0) { | ||||||
| 				menuButtonScrollIndex--; | 				menuButtonScrollIndex--; | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| @@ -55,9 +58,20 @@ | |||||||
|  |  | ||||||
| 	let isTouch = false; | 	let isTouch = false; | ||||||
| 	let nav: HTMLDivElement; | 	let nav: HTMLDivElement; | ||||||
|  | 	let settings: HTMLDialogElement; | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <svelte:body | <svelte:body | ||||||
|  | 	on:keyup={(e) => { | ||||||
|  | 		if (e.key === 'Escape') { | ||||||
|  | 			e.preventDefault(); | ||||||
|  | 			if (settings.open) { | ||||||
|  | 				settings.close(); | ||||||
|  | 			} else { | ||||||
|  | 				settings.show(); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}} | ||||||
| 	on:touchend={(e) => { | 	on:touchend={(e) => { | ||||||
| 		// eslint-disable-next-line @typescript-eslint/ban-ts-comment | 		// eslint-disable-next-line @typescript-eslint/ban-ts-comment | ||||||
| 		// @ts-ignore | 		// @ts-ignore | ||||||
| @@ -78,7 +92,17 @@ | |||||||
| 				? 'btn btn-square relative w-16 h-16' | 				? 'btn btn-square relative w-16 h-16' | ||||||
| 				: 'btn btn-square group/menu-button relative w-16 h-16'} | 				: 'btn btn-square group/menu-button relative w-16 h-16'} | ||||||
| 			on:click={() => { | 			on:click={() => { | ||||||
| 				if (!isTouch) showMenuPermanent = !showMenuPermanent; | 				if (!isTouch) { | ||||||
|  | 					let activePath = navPaths.find((path) => path.active); | ||||||
|  | 					if (activePath !== undefined) { | ||||||
|  | 						goto(activePath.href); | ||||||
|  | 					} else if ($playAudio) { | ||||||
|  | 						new Audio( | ||||||
|  | 							`${env.PUBLIC_BASE_PATH}/aud/chest-${showMenuPermanent ? 'close' : 'open'}.mp3` | ||||||
|  | 						).play(); | ||||||
|  | 					} | ||||||
|  | 					showMenuPermanent = !showMenuPermanent; | ||||||
|  | 				} | ||||||
| 			}} | 			}} | ||||||
| 			on:touchend={() => { | 			on:touchend={() => { | ||||||
| 				isTouch = true; | 				isTouch = true; | ||||||
| @@ -127,7 +151,7 @@ | |||||||
| 								<img class="w-1/2 h-1/2 pixelated" src={navPath.sprite} alt={navPath.name} /> | 								<img class="w-1/2 h-1/2 pixelated" src={navPath.sprite} alt={navPath.name} /> | ||||||
| 							</div> | 							</div> | ||||||
| 							<img | 							<img | ||||||
| 								class="transition-opacity delay-50 group-hover/menu-item:opacity-100 absolute w-full h-full pixelated scale-110" | 								class="transition-opacity delay-50 group-hover/menu-item:opacity-100 absolute w-full h-full pixelated scale-110 z-10" | ||||||
| 								class:opacity-0={!navPath.active} | 								class:opacity-0={!navPath.active} | ||||||
| 								src="{env.PUBLIC_BASE_PATH}/img/selected-frame.png" | 								src="{env.PUBLIC_BASE_PATH}/img/selected-frame.png" | ||||||
| 								alt="menu hover" | 								alt="menu hover" | ||||||
| @@ -139,3 +163,13 @@ | |||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
| </nav> | </nav> | ||||||
|  |  | ||||||
|  | <dialog class="modal" bind:this={settings}> | ||||||
|  | 	<form method="dialog" class="modal-box" style="overflow: unset"> | ||||||
|  | 		<button class="btn btn-sm btn-circle btn-ghost absolute right-2 top-2">✕</button> | ||||||
|  | 		<Settings /> | ||||||
|  | 	</form> | ||||||
|  | 	<form method="dialog" class="modal-backdrop bg-[rgba(0,0,0,.3)]"> | ||||||
|  | 		<button>close</button> | ||||||
|  | 	</form> | ||||||
|  | </dialog> | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								src/routes/Settings.svelte
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								src/routes/Settings.svelte
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | <script lang="ts"> | ||||||
|  | 	import { playAudio } from '$lib/stores'; | ||||||
|  | 	import { get } from 'svelte/store'; | ||||||
|  | 	import { IconOutline } from 'svelte-heros-v2'; | ||||||
|  |  | ||||||
|  | 	let settings = [ | ||||||
|  | 		{ | ||||||
|  | 			name: 'Sound abspielen', | ||||||
|  | 			description: | ||||||
|  | 				'Manche Elemente können Sounds abspielen. Aktiviere diese Option und finde raus welche', | ||||||
|  | 			store: playAudio | ||||||
|  | 		} | ||||||
|  | 	]; | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <div> | ||||||
|  | 	<h2 class="text-2xl">Einstellungen</h2> | ||||||
|  | 	<div> | ||||||
|  | 		<div class="divider" /> | ||||||
|  | 		<div class="grid grid-cols-2"> | ||||||
|  | 			{#each settings as setting} | ||||||
|  | 				<div class="flex"> | ||||||
|  | 					<p>{setting.name}</p> | ||||||
|  | 					<span class="tooltip ml-[0.2rem] -mt-[1px]" data-tip={setting.description}> | ||||||
|  | 						<IconOutline name="question-mark-circle-outline" width="16" height="16" /> | ||||||
|  | 					</span> | ||||||
|  | 				</div> | ||||||
|  | 				<input | ||||||
|  | 					type="checkbox" | ||||||
|  | 					class="toggle justify-self-end mr-6" | ||||||
|  | 					checked={get(setting.store)} | ||||||
|  | 					on:change={(e) => { | ||||||
|  | 						// eslint-disable-next-line @typescript-eslint/ban-ts-comment | ||||||
|  | 						// @ts-ignore | ||||||
|  | 						setting.store.set(e.target.checked); | ||||||
|  | 					}} | ||||||
|  | 				/> | ||||||
|  | 			{/each} | ||||||
|  | 		</div> | ||||||
|  | 		<div class="divider" /> | ||||||
|  | 	</div> | ||||||
|  | </div> | ||||||
							
								
								
									
										
											BIN
										
									
								
								static/aud/chest-close.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/aud/chest-close.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								static/aud/chest-open.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/aud/chest-open.mp3
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
		Reference in New Issue
	
	Block a user