mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 02:46:47 +01:00
fix(web): restore button in asset viewer (#8935)
* fix(web): restore button added to trashed asset-view to restore single item * fixed the asset-viewer menu to update upon restoration * prettier formatting complete, testing passed * chore: clean up --------- Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
This commit is contained in:
parent
171b6bb0a6
commit
3abfe3c99e
4 changed files with 33 additions and 7 deletions
|
@ -20,6 +20,7 @@
|
||||||
mdiFolderDownloadOutline,
|
mdiFolderDownloadOutline,
|
||||||
mdiHeart,
|
mdiHeart,
|
||||||
mdiHeartOutline,
|
mdiHeartOutline,
|
||||||
|
mdiHistory,
|
||||||
mdiImageAlbum,
|
mdiImageAlbum,
|
||||||
mdiImageMinusOutline,
|
mdiImageMinusOutline,
|
||||||
mdiImageOutline,
|
mdiImageOutline,
|
||||||
|
@ -52,6 +53,7 @@
|
||||||
|
|
||||||
type MenuItemEvent =
|
type MenuItemEvent =
|
||||||
| 'addToAlbum'
|
| 'addToAlbum'
|
||||||
|
| 'restoreAsset'
|
||||||
| 'addToSharedAlbum'
|
| 'addToSharedAlbum'
|
||||||
| 'asProfileImage'
|
| 'asProfileImage'
|
||||||
| 'setAsAlbumCover'
|
| 'setAsAlbumCover'
|
||||||
|
@ -70,6 +72,7 @@
|
||||||
delete: void;
|
delete: void;
|
||||||
toggleArchive: void;
|
toggleArchive: void;
|
||||||
addToAlbum: void;
|
addToAlbum: void;
|
||||||
|
restoreAsset: void;
|
||||||
addToSharedAlbum: void;
|
addToSharedAlbum: void;
|
||||||
asProfileImage: void;
|
asProfileImage: void;
|
||||||
setAsAlbumCover: void;
|
setAsAlbumCover: void;
|
||||||
|
@ -208,12 +211,16 @@
|
||||||
{#if showDownloadButton}
|
{#if showDownloadButton}
|
||||||
<MenuOption icon={mdiFolderDownloadOutline} on:click={() => onMenuClick('download')} text="Download" />
|
<MenuOption icon={mdiFolderDownloadOutline} on:click={() => onMenuClick('download')} text="Download" />
|
||||||
{/if}
|
{/if}
|
||||||
|
{#if asset.isTrashed}
|
||||||
|
<MenuOption icon={mdiHistory} on:click={() => onMenuClick('restoreAsset')} text="Restore" />
|
||||||
|
{:else}
|
||||||
<MenuOption icon={mdiImageAlbum} on:click={() => onMenuClick('addToAlbum')} text="Add to album" />
|
<MenuOption icon={mdiImageAlbum} on:click={() => onMenuClick('addToAlbum')} text="Add to album" />
|
||||||
<MenuOption
|
<MenuOption
|
||||||
icon={mdiShareVariantOutline}
|
icon={mdiShareVariantOutline}
|
||||||
on:click={() => onMenuClick('addToSharedAlbum')}
|
on:click={() => onMenuClick('addToSharedAlbum')}
|
||||||
text="Add to shared album"
|
text="Add to shared album"
|
||||||
/>
|
/>
|
||||||
|
{/if}
|
||||||
|
|
||||||
{#if isOwner}
|
{#if isOwner}
|
||||||
{#if hasStackChildren}
|
{#if hasStackChildren}
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
getActivityStatistics,
|
getActivityStatistics,
|
||||||
getAllAlbums,
|
getAllAlbums,
|
||||||
runAssetJobs,
|
runAssetJobs,
|
||||||
|
restoreAssets,
|
||||||
updateAsset,
|
updateAsset,
|
||||||
updateAlbumInfo,
|
updateAlbumInfo,
|
||||||
type ActivityResponseDto,
|
type ActivityResponseDto,
|
||||||
|
@ -403,6 +404,22 @@
|
||||||
await handleGetAllAlbums();
|
await handleGetAllAlbums();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const handleRestoreAsset = async () => {
|
||||||
|
try {
|
||||||
|
await restoreAssets({ bulkIdsDto: { ids: [asset.id] } });
|
||||||
|
asset.isTrashed = false;
|
||||||
|
|
||||||
|
dispatch('action', { type: AssetAction.RESTORE, asset });
|
||||||
|
|
||||||
|
notificationController.show({
|
||||||
|
type: NotificationType.Info,
|
||||||
|
message: `Restored asset`,
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
handleError(error, 'Error restoring asset');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
const toggleArchive = async () => {
|
const toggleArchive = async () => {
|
||||||
try {
|
try {
|
||||||
const data = await updateAsset({
|
const data = await updateAsset({
|
||||||
|
@ -556,6 +573,7 @@
|
||||||
on:delete={() => trashOrDelete()}
|
on:delete={() => trashOrDelete()}
|
||||||
on:favorite={toggleFavorite}
|
on:favorite={toggleFavorite}
|
||||||
on:addToAlbum={() => openAlbumPicker(false)}
|
on:addToAlbum={() => openAlbumPicker(false)}
|
||||||
|
on:restoreAsset={() => handleRestoreAsset()}
|
||||||
on:addToSharedAlbum={() => openAlbumPicker(true)}
|
on:addToSharedAlbum={() => openAlbumPicker(true)}
|
||||||
on:playMotionPhoto={() => (shouldPlayMotionPhoto = true)}
|
on:playMotionPhoto={() => (shouldPlayMotionPhoto = true)}
|
||||||
on:stopMotionPhoto={() => (shouldPlayMotionPhoto = false)}
|
on:stopMotionPhoto={() => (shouldPlayMotionPhoto = false)}
|
||||||
|
|
|
@ -169,6 +169,7 @@
|
||||||
switch (action) {
|
switch (action) {
|
||||||
case removeAction:
|
case removeAction:
|
||||||
case AssetAction.TRASH:
|
case AssetAction.TRASH:
|
||||||
|
case AssetAction.RESTORE:
|
||||||
case AssetAction.DELETE: {
|
case AssetAction.DELETE: {
|
||||||
// find the next asset to show or close the viewer
|
// find the next asset to show or close the viewer
|
||||||
(await handleNext()) || (await handlePrevious()) || handleClose();
|
(await handleNext()) || (await handlePrevious()) || handleClose();
|
||||||
|
|
|
@ -5,7 +5,7 @@ export enum AssetAction {
|
||||||
UNFAVORITE = 'unfavorite',
|
UNFAVORITE = 'unfavorite',
|
||||||
TRASH = 'trash',
|
TRASH = 'trash',
|
||||||
DELETE = 'delete',
|
DELETE = 'delete',
|
||||||
// RESTORE = 'restore',
|
RESTORE = 'restore',
|
||||||
ADD = 'add',
|
ADD = 'add',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue