Enhance delete foliage layer command to remove masks from affected terrains and improve undo state restoration
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
import { createOpaqueId } from "../core/ids";
|
import { createOpaqueId } from "../core/ids";
|
||||||
|
import { cloneTerrain, type Terrain } from "../document/terrains";
|
||||||
import { cloneFoliageLayer, type FoliageLayer } from "../foliage/foliage";
|
import { cloneFoliageLayer, type FoliageLayer } from "../foliage/foliage";
|
||||||
|
|
||||||
import type { EditorCommand } from "./command";
|
import type { EditorCommand } from "./command";
|
||||||
@@ -7,6 +8,7 @@ export function createDeleteFoliageLayerCommand(
|
|||||||
foliageLayerId: string
|
foliageLayerId: string
|
||||||
): EditorCommand {
|
): EditorCommand {
|
||||||
let deletedLayer: FoliageLayer | null = null;
|
let deletedLayer: FoliageLayer | null = null;
|
||||||
|
let previousTerrains: Record<string, Terrain> | null = null;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
id: createOpaqueId("command"),
|
id: createOpaqueId("command"),
|
||||||
@@ -23,15 +25,44 @@ export function createDeleteFoliageLayerCommand(
|
|||||||
deletedLayer = cloneFoliageLayer(currentLayer);
|
deletedLayer = cloneFoliageLayer(currentLayer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (previousTerrains === null) {
|
||||||
|
previousTerrains = Object.fromEntries(
|
||||||
|
Object.entries(currentDocument.terrains)
|
||||||
|
.filter(
|
||||||
|
([, terrain]) => terrain.foliageMasks[foliageLayerId] !== undefined
|
||||||
|
)
|
||||||
|
.map(([terrainId, terrain]) => [terrainId, cloneTerrain(terrain)])
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
const nextFoliageLayers = {
|
const nextFoliageLayers = {
|
||||||
...currentDocument.foliageLayers
|
...currentDocument.foliageLayers
|
||||||
};
|
};
|
||||||
|
const nextTerrains = {
|
||||||
|
...currentDocument.terrains
|
||||||
|
};
|
||||||
|
|
||||||
delete nextFoliageLayers[foliageLayerId];
|
delete nextFoliageLayers[foliageLayerId];
|
||||||
|
|
||||||
|
for (const [terrainId, terrain] of Object.entries(nextTerrains)) {
|
||||||
|
if (terrain.foliageMasks[foliageLayerId] === undefined) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
const nextFoliageMasks = {
|
||||||
|
...terrain.foliageMasks
|
||||||
|
};
|
||||||
|
delete nextFoliageMasks[foliageLayerId];
|
||||||
|
nextTerrains[terrainId] = cloneTerrain({
|
||||||
|
...terrain,
|
||||||
|
foliageMasks: nextFoliageMasks
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
context.setDocument({
|
context.setDocument({
|
||||||
...currentDocument,
|
...currentDocument,
|
||||||
foliageLayers: nextFoliageLayers
|
foliageLayers: nextFoliageLayers,
|
||||||
|
terrains: nextTerrains
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
undo(context) {
|
undo(context) {
|
||||||
@@ -40,13 +71,23 @@ export function createDeleteFoliageLayerCommand(
|
|||||||
}
|
}
|
||||||
|
|
||||||
const currentDocument = context.getDocument();
|
const currentDocument = context.getDocument();
|
||||||
|
const restoredTerrains = {
|
||||||
|
...currentDocument.terrains
|
||||||
|
};
|
||||||
|
|
||||||
|
if (previousTerrains !== null) {
|
||||||
|
for (const [terrainId, terrain] of Object.entries(previousTerrains)) {
|
||||||
|
restoredTerrains[terrainId] = cloneTerrain(terrain);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
context.setDocument({
|
context.setDocument({
|
||||||
...currentDocument,
|
...currentDocument,
|
||||||
foliageLayers: {
|
foliageLayers: {
|
||||||
...currentDocument.foliageLayers,
|
...currentDocument.foliageLayers,
|
||||||
[deletedLayer.id]: cloneFoliageLayer(deletedLayer)
|
[deletedLayer.id]: cloneFoliageLayer(deletedLayer)
|
||||||
}
|
},
|
||||||
|
terrains: restoredTerrains
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user