mirror of
https://github.com/samsonjs/immich.git
synced 2026-04-27 15:07:45 +00:00
refactor(web): user setting actions (#25424)
This commit is contained in:
parent
417af66f30
commit
dc82c13ddc
2 changed files with 21 additions and 16 deletions
14
web/src/lib/services/keyboard.service.ts
Normal file
14
web/src/lib/services/keyboard.service.ts
Normal file
|
|
@ -0,0 +1,14 @@
|
||||||
|
import ShortcutsModal from '$lib/modals/ShortcutsModal.svelte';
|
||||||
|
import { modalManager, type ActionItem } from '@immich/ui';
|
||||||
|
import { mdiKeyboard } from '@mdi/js';
|
||||||
|
import type { MessageFormatter } from 'svelte-i18n';
|
||||||
|
|
||||||
|
export const getKeyboardActions = ($t: MessageFormatter) => {
|
||||||
|
const KeyboardShortcuts: ActionItem = {
|
||||||
|
title: $t('show_keyboard_shortcuts'),
|
||||||
|
icon: mdiKeyboard,
|
||||||
|
onAction: () => modalManager.show(ShortcutsModal, {}),
|
||||||
|
};
|
||||||
|
|
||||||
|
return { KeyboardShortcuts };
|
||||||
|
};
|
||||||
|
|
@ -1,30 +1,21 @@
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import UserPageLayout from '$lib/components/layouts/user-page-layout.svelte';
|
import UserPageLayout from '$lib/components/layouts/user-page-layout.svelte';
|
||||||
import UserSettingsList from '$lib/components/user-settings-page/user-settings-list.svelte';
|
import UserSettingsList from '$lib/components/user-settings-page/user-settings-list.svelte';
|
||||||
import ShortcutsModal from '$lib/modals/ShortcutsModal.svelte';
|
import { getKeyboardActions } from '$lib/services/keyboard.service';
|
||||||
import { Container, IconButton, modalManager } from '@immich/ui';
|
import { Container } from '@immich/ui';
|
||||||
import { mdiKeyboard } from '@mdi/js';
|
|
||||||
import { t } from 'svelte-i18n';
|
import { t } from 'svelte-i18n';
|
||||||
import type { PageData } from './$types';
|
import type { PageData } from './$types';
|
||||||
|
|
||||||
interface Props {
|
type Props = {
|
||||||
data: PageData;
|
data: PageData;
|
||||||
}
|
};
|
||||||
|
|
||||||
let { data }: Props = $props();
|
let { data }: Props = $props();
|
||||||
|
|
||||||
|
const { KeyboardShortcuts } = $derived(getKeyboardActions($t));
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<UserPageLayout title={data.meta.title}>
|
<UserPageLayout title={data.meta.title} actions={[KeyboardShortcuts]}>
|
||||||
{#snippet buttons()}
|
|
||||||
<IconButton
|
|
||||||
shape="round"
|
|
||||||
color="secondary"
|
|
||||||
variant="ghost"
|
|
||||||
icon={mdiKeyboard}
|
|
||||||
aria-label={$t('show_keyboard_shortcuts')}
|
|
||||||
onclick={() => modalManager.show(ShortcutsModal, {})}
|
|
||||||
/>
|
|
||||||
{/snippet}
|
|
||||||
<Container size="medium" center>
|
<Container size="medium" center>
|
||||||
<UserSettingsList keys={data.keys} sessions={data.sessions} />
|
<UserSettingsList keys={data.keys} sessions={data.sessions} />
|
||||||
</Container>
|
</Container>
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue