mirror of
https://github.com/immich-app/immich.git
synced 2025-05-31 04:05:39 -04:00
62 lines
2.6 KiB
Svelte
62 lines
2.6 KiB
Svelte
<script lang="ts">
|
|
import { page } from '$app/stores';
|
|
import { OpenSettingQueryParameterValue, QueryParameter } from '$lib/constants';
|
|
import { featureFlags } from '$lib/stores/server-config.store';
|
|
import { user } from '$lib/stores/user.store';
|
|
import { oauth } from '$lib/utils';
|
|
import { type ApiKeyResponseDto, type SessionResponseDto } from '@immich/sdk';
|
|
import SettingAccordionState from '../shared-components/settings/setting-accordion-state.svelte';
|
|
import SettingAccordion from '../shared-components/settings/setting-accordion.svelte';
|
|
import AppSettings from './app-settings.svelte';
|
|
import ChangePasswordSettings from './change-password-settings.svelte';
|
|
import DeviceList from './device-list.svelte';
|
|
import MemoriesSettings from './memories-settings.svelte';
|
|
import OAuthSettings from './oauth-settings.svelte';
|
|
import PartnerSettings from './partner-settings.svelte';
|
|
import UserAPIKeyList from './user-api-key-list.svelte';
|
|
import UserProfileSettings from './user-profile-settings.svelte';
|
|
|
|
export let keys: ApiKeyResponseDto[] = [];
|
|
export let sessions: SessionResponseDto[] = [];
|
|
|
|
let oauthOpen =
|
|
oauth.isCallback(window.location) ||
|
|
$page.url.searchParams.get(QueryParameter.OPEN_SETTING) === OpenSettingQueryParameterValue.OAUTH;
|
|
</script>
|
|
|
|
<SettingAccordionState queryParam={QueryParameter.IS_OPEN}>
|
|
<SettingAccordion key="app-settings" title="App Settings" subtitle="Manage the app settings">
|
|
<AppSettings />
|
|
</SettingAccordion>
|
|
|
|
<SettingAccordion key="account" title="Account" subtitle="Manage your account">
|
|
<UserProfileSettings />
|
|
</SettingAccordion>
|
|
|
|
<SettingAccordion key="api-keys" title="API Keys" subtitle="Manage your API keys">
|
|
<UserAPIKeyList bind:keys />
|
|
</SettingAccordion>
|
|
|
|
<SettingAccordion key="authorized-devices" title="Authorized Devices" subtitle="Manage your logged-in devices">
|
|
<DeviceList bind:devices={sessions} />
|
|
</SettingAccordion>
|
|
|
|
<SettingAccordion key="memories" title="Memories" subtitle="Manage what you see in your memories">
|
|
<MemoriesSettings user={$user} />
|
|
</SettingAccordion>
|
|
|
|
{#if $featureFlags.loaded && $featureFlags.oauth}
|
|
<SettingAccordion key="oauth" title="OAuth" subtitle="Manage your OAuth connection" isOpen={oauthOpen || undefined}>
|
|
<OAuthSettings user={$user} />
|
|
</SettingAccordion>
|
|
{/if}
|
|
|
|
<SettingAccordion key="password" title="Password" subtitle="Change your password">
|
|
<ChangePasswordSettings />
|
|
</SettingAccordion>
|
|
|
|
<SettingAccordion key="partner-sharing" title="Partner Sharing" subtitle="Manage sharing with partners">
|
|
<PartnerSettings user={$user} />
|
|
</SettingAccordion>
|
|
</SettingAccordionState>
|