1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-22 11:42:46 +01:00

fix(web): use natural asset order for navigation (#3092)

This commit is contained in:
Thomas 2023-07-03 03:02:38 +01:00 committed by GitHub
parent 7947f4db4c
commit 1a0a3aa2c1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -1,6 +1,5 @@
import { AssetGridState, BucketPosition } from '$lib/models/asset-grid-state'; import { AssetGridState, BucketPosition } from '$lib/models/asset-grid-state';
import { api, AssetResponseDto } from '@api'; import { api, AssetResponseDto } from '@api';
import { sortBy } from 'lodash-es';
import { derived, writable } from 'svelte/store'; import { derived, writable } from 'svelte/store';
import { assetGridState, assetStore } from './assets.store'; import { assetGridState, assetStore } from './assets.store';
@ -20,8 +19,6 @@ function createAssetInteractionStore() {
let _selectedAssets: Set<AssetResponseDto>; let _selectedAssets: Set<AssetResponseDto>;
let _selectedGroup: Set<string>; let _selectedGroup: Set<string>;
let _assetsInAlbums: AssetResponseDto[]; let _assetsInAlbums: AssetResponseDto[];
let savedAssetLength = 0;
let assetSortedByDate: AssetResponseDto[] = [];
// Subscriber // Subscriber
assetGridState.subscribe((state) => { assetGridState.subscribe((state) => {
@ -64,40 +61,31 @@ function createAssetInteractionStore() {
}; };
const navigateAsset = async (direction: 'next' | 'previous') => { const navigateAsset = async (direction: 'next' | 'previous') => {
// Flatten and sort the asset by date if there are new assets let index = _assetGridState.assets.findIndex(({ id }) => id === _viewingAssetStoreState.id);
if (assetSortedByDate.length === 0 || savedAssetLength !== _assetGridState.assets.length) {
assetSortedByDate = sortBy(_assetGridState.assets, (a) => a.fileCreatedAt);
savedAssetLength = _assetGridState.assets.length;
}
// Find the index of the current asset index = direction === 'next' ? index + 1 : index - 1;
const currentIndex = assetSortedByDate.findIndex((a) => a.id === _viewingAssetStoreState.id);
// Get the next or previous asset const needMoreAbove = index < 0;
const nextIndex = direction === 'previous' ? currentIndex + 1 : currentIndex - 1; const needMoreBelow = index >= _assetGridState.assets.length;
// Run out of asset, this might be because there is no asset in the next bucket.
if (nextIndex == -1) {
let nextBucket = '';
// Find next bucket that doesn't have all assets loaded
// Try to load more assets if we're at the end.
if (needMoreAbove || needMoreBelow) {
for (const bucket of _assetGridState.buckets) { for (const bucket of _assetGridState.buckets) {
if (bucket.assets.length === 0) { if (bucket.assets.length === 0) {
nextBucket = bucket.bucketDate; await assetStore.getAssetsByBucket(
bucket.bucketDate,
needMoreAbove ? BucketPosition.Above : BucketPosition.Below,
);
navigateAsset(direction);
break; break;
} }
} }
if (nextBucket !== '') {
await assetStore.getAssetsByBucket(nextBucket, BucketPosition.Below);
navigateAsset(direction);
}
return; return;
} }
const nextAsset = assetSortedByDate[nextIndex]; const asset = _assetGridState.assets[index];
if (nextAsset) { if (asset) {
setViewingAsset(nextAsset); setViewingAsset(asset);
} }
}; };