mirror of
https://github.com/immich-app/immich.git
synced 2025-01-19 18:26:46 +01:00
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 <alex.tran1502@gmail.com>
This commit is contained in:
parent
a78260296c
commit
0dbe44cb78
2 changed files with 27 additions and 3 deletions
|
@ -23,7 +23,7 @@
|
||||||
await (detail.default ? resetToDefault(detail.configKeys) : reset(detail.configKeys));
|
await (detail.default ? resetToDefault(detail.configKeys) : reset(detail.configKeys));
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleSave = async (update: Partial<SystemConfigDto>) => {
|
export const handleSave = async (update: Partial<SystemConfigDto>) => {
|
||||||
try {
|
try {
|
||||||
const newConfig = await updateConfig({
|
const newConfig = await updateConfig({
|
||||||
systemConfigDto: {
|
systemConfigDto: {
|
||||||
|
|
|
@ -23,14 +23,16 @@
|
||||||
import { featureFlags } from '$lib/stores/server-config.store';
|
import { featureFlags } from '$lib/stores/server-config.store';
|
||||||
import { copyToClipboard } from '$lib/utils';
|
import { copyToClipboard } from '$lib/utils';
|
||||||
import { downloadBlob } from '$lib/utils/asset-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 type { PageData } from './$types';
|
||||||
import SettingAccordionState from '$lib/components/shared-components/settings/setting-accordion-state.svelte';
|
import SettingAccordionState from '$lib/components/shared-components/settings/setting-accordion-state.svelte';
|
||||||
import { QueryParameter } from '$lib/constants';
|
import { QueryParameter } from '$lib/constants';
|
||||||
|
import type { SystemConfigDto } from '@immich/sdk';
|
||||||
|
|
||||||
export let data: PageData;
|
export let data: PageData;
|
||||||
|
|
||||||
let config = data.configs;
|
let config = data.configs;
|
||||||
|
let handleSave: (update: Partial<SystemConfigDto>) => Promise<void>;
|
||||||
|
|
||||||
type Settings =
|
type Settings =
|
||||||
| typeof JobSettings
|
| typeof JobSettings
|
||||||
|
@ -58,6 +60,20 @@
|
||||||
setTimeout(() => downloadManager.clear(downloadKey), 5000);
|
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<{
|
const settings: Array<{
|
||||||
item: Settings;
|
item: Settings;
|
||||||
title: string;
|
title: string;
|
||||||
|
@ -157,6 +173,8 @@
|
||||||
];
|
];
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<input bind:this={inputElement} type="file" accept=".json" style="display: none" on:change={uploadConfig} />
|
||||||
|
|
||||||
<div class="h-svh flex flex-col overflow-hidden">
|
<div class="h-svh flex flex-col overflow-hidden">
|
||||||
{#if $featureFlags.configFile}
|
{#if $featureFlags.configFile}
|
||||||
<div class="flex flex-row items-center gap-2 bg-gray-100 p-3 dark:bg-gray-800">
|
<div class="flex flex-row items-center gap-2 bg-gray-100 p-3 dark:bg-gray-800">
|
||||||
|
@ -181,9 +199,15 @@
|
||||||
Export as JSON
|
Export as JSON
|
||||||
</div>
|
</div>
|
||||||
</LinkButton>
|
</LinkButton>
|
||||||
|
<LinkButton on:click={() => inputElement?.click()}>
|
||||||
|
<div class="flex place-items-center gap-2 text-sm">
|
||||||
|
<Icon path={mdiUpload} size="18" />
|
||||||
|
Import from JSON
|
||||||
|
</div>
|
||||||
|
</LinkButton>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<AdminSettings bind:config let:handleReset let:handleSave let:savedConfig let:defaultConfig>
|
<AdminSettings bind:config let:handleReset bind:handleSave let:savedConfig let:defaultConfig>
|
||||||
<section id="setting-content" class="flex place-content-center sm:mx-4">
|
<section id="setting-content" class="flex place-content-center sm:mx-4">
|
||||||
<section class="w-full pb-28 sm:w-5/6 md:w-[850px]">
|
<section class="w-full pb-28 sm:w-5/6 md:w-[850px]">
|
||||||
<SettingAccordionState queryParam={QueryParameter.IS_OPEN}>
|
<SettingAccordionState queryParam={QueryParameter.IS_OPEN}>
|
||||||
|
|
Loading…
Reference in a new issue