immich/web/src/lib/modals/PinCodeResetModal.svelte
2026-02-19 21:50:39 +00:00

44 lines
1.4 KiB
Svelte

<script lang="ts">
import { featureFlagsManager } from '$lib/managers/feature-flags-manager.svelte';
import { handleResetPinCode } from '$lib/services/user.service';
import { BasicModal, Field, FormModal, HelperText, PasswordInput, Stack, type ModalSize } from '@immich/ui';
import { mdiLockReset } from '@mdi/js';
import { t } from 'svelte-i18n';
type Props = {
onClose: (success?: true) => void;
};
let { onClose }: Props = $props();
let password = $state('');
const onSubmit = async () => {
const success = await handleResetPinCode({ password });
if (success) {
onClose();
}
};
const common = $derived({ title: $t('reset'), size: 'small' as ModalSize, icon: mdiLockReset, onClose });
</script>
{#if featureFlagsManager.value.passwordLogin}
<FormModal {...common} submitColor="danger" submitText={$t('reset')} disabled={!password} {onSubmit}>
<Stack gap={4}>
<div>{$t('reset_pin_code_description')}</div>
<hr class="my-2 h-px w-full border-0 bg-gray-200 dark:bg-gray-600" />
<section>
<Field label={$t('confirm_password')} required>
<PasswordInput bind:value={password} autocomplete="current-password" />
<HelperText color="muted">{$t('reset_pin_code_with_password')}</HelperText>
</Field>
</section>
</Stack>
</FormModal>
{:else}
<BasicModal {...common}>
<div>{$t('reset_pin_code_description')}</div>
</BasicModal>
{/if}