refactor: all user admin page modals (#18097)

This commit is contained in:
Daniel Dietzler 2025-05-05 23:54:42 +02:00 committed by GitHub
parent 12610e4a9f
commit 52975eadb3
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 29 additions and 65 deletions

View File

@ -9,12 +9,10 @@
interface Props { interface Props {
user: UserResponseDto; user: UserResponseDto;
onSuccess: () => void; onClose: (confirmed?: true) => void;
onFail: () => void;
onCancel: () => void;
} }
let { user, onSuccess, onFail, onCancel }: Props = $props(); let { user, onClose }: Props = $props();
let forceDelete = $state(false); let forceDelete = $state(false);
let deleteButtonDisabled = $state(false); let deleteButtonDisabled = $state(false);
@ -27,14 +25,11 @@
userAdminDeleteDto: { force: forceDelete }, userAdminDeleteDto: { force: forceDelete },
}); });
if (deletedAt == undefined) { if (deletedAt !== undefined) {
onFail(); onClose(true);
} else {
onSuccess();
} }
} catch (error) { } catch (error) {
handleError(error, $t('errors.unable_to_delete_user')); handleError(error, $t('errors.unable_to_delete_user'));
onFail();
} }
}; };
@ -47,7 +42,7 @@
<ConfirmDialog <ConfirmDialog
title={$t('delete_user')} title={$t('delete_user')}
confirmText={forceDelete ? $t('permanently_delete') : $t('delete')} confirmText={forceDelete ? $t('permanently_delete') : $t('delete')}
onClose={(confirmed) => (confirmed ? handleDeleteUser() : onCancel())} onClose={(confirmed) => (confirmed ? handleDeleteUser() : onClose())}
disabled={deleteButtonDisabled} disabled={deleteButtonDisabled}
> >
{#snippet promptSnippet()} {#snippet promptSnippet()}

View File

@ -7,24 +7,20 @@
interface Props { interface Props {
user: UserResponseDto; user: UserResponseDto;
onSuccess: () => void; onClose: (confirmed?: true) => void;
onFail: () => void;
onCancel: () => void;
} }
let { user, onSuccess, onFail, onCancel }: Props = $props(); let { user, onClose }: Props = $props();
const handleRestoreUser = async () => { const handleRestoreUser = async () => {
try { try {
const { deletedAt } = await restoreUserAdmin({ id: user.id }); const { deletedAt } = await restoreUserAdmin({ id: user.id });
if (deletedAt == undefined) {
onSuccess(); if (deletedAt === undefined) {
} else { onClose(true);
onFail();
} }
} catch (error) { } catch (error) {
handleError(error, $t('errors.unable_to_restore_user')); handleError(error, $t('errors.unable_to_restore_user'));
onFail();
} }
}; };
</script> </script>
@ -33,7 +29,7 @@
title={$t('restore_user')} title={$t('restore_user')}
confirmText={$t('continue')} confirmText={$t('continue')}
confirmColor="success" confirmColor="success"
onClose={(confirmed) => (confirmed ? handleRestoreUser() : onCancel())} onClose={(confirmed) => (confirmed ? handleRestoreUser() : onClose())}
> >
{#snippet promptSnippet()} {#snippet promptSnippet()}
<p> <p>

View File

@ -1,10 +1,6 @@
<script lang="ts"> <script lang="ts">
import { page } from '$app/stores'; import { page } from '$app/stores';
import DeleteConfirmDialog from '$lib/components/admin-page/delete-confirm-dialogue.svelte';
import RestoreDialogue from '$lib/components/admin-page/restore-dialogue.svelte';
import Icon from '$lib/components/elements/icon.svelte'; import Icon from '$lib/components/elements/icon.svelte';
import CreateUserForm from '$lib/components/forms/create-user-form.svelte';
import EditUserForm from '$lib/components/forms/edit-user-form.svelte';
import UserPageLayout from '$lib/components/layouts/user-page-layout.svelte'; import UserPageLayout from '$lib/components/layouts/user-page-layout.svelte';
import { import {
NotificationType, NotificationType,
@ -12,6 +8,10 @@
} from '$lib/components/shared-components/notification/notification'; } from '$lib/components/shared-components/notification/notification';
import PasswordResetSuccess from '$lib/forms/password-reset-success.svelte'; import PasswordResetSuccess from '$lib/forms/password-reset-success.svelte';
import { modalManager } from '$lib/managers/modal-manager.svelte'; import { modalManager } from '$lib/managers/modal-manager.svelte';
import UserCreateModal from '$lib/modals/UserCreateModal.svelte';
import UserDeleteConfirmModal from '$lib/modals/UserDeleteConfirmModal.svelte';
import UserEditModal from '$lib/modals/UserEditModal.svelte';
import UserRestoreConfirmModal from '$lib/modals/UserRestoreConfirmModal.svelte';
import { locale } from '$lib/stores/preferences.store'; import { locale } from '$lib/stores/preferences.store';
import { serverConfig } from '$lib/stores/server-config.store'; import { serverConfig } from '$lib/stores/server-config.store';
import { user } from '$lib/stores/user.store'; import { user } from '$lib/stores/user.store';
@ -32,9 +32,6 @@
let { data }: Props = $props(); let { data }: Props = $props();
let allUsers: UserAdminResponseDto[] = $state([]); let allUsers: UserAdminResponseDto[] = $state([]);
let shouldShowDeleteConfirmDialog = $state(false);
let shouldShowRestoreDialog = $state(false);
let selectedUser = $state<UserAdminResponseDto>();
const refresh = async () => { const refresh = async () => {
allUsers = await searchUsersAdmin({ withDeleted: true }); allUsers = await searchUsersAdmin({ withDeleted: true });
@ -62,12 +59,12 @@
}; };
const handleCreate = async () => { const handleCreate = async () => {
await modalManager.open(CreateUserForm, {}); await modalManager.open(UserCreateModal, {});
await refresh(); await refresh();
}; };
const handleEdit = async (dto: UserAdminResponseDto) => { const handleEdit = async (dto: UserAdminResponseDto) => {
const result = await modalManager.open(EditUserForm, { user: dto, canResetPassword: dto.id !== $user.id }); const result = await modalManager.open(UserEditModal, { user: dto, canResetPassword: dto.id !== $user.id });
switch (result?.action) { switch (result?.action) {
case 'resetPassword': { case 'resetPassword': {
await modalManager.open(PasswordResetSuccess, { newPassword: result.data }); await modalManager.open(PasswordResetSuccess, { newPassword: result.data });
@ -80,48 +77,24 @@
} }
}; };
const deleteUserHandler = (user: UserAdminResponseDto) => { const handleDelete = async (user: UserAdminResponseDto) => {
selectedUser = user; const result = await modalManager.open(UserDeleteConfirmModal, { user });
shouldShowDeleteConfirmDialog = true; if (result) {
};
const onUserDelete = async () => {
await refresh(); await refresh();
shouldShowDeleteConfirmDialog = false; }
}; };
const restoreUserHandler = (user: UserAdminResponseDto) => { const handleRestore = async (user: UserAdminResponseDto) => {
selectedUser = user; const result = await modalManager.open(UserRestoreConfirmModal, { user });
shouldShowRestoreDialog = true; if (result) {
};
const onUserRestore = async () => {
await refresh(); await refresh();
shouldShowRestoreDialog = false; }
}; };
</script> </script>
<UserPageLayout title={data.meta.title} admin> <UserPageLayout title={data.meta.title} admin>
<section id="setting-content" class="flex place-content-center sm:mx-4"> <section id="setting-content" class="flex place-content-center sm:mx-4">
<section class="w-full pb-28 lg:w-[850px]"> <section class="w-full pb-28 lg:w-[850px]">
{#if shouldShowDeleteConfirmDialog && selectedUser}
<DeleteConfirmDialog
user={selectedUser}
onSuccess={onUserDelete}
onFail={onUserDelete}
onCancel={() => (shouldShowDeleteConfirmDialog = false)}
/>
{/if}
{#if shouldShowRestoreDialog && selectedUser}
<RestoreDialogue
user={selectedUser}
onSuccess={onUserRestore}
onFail={onUserRestore}
onCancel={() => (shouldShowRestoreDialog = false)}
/>
{/if}
<table class="my-5 w-full text-start"> <table class="my-5 w-full text-start">
<thead <thead
class="mb-4 flex h-12 w-full rounded-md border bg-gray-50 text-immich-primary dark:border-immich-dark-gray dark:bg-immich-dark-gray dark:text-immich-dark-primary" class="mb-4 flex h-12 w-full rounded-md border bg-gray-50 text-immich-primary dark:border-immich-dark-gray dark:bg-immich-dark-gray dark:text-immich-dark-primary"
@ -176,7 +149,7 @@
size="small" size="small"
icon={mdiTrashCanOutline} icon={mdiTrashCanOutline}
title={$t('delete_user')} title={$t('delete_user')}
onclick={() => deleteUserHandler(immichUser)} onclick={() => handleDelete(immichUser)}
aria-label={$t('delete_user')} aria-label={$t('delete_user')}
/> />
{/if} {/if}
@ -189,7 +162,7 @@
title={$t('admin.user_restore_scheduled_removal', { title={$t('admin.user_restore_scheduled_removal', {
values: { date: getDeleteDate(immichUser.deletedAt) }, values: { date: getDeleteDate(immichUser.deletedAt) },
})} })}
onclick={() => restoreUserHandler(immichUser)} onclick={() => handleRestore(immichUser)}
aria-label={$t('admin.user_restore_scheduled_removal')} aria-label={$t('admin.user_restore_scheduled_removal')}
/> />
{/if} {/if}