mirror of
https://github.com/pacnpal/thrilltrack-explorer.git
synced 2025-12-21 17:51:14 -05:00
Fix: Show moderator edits in creation submissions
This commit is contained in:
@@ -229,10 +229,15 @@ export function SubmissionChangesDisplay({
|
||||
<h4 className="text-sm font-medium">Creation Data (with moderator edits highlighted)</h4>
|
||||
<div className="grid gap-2">
|
||||
{changes.fieldChanges.map((change, idx) => {
|
||||
// Highlight fields that were modified (not just added)
|
||||
const wasEditedByModerator = change.changeType === 'modified' &&
|
||||
item.original_data &&
|
||||
item.original_data[change.field] !== undefined;
|
||||
// Highlight fields that were added OR modified by moderator
|
||||
const wasEditedByModerator = item.original_data &&
|
||||
Object.keys(item.original_data).length > 0 &&
|
||||
(
|
||||
// Field was modified from original value
|
||||
(change.changeType === 'modified') ||
|
||||
// Field was added by moderator (not in original submission)
|
||||
(change.changeType === 'added' && item.original_data[change.field] === undefined)
|
||||
);
|
||||
|
||||
return (
|
||||
<div key={idx} className={wasEditedByModerator ? 'border-l-4 border-blue-500 pl-3 bg-blue-50/50 dark:bg-blue-950/30 rounded' : ''}>
|
||||
|
||||
@@ -157,9 +157,51 @@ export async function detectChanges(
|
||||
let hasLocationChange = false;
|
||||
|
||||
if (action === 'create') {
|
||||
// For creates, all fields are "added" - be more permissive to show all data
|
||||
// Check if this creation was edited by a moderator
|
||||
const hasModeratorEdits = originalData && Object.keys(originalData).length > 0;
|
||||
|
||||
if (hasModeratorEdits) {
|
||||
// Compare item_data with original_data to detect moderator changes
|
||||
const allKeys = new Set([
|
||||
...Object.keys(itemData),
|
||||
...Object.keys(originalData)
|
||||
]);
|
||||
|
||||
allKeys.forEach(key => {
|
||||
if (!shouldTrackField(key)) return;
|
||||
|
||||
const oldValue = originalData[key];
|
||||
const newValue = itemData[key];
|
||||
|
||||
// Skip if both are empty
|
||||
const oldEmpty = oldValue === null || oldValue === undefined || oldValue === '';
|
||||
const newEmpty = newValue === null || newValue === undefined || newValue === '';
|
||||
|
||||
if (oldEmpty && newEmpty) return;
|
||||
|
||||
// Detect the type of change
|
||||
if (!isEqual(oldValue, newValue)) {
|
||||
fieldChanges.push({
|
||||
field: key,
|
||||
oldValue,
|
||||
newValue,
|
||||
changeType: oldEmpty && !newEmpty ? 'added' : // Moderator added new field
|
||||
newEmpty && !oldEmpty ? 'removed' : // Moderator removed field
|
||||
'modified', // Moderator changed value
|
||||
});
|
||||
} else if (!newEmpty) {
|
||||
// Field unchanged - show as 'added' (part of original submission)
|
||||
fieldChanges.push({
|
||||
field: key,
|
||||
oldValue: null,
|
||||
newValue,
|
||||
changeType: 'added',
|
||||
});
|
||||
}
|
||||
});
|
||||
} else {
|
||||
// No moderator edits - show all fields as 'added' (original behavior)
|
||||
Object.entries(itemData).forEach(([key, value]) => {
|
||||
// For creates, exclude only system fields and internal metadata
|
||||
const systemFields = ['id', 'created_at', 'updated_at', 'slug', 'images', 'image_assignments'];
|
||||
const shouldShow = !systemFields.includes(key) && value !== null && value !== undefined && value !== '';
|
||||
|
||||
@@ -172,6 +214,7 @@ export async function detectChanges(
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
} else if (action === 'edit') {
|
||||
// Compare each field
|
||||
const allKeys = new Set([
|
||||
|
||||
Reference in New Issue
Block a user