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:
parent
7947f4db4c
commit
1a0a3aa2c1
1 changed files with 14 additions and 26 deletions
|
@ -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);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue