mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-31 10:37:11 -04:00 
			
		
		
		
	fix(web): Timeline narrow date groups style (#2713)
* Truncate date group title * Precalculate justified layout width * Add title to date group title to show when truncated --------- Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
This commit is contained in:
		
							parent
							
								
									9cdec62918
								
							
						
					
					
						commit
						053a0482b4
					
				| @ -66,7 +66,7 @@ | ||||
| 	<div | ||||
| 		style:width="{width}px" | ||||
| 		style:height="{height}px" | ||||
| 		class="relative group {disabled | ||||
| 		class="relative group overflow-hidden {disabled | ||||
| 			? 'bg-gray-300' | ||||
| 			: 'bg-immich-primary/20 dark:bg-immich-dark-primary/20'}" | ||||
| 		class:cursor-not-allowed={disabled} | ||||
|  | ||||
| @ -52,15 +52,17 @@ | ||||
| 	$: geometry = (() => { | ||||
| 		const geometry = []; | ||||
| 		for (let group of assetsGroupByDate) { | ||||
| 			geometry.push( | ||||
| 				justifiedLayout(group.map(getAssetRatio), { | ||||
| 					boxSpacing: 2, | ||||
| 					containerWidth: Math.floor(viewportWidth), | ||||
| 					containerPadding: 0, | ||||
| 					targetRowHeightTolerance: 0.15, | ||||
| 					targetRowHeight: 235 | ||||
| 				}) | ||||
| 			); | ||||
| 			const justifiedLayoutResult = justifiedLayout(group.map(getAssetRatio), { | ||||
| 				boxSpacing: 2, | ||||
| 				containerWidth: Math.floor(viewportWidth), | ||||
| 				containerPadding: 0, | ||||
| 				targetRowHeightTolerance: 0.15, | ||||
| 				targetRowHeight: 235 | ||||
| 			}); | ||||
| 			geometry.push({ | ||||
| 				...justifiedLayoutResult, | ||||
| 				containerWidth: calculateWidth(justifiedLayoutResult.boxes) | ||||
| 			}); | ||||
| 		} | ||||
| 		return geometry; | ||||
| 	})(); | ||||
| @ -182,6 +184,7 @@ | ||||
| 			<!-- Date group title --> | ||||
| 			<p | ||||
| 				class="font-medium text-xs md:text-sm text-immich-fg dark:text-immich-dark-fg mb-2 flex place-items-center h-6" | ||||
| 				style="width: {geometry[groupIndex].containerWidth}px" | ||||
| 			> | ||||
| 				{#if (hoveredDateGroup == dateGroupTitle && isMouseOverGroup) || $selectedGroup.has(dateGroupTitle)} | ||||
| 					<div | ||||
| @ -198,7 +201,7 @@ | ||||
| 					</div> | ||||
| 				{/if} | ||||
| 
 | ||||
| 				<span> | ||||
| 				<span class="truncate" title={dateGroupTitle}> | ||||
| 					{dateGroupTitle} | ||||
| 				</span> | ||||
| 			</p> | ||||
| @ -206,9 +209,8 @@ | ||||
| 			<!-- Image grid --> | ||||
| 			<div | ||||
| 				class="relative" | ||||
| 				style="height: {geometry[groupIndex].containerHeight}px;width: {calculateWidth( | ||||
| 					geometry[groupIndex].boxes | ||||
| 				)}px" | ||||
| 				style="height: {geometry[groupIndex].containerHeight}px;width: {geometry[groupIndex] | ||||
| 					.containerWidth}px" | ||||
| 			> | ||||
| 				{#each assetsInDateGroup as asset, index (asset.id)} | ||||
| 					{@const box = geometry[groupIndex].boxes[index]} | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user