From 0dbe44cb78dd8bcd3920d651b7d650950c790f1f Mon Sep 17 00:00:00 2001 From: Alexandre Truppel Date: Wed, 24 Apr 2024 21:43:43 +0200 Subject: [PATCH] feat(web): upload json config (#8953) * Button added, config is uploaded * Refactored to pass "npm run lint" (also verified other PR checklist Web checks) * Auto-save on config upload * Static input element --------- Co-authored-by: Alex Tran --- .../admin-page/settings/admin-settings.svelte | 2 +- .../routes/admin/system-settings/+page.svelte | 28 +++++++++++++++++-- 2 files changed, 27 insertions(+), 3 deletions(-) diff --git a/web/src/lib/components/admin-page/settings/admin-settings.svelte b/web/src/lib/components/admin-page/settings/admin-settings.svelte index 8f819f1eb3..79ed46947d 100644 --- a/web/src/lib/components/admin-page/settings/admin-settings.svelte +++ b/web/src/lib/components/admin-page/settings/admin-settings.svelte @@ -23,7 +23,7 @@ await (detail.default ? resetToDefault(detail.configKeys) : reset(detail.configKeys)); }; - const handleSave = async (update: Partial) => { + export const handleSave = async (update: Partial) => { try { const newConfig = await updateConfig({ systemConfigDto: { diff --git a/web/src/routes/admin/system-settings/+page.svelte b/web/src/routes/admin/system-settings/+page.svelte index cb80a9e0d6..fee111dd0e 100644 --- a/web/src/routes/admin/system-settings/+page.svelte +++ b/web/src/routes/admin/system-settings/+page.svelte @@ -23,14 +23,16 @@ import { featureFlags } from '$lib/stores/server-config.store'; import { copyToClipboard } from '$lib/utils'; import { downloadBlob } from '$lib/utils/asset-utils'; - import { mdiAlert, mdiContentCopy, mdiDownload } from '@mdi/js'; + import { mdiAlert, mdiContentCopy, mdiDownload, mdiUpload } from '@mdi/js'; import type { PageData } from './$types'; import SettingAccordionState from '$lib/components/shared-components/settings/setting-accordion-state.svelte'; import { QueryParameter } from '$lib/constants'; + import type { SystemConfigDto } from '@immich/sdk'; export let data: PageData; let config = data.configs; + let handleSave: (update: Partial) => Promise; type Settings = | typeof JobSettings @@ -58,6 +60,20 @@ setTimeout(() => downloadManager.clear(downloadKey), 5000); }; + let inputElement: HTMLInputElement; + const uploadConfig = (e: Event) => { + const file = (e.target as HTMLInputElement).files?.[0]; + if (!file) { + return; + } + const reader = async () => { + const text = await file.text(); + const newConfig = JSON.parse(text); + await handleSave(newConfig); + }; + reader().catch((error) => console.error('Error handling JSON config upload', error)); + }; + const settings: Array<{ item: Settings; title: string; @@ -157,6 +173,8 @@ ]; + +
{#if $featureFlags.configFile}
@@ -181,9 +199,15 @@ Export as JSON
+ inputElement?.click()}> +
+ + Import from JSON +
+
- +