2022-12-17 16:08:18 -06:00
|
|
|
<script lang="ts">
|
2023-07-01 00:50:47 -04:00
|
|
|
import { page } from '$app/stores';
|
2024-02-14 06:38:57 -08:00
|
|
|
import { OpenSettingQueryParameterValue, QueryParameter } from '$lib/constants';
|
2023-09-08 22:51:46 -04:00
|
|
|
import { featureFlags } from '$lib/stores/server-config.store';
|
2024-02-14 06:38:57 -08:00
|
|
|
import { user } from '$lib/stores/user.store';
|
|
|
|
|
import { oauth } from '$lib/utils';
|
2024-04-19 06:47:29 -04:00
|
|
|
import { type ApiKeyResponseDto, type SessionResponseDto } from '@immich/sdk';
|
|
|
|
|
import SettingAccordionState from '../shared-components/settings/setting-accordion-state.svelte';
|
2024-02-22 15:36:14 +01:00
|
|
|
import SettingAccordion from '../shared-components/settings/setting-accordion.svelte';
|
2024-03-11 12:45:01 -04:00
|
|
|
import AppSettings from './app-settings.svelte';
|
2023-07-01 00:50:47 -04:00
|
|
|
import ChangePasswordSettings from './change-password-settings.svelte';
|
|
|
|
|
import DeviceList from './device-list.svelte';
|
2023-08-09 22:01:16 -04:00
|
|
|
import OAuthSettings from './oauth-settings.svelte';
|
2023-07-01 00:50:47 -04:00
|
|
|
import PartnerSettings from './partner-settings.svelte';
|
2023-08-09 22:01:16 -04:00
|
|
|
import UserAPIKeyList from './user-api-key-list.svelte';
|
2023-07-01 00:50:47 -04:00
|
|
|
import UserProfileSettings from './user-profile-settings.svelte';
|
2024-06-03 16:00:20 -05:00
|
|
|
import NotificationsSettings from '$lib/components/user-settings-page/notifications-settings.svelte';
|
2024-06-04 21:53:00 +02:00
|
|
|
import { t } from 'svelte-i18n';
|
2024-06-14 17:27:12 +02:00
|
|
|
import DownloadSettings from '$lib/components/user-settings-page/download-settings.svelte';
|
2024-07-26 10:34:35 -05:00
|
|
|
import UserPurchaseSettings from '$lib/components/user-settings-page/user-purchase-settings.svelte';
|
2024-08-29 14:29:04 -05:00
|
|
|
import FeatureSettings from '$lib/components/user-settings-page/feature-settings.svelte';
|
2024-09-16 15:51:03 -05:00
|
|
|
import {
|
|
|
|
|
mdiAccountGroupOutline,
|
|
|
|
|
mdiAccountOutline,
|
|
|
|
|
mdiApi,
|
|
|
|
|
mdiBellOutline,
|
|
|
|
|
mdiCogOutline,
|
|
|
|
|
mdiDevices,
|
|
|
|
|
mdiDownload,
|
|
|
|
|
mdiFeatureSearchOutline,
|
|
|
|
|
mdiKeyOutline,
|
|
|
|
|
mdiOnepassword,
|
|
|
|
|
mdiTwoFactorAuthentication,
|
|
|
|
|
} from '@mdi/js';
|
2023-07-01 00:50:47 -04:00
|
|
|
|
2024-11-14 08:43:25 -06:00
|
|
|
interface Props {
|
|
|
|
|
keys?: ApiKeyResponseDto[];
|
|
|
|
|
sessions?: SessionResponseDto[];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let { keys = $bindable([]), sessions = $bindable([]) }: Props = $props();
|
2023-08-17 05:56:06 +02:00
|
|
|
|
2024-02-28 22:40:08 +01:00
|
|
|
let oauthOpen =
|
|
|
|
|
oauth.isCallback(window.location) ||
|
|
|
|
|
$page.url.searchParams.get(QueryParameter.OPEN_SETTING) === OpenSettingQueryParameterValue.OAUTH;
|
2022-12-17 16:08:18 -06:00
|
|
|
</script>
|
|
|
|
|
|
2024-02-28 22:40:08 +01:00
|
|
|
<SettingAccordionState queryParam={QueryParameter.IS_OPEN}>
|
2024-09-16 15:51:03 -05:00
|
|
|
<SettingAccordion
|
|
|
|
|
icon={mdiCogOutline}
|
|
|
|
|
key="app-settings"
|
|
|
|
|
title={$t('app_settings')}
|
|
|
|
|
subtitle={$t('manage_the_app_settings')}
|
|
|
|
|
>
|
2024-03-11 12:45:01 -04:00
|
|
|
<AppSettings />
|
2024-02-28 22:40:08 +01:00
|
|
|
</SettingAccordion>
|
2022-12-21 09:43:35 -05:00
|
|
|
|
2024-09-16 15:51:03 -05:00
|
|
|
<SettingAccordion icon={mdiAccountOutline} key="account" title={$t('account')} subtitle={$t('manage_your_account')}>
|
2024-02-28 22:40:08 +01:00
|
|
|
<UserProfileSettings />
|
|
|
|
|
</SettingAccordion>
|
2022-12-26 10:35:52 -05:00
|
|
|
|
2024-09-16 15:51:03 -05:00
|
|
|
<SettingAccordion icon={mdiApi} key="api-keys" title={$t('api_keys')} subtitle={$t('manage_your_api_keys')}>
|
2024-02-28 22:40:08 +01:00
|
|
|
<UserAPIKeyList bind:keys />
|
|
|
|
|
</SettingAccordion>
|
2023-01-02 15:22:33 -05:00
|
|
|
|
2024-09-16 15:51:03 -05:00
|
|
|
<SettingAccordion
|
|
|
|
|
icon={mdiDevices}
|
|
|
|
|
key="authorized-devices"
|
|
|
|
|
title={$t('authorized_devices')}
|
|
|
|
|
subtitle={$t('manage_your_devices')}
|
|
|
|
|
>
|
2024-04-19 06:47:29 -04:00
|
|
|
<DeviceList bind:devices={sessions} />
|
2024-02-28 22:40:08 +01:00
|
|
|
</SettingAccordion>
|
2023-09-20 13:16:33 +02:00
|
|
|
|
2024-06-14 17:27:12 +02:00
|
|
|
<SettingAccordion
|
2024-09-16 15:51:03 -05:00
|
|
|
icon={mdiDownload}
|
2024-06-14 17:27:12 +02:00
|
|
|
key="download-settings"
|
|
|
|
|
title={$t('download_settings')}
|
|
|
|
|
subtitle={$t('download_settings_description')}
|
|
|
|
|
>
|
|
|
|
|
<DownloadSettings />
|
|
|
|
|
</SettingAccordion>
|
|
|
|
|
|
2024-09-16 15:51:03 -05:00
|
|
|
<SettingAccordion
|
|
|
|
|
icon={mdiFeatureSearchOutline}
|
|
|
|
|
key="feature"
|
|
|
|
|
title={$t('features')}
|
|
|
|
|
subtitle={$t('features_setting_description')}
|
|
|
|
|
>
|
2024-08-29 14:29:04 -05:00
|
|
|
<FeatureSettings />
|
2023-07-01 00:50:47 -04:00
|
|
|
</SettingAccordion>
|
2023-04-25 22:19:23 -04:00
|
|
|
|
2024-09-16 15:51:03 -05:00
|
|
|
<SettingAccordion
|
|
|
|
|
icon={mdiBellOutline}
|
|
|
|
|
key="notifications"
|
|
|
|
|
title={$t('notifications')}
|
|
|
|
|
subtitle={$t('notifications_setting_description')}
|
|
|
|
|
>
|
2024-06-03 16:00:20 -05:00
|
|
|
<NotificationsSettings />
|
|
|
|
|
</SettingAccordion>
|
|
|
|
|
|
2024-02-28 22:40:08 +01:00
|
|
|
{#if $featureFlags.loaded && $featureFlags.oauth}
|
2024-06-04 21:53:00 +02:00
|
|
|
<SettingAccordion
|
2024-09-16 15:51:03 -05:00
|
|
|
icon={mdiTwoFactorAuthentication}
|
2024-06-04 21:53:00 +02:00
|
|
|
key="oauth"
|
|
|
|
|
title={$t('oauth')}
|
|
|
|
|
subtitle={$t('manage_your_oauth_connection')}
|
|
|
|
|
isOpen={oauthOpen || undefined}
|
|
|
|
|
>
|
2024-02-28 22:40:08 +01:00
|
|
|
<OAuthSettings user={$user} />
|
|
|
|
|
</SettingAccordion>
|
|
|
|
|
{/if}
|
2023-05-15 20:30:53 +03:00
|
|
|
|
2024-09-16 15:51:03 -05:00
|
|
|
<SettingAccordion icon={mdiOnepassword} key="password" title={$t('password')} subtitle={$t('change_your_password')}>
|
2024-02-28 22:40:08 +01:00
|
|
|
<ChangePasswordSettings />
|
|
|
|
|
</SettingAccordion>
|
2023-09-27 23:09:54 -04:00
|
|
|
|
2024-09-16 15:51:03 -05:00
|
|
|
<SettingAccordion
|
|
|
|
|
icon={mdiAccountGroupOutline}
|
|
|
|
|
key="partner-sharing"
|
|
|
|
|
title={$t('partner_sharing')}
|
|
|
|
|
subtitle={$t('manage_sharing_with_partners')}
|
|
|
|
|
>
|
2024-02-28 22:40:08 +01:00
|
|
|
<PartnerSettings user={$user} />
|
|
|
|
|
</SettingAccordion>
|
2024-07-26 10:34:35 -05:00
|
|
|
|
|
|
|
|
<SettingAccordion
|
2024-09-16 15:51:03 -05:00
|
|
|
icon={mdiKeyOutline}
|
2024-07-26 10:34:35 -05:00
|
|
|
key="user-purchase-settings"
|
|
|
|
|
title={$t('user_purchase_settings')}
|
|
|
|
|
subtitle={$t('user_purchase_settings_description')}
|
2024-08-29 14:29:04 -05:00
|
|
|
autoScrollTo={true}
|
2024-07-26 10:34:35 -05:00
|
|
|
>
|
|
|
|
|
<UserPurchaseSettings />
|
|
|
|
|
</SettingAccordion>
|
2024-02-28 22:40:08 +01:00
|
|
|
</SettingAccordionState>
|