Fixed bug in QuestEditorUiPersister config sanitization code. When removing old components results in empty containers, these containers are now also removed.

This commit is contained in:
Daan Vanden Bosch 2020-07-14 22:08:36 +02:00
parent 767397d26d
commit d0d6b7ff1a

View File

@ -65,33 +65,22 @@ export class QuestEditorUiPersister extends Persister {
return undefined;
}
switch (config.type) {
case "component":
{
// Remove corrupted components.
if (!("componentName" in config)) {
return undefined;
}
if (config.type === "component") {
// Remove corrupted components.
if (!("componentName" in config)) {
return undefined;
}
const component = components.get(config.componentName);
const component = components.get(config.componentName);
// Remove deprecated components.
if (!component) {
return undefined;
}
// Remove deprecated components.
if (!component) {
return undefined;
}
found.add(config.componentName);
config.id = component.id;
config.title = component.title;
}
break;
case "stack":
// Remove empty stacks.
if (config.content == undefined || config.content.length === 0) {
return undefined;
}
break;
found.add(config.componentName);
config.id = component.id;
config.title = component.title;
}
// Sanitize child items.
@ -101,6 +90,17 @@ export class QuestEditorUiPersister extends Persister {
.filter(item => item) as ItemConfigType[];
}
// Remove empty containers.
switch (config.type) {
case "row":
case "column":
case "stack":
if (config.content == undefined || config.content.length === 0) {
return undefined;
}
break;
}
// Remove corrupted activeItemIndex properties.
const cfg = config as any;