diff --git a/src/pages/ContentCreation.jsx b/src/pages/ContentCreation.jsx index 1a682a4..68f542c 100644 --- a/src/pages/ContentCreation.jsx +++ b/src/pages/ContentCreation.jsx @@ -465,7 +465,7 @@ function PairForm({ objectId, allObjects, onPairSaved }) { // ─── EditPairForm ───────────────────────────────────────────────────────────── -function EditPairForm({ pair, allObjects, onSaved, onCancel, onDeleted }) { +function EditPairForm({ pair, allObjects, onSaved, onCancel, onDeleted, onSavedAndTranslate }) { const lang = getUserLang(); const [loading, setLoading] = useState(true); const [saving, setSaving] = useState(false); @@ -592,7 +592,7 @@ function EditPairForm({ pair, allObjects, onSaved, onCancel, onDeleted }) { finally { setCreatingWord(false); } } - async function handleSave() { + async function handleSave({ translateAfter = false } = {}) { setSaving(true); try { const ph = t => withPlaceholders(t, wordMap, objectAssignments); @@ -646,7 +646,8 @@ function EditPairForm({ pair, allObjects, onSaved, onCancel, onDeleted }) { if (pair.answer_type !== type) patchPair.answer_type = type; if (pair.status !== pairStatus) patchPair.status = pairStatus; if (Object.keys(patchPair).length) await apiPatch('/pairs', pair.id, patchPair); - onSaved(); + if (translateAfter && onSavedAndTranslate) onSavedAndTranslate({ ...pair, answer_type: type }); + else onSaved(); } catch (e) { alert('Fehler: ' + e.message); } finally { setSaving(false); } } @@ -837,10 +838,17 @@ function EditPairForm({ pair, allObjects, onSaved, onCancel, onDeleted }) {
-
+ {onSavedAndTranslate && ( + + )} {!confirmDelete ? (