mirror of
https://github.com/immich-app/immich.git
synced 2025-05-31 20:25:32 -04:00
refactor: duplicates information modal (#18282)
This commit is contained in:
parent
b3b774cfe5
commit
c9d45eee86
@ -1,20 +0,0 @@
|
|||||||
<script lang="ts">
|
|
||||||
import { t } from 'svelte-i18n';
|
|
||||||
import FullScreenModal from './full-screen-modal.svelte';
|
|
||||||
|
|
||||||
interface Props {
|
|
||||||
onClose: () => void;
|
|
||||||
}
|
|
||||||
|
|
||||||
let { onClose }: Props = $props();
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<FullScreenModal title={$t('deduplication_info')} width="auto" {onClose}>
|
|
||||||
<div class="text-sm dark:text-white">
|
|
||||||
<p>{$t('deduplication_info_description')}</p>
|
|
||||||
<ol class="ms-8 mt-2" style="list-style: decimal">
|
|
||||||
<li>{$t('deduplication_criteria_1')}</li>
|
|
||||||
<li>{$t('deduplication_criteria_2')}</li>
|
|
||||||
</ol>
|
|
||||||
</div>
|
|
||||||
</FullScreenModal>
|
|
22
web/src/lib/modals/DuplicatesInformationModal.svelte
Normal file
22
web/src/lib/modals/DuplicatesInformationModal.svelte
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<script lang="ts">
|
||||||
|
import { Modal, ModalBody } from '@immich/ui';
|
||||||
|
import { t } from 'svelte-i18n';
|
||||||
|
|
||||||
|
interface Props {
|
||||||
|
onClose: () => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
let { onClose }: Props = $props();
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<Modal title={$t('deduplication_info')} size="small" {onClose}>
|
||||||
|
<ModalBody>
|
||||||
|
<div class="text-sm dark:text-white">
|
||||||
|
<p>{$t('deduplication_info_description')}</p>
|
||||||
|
<ol class="ms-8 mt-2" style="list-style: decimal">
|
||||||
|
<li>{$t('deduplication_criteria_1')}</li>
|
||||||
|
<li>{$t('deduplication_criteria_2')}</li>
|
||||||
|
</ol>
|
||||||
|
</div>
|
||||||
|
</ModalBody>
|
||||||
|
</Modal>
|
@ -1,13 +1,13 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import CircleIconButton from '$lib/components/elements/buttons/circle-icon-button.svelte';
|
import CircleIconButton from '$lib/components/elements/buttons/circle-icon-button.svelte';
|
||||||
import UserPageLayout from '$lib/components/layouts/user-page-layout.svelte';
|
import UserPageLayout from '$lib/components/layouts/user-page-layout.svelte';
|
||||||
import DuplicatesModal from '$lib/components/shared-components/duplicates-modal.svelte';
|
|
||||||
import {
|
import {
|
||||||
NotificationType,
|
NotificationType,
|
||||||
notificationController,
|
notificationController,
|
||||||
} from '$lib/components/shared-components/notification/notification';
|
} from '$lib/components/shared-components/notification/notification';
|
||||||
import DuplicatesCompareControl from '$lib/components/utilities-page/duplicates/duplicates-compare-control.svelte';
|
import DuplicatesCompareControl from '$lib/components/utilities-page/duplicates/duplicates-compare-control.svelte';
|
||||||
import { modalManager } from '$lib/managers/modal-manager.svelte';
|
import { modalManager } from '$lib/managers/modal-manager.svelte';
|
||||||
|
import DuplicatesInformationModal from '$lib/modals/DuplicatesInformationModal.svelte';
|
||||||
import ShortcutsModal from '$lib/modals/ShortcutsModal.svelte';
|
import ShortcutsModal from '$lib/modals/ShortcutsModal.svelte';
|
||||||
import { locale } from '$lib/stores/preferences.store';
|
import { locale } from '$lib/stores/preferences.store';
|
||||||
import { featureFlags } from '$lib/stores/server-config.store';
|
import { featureFlags } from '$lib/stores/server-config.store';
|
||||||
@ -27,8 +27,6 @@
|
|||||||
|
|
||||||
let { data = $bindable() }: Props = $props();
|
let { data = $bindable() }: Props = $props();
|
||||||
|
|
||||||
let isShowDuplicateInfo = $state(false);
|
|
||||||
|
|
||||||
interface Shortcuts {
|
interface Shortcuts {
|
||||||
general: ExplainedShortcut[];
|
general: ExplainedShortcut[];
|
||||||
actions: ExplainedShortcut[];
|
actions: ExplainedShortcut[];
|
||||||
@ -201,7 +199,7 @@
|
|||||||
title={$t('deduplication_info')}
|
title={$t('deduplication_info')}
|
||||||
size="16"
|
size="16"
|
||||||
padding="2"
|
padding="2"
|
||||||
onclick={() => (isShowDuplicateInfo = true)}
|
onclick={() => modalManager.show(DuplicatesInformationModal, {})}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -220,7 +218,3 @@
|
|||||||
{/if}
|
{/if}
|
||||||
</div>
|
</div>
|
||||||
</UserPageLayout>
|
</UserPageLayout>
|
||||||
|
|
||||||
{#if isShowDuplicateInfo}
|
|
||||||
<DuplicatesModal onClose={() => (isShowDuplicateInfo = false)} />
|
|
||||||
{/if}
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user