mirror of
				https://github.com/immich-app/immich.git
				synced 2025-11-04 03:39:37 -05: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), {
 | 
			
		||||
			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