mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-25 15:52:33 -04:00 
			
		
		
		
	fix(web): Duplicate arrow shortcuts go to next/previous duplicate when viewing assets (#21200)
- get assetviewer state and don't handle next/previous duplicate if isViewing
This commit is contained in:
		
							parent
							
								
									38a8a67be9
								
							
						
					
					
						commit
						d9d8beb92f
					
				| @ -11,6 +11,7 @@ | |||||||
|   import { AppRoute } from '$lib/constants'; |   import { AppRoute } from '$lib/constants'; | ||||||
|   import DuplicatesInformationModal from '$lib/modals/DuplicatesInformationModal.svelte'; |   import DuplicatesInformationModal from '$lib/modals/DuplicatesInformationModal.svelte'; | ||||||
|   import ShortcutsModal from '$lib/modals/ShortcutsModal.svelte'; |   import ShortcutsModal from '$lib/modals/ShortcutsModal.svelte'; | ||||||
|  |   import { assetViewingStore } from '$lib/stores/asset-viewing.store'; | ||||||
|   import { locale } from '$lib/stores/preferences.store'; |   import { locale } from '$lib/stores/preferences.store'; | ||||||
|   import { featureFlags } from '$lib/stores/server-config.store'; |   import { featureFlags } from '$lib/stores/server-config.store'; | ||||||
|   import { stackAssets } from '$lib/utils/asset-utils'; |   import { stackAssets } from '$lib/utils/asset-utils'; | ||||||
| @ -60,6 +61,7 @@ | |||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   let duplicates = $state(data.duplicates); |   let duplicates = $state(data.duplicates); | ||||||
|  |   const { isViewing: showAssetViewer } = assetViewingStore; | ||||||
| 
 | 
 | ||||||
|   const correctDuplicatesIndex = (index: number) => { |   const correctDuplicatesIndex = (index: number) => { | ||||||
|     return Math.max(0, Math.min(index, duplicates.length - 1)); |     return Math.max(0, Math.min(index, duplicates.length - 1)); | ||||||
| @ -189,9 +191,21 @@ | |||||||
|   const handlePrevious = async () => { |   const handlePrevious = async () => { | ||||||
|     await correctDuplicatesIndexAndGo(Math.max(duplicatesIndex - 1, 0)); |     await correctDuplicatesIndexAndGo(Math.max(duplicatesIndex - 1, 0)); | ||||||
|   }; |   }; | ||||||
|  |   const handlePreviousShortcut = async () => { | ||||||
|  |     if ($showAssetViewer) { | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     await handlePrevious(); | ||||||
|  |   }; | ||||||
|   const handleNext = async () => { |   const handleNext = async () => { | ||||||
|     await correctDuplicatesIndexAndGo(Math.min(duplicatesIndex + 1, duplicates.length - 1)); |     await correctDuplicatesIndexAndGo(Math.min(duplicatesIndex + 1, duplicates.length - 1)); | ||||||
|   }; |   }; | ||||||
|  |   const handleNextShortcut = async () => { | ||||||
|  |     if ($showAssetViewer) { | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     await handleNext(); | ||||||
|  |   }; | ||||||
|   const handleLast = async () => { |   const handleLast = async () => { | ||||||
|     await correctDuplicatesIndexAndGo(duplicates.length - 1); |     await correctDuplicatesIndexAndGo(duplicates.length - 1); | ||||||
|   }; |   }; | ||||||
| @ -203,8 +217,8 @@ | |||||||
| 
 | 
 | ||||||
| <svelte:document | <svelte:document | ||||||
|   use:shortcuts={[ |   use:shortcuts={[ | ||||||
|     { shortcut: { key: 'ArrowLeft' }, onShortcut: handlePrevious }, |     { shortcut: { key: 'ArrowLeft' }, onShortcut: handlePreviousShortcut }, | ||||||
|     { shortcut: { key: 'ArrowRight' }, onShortcut: handleNext }, |     { shortcut: { key: 'ArrowRight' }, onShortcut: handleNextShortcut }, | ||||||
|   ]} |   ]} | ||||||
| /> | /> | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user