Files
lucent-laravel/front/js/entry/RecordEditEntry/RecordEditEntry.svelte
T

70 lines
2.9 KiB
Svelte
Raw Normal View History

2026-01-09 16:54:42 +02:00
<script>
import ChannelLayout from "../../layouts/ChannelLayout.svelte";
import { onMount } from "svelte";
import TextField from "./fields/TextField.svelte";
import LocaleChooser from "./LocaleChooser.svelte";
2026-01-09 19:08:00 +02:00
import RecordStatus from "./RecordStatus.svelte";
import PublishingOptions from "./PublishingOptions.svelte";
2026-01-09 16:54:42 +02:00
import { getSelectedLocales } from "./locale.svelte.js";
let { channel, user, data } = $props();
let selectedLocales = $state(getSelectedLocales());
let record = $state(data.record);
function handleLocaleChange() {
selectedLocales = getSelectedLocales();
}
</script>
<!-- <svelte:window on:beforeunload={beforeUnload} /> -->
<ChannelLayout {body} {channel} schemas={data.schemas} {user}></ChannelLayout>
{#snippet body()}
2026-01-09 19:08:00 +02:00
<RecordStatus {channel} {record} status={data.recordStatus}></RecordStatus>
<div style="display:flex;gap:20px;justify-content: space-between;">
<LocaleChooser {channel} onLocaleChange={handleLocaleChange}
></LocaleChooser>
<PublishingOptions {record} status={data.recordStatus}
></PublishingOptions>
</div>
<fieldset disabled={data.recordStatus === "trashed"}>
{#each data.fields as field}
<div style="display:flex;gap:20px;">
{#if field.type === "text"}
<TextField
{channel}
{record}
validationError={data.validationErrors.find(
(f) =>
f.fieldId === field.id && f.locale === "main",
)}
schemaField={field}
locale="main"
dataField={data.draftData.find(
(f) => f.id === field.id && f.locale === "main",
)}
></TextField>
{#if field.translatable}
{#each selectedLocales as locale (locale)}
<TextField
{channel}
{record}
validationError={data.validationErrors.find(
(f) =>
f.fieldId === field.id &&
f.locale === locale,
)}
schemaField={field}
{locale}
dataField={data.draftData.find(
(f) =>
f.id === field.id &&
f.locale === locale,
)}
></TextField>
{/each}
{/if}
2026-01-09 16:54:42 +02:00
{/if}
2026-01-09 19:08:00 +02:00
</div>
{/each}
</fieldset>
2026-01-09 16:54:42 +02:00
{/snippet}