diff --git a/Content.Shared/_CorvaxNext/FromTileCrafter/Systems/FromTileCrafterSystem.cs b/Content.Shared/_CorvaxNext/FromTileCrafter/Systems/FromTileCrafterSystem.cs index d1aa93ecf25..1fc904daa6a 100644 --- a/Content.Shared/_CorvaxNext/FromTileCrafter/Systems/FromTileCrafterSystem.cs +++ b/Content.Shared/_CorvaxNext/FromTileCrafter/Systems/FromTileCrafterSystem.cs @@ -31,10 +31,14 @@ public override void Initialize() private void OnFromTileCraftComplete(Entity ent, ref FromTileCraftDoAfterEvent args) { - var comp = ent.Comp; + if (_netManager.IsClient) + return; + if (args.Handled || args.Cancelled) return; + var comp = ent.Comp; + var gridUid = GetEntity(args.Grid); if (!TryComp(gridUid, out var grid)) return; @@ -42,13 +46,11 @@ private void OnFromTileCraftComplete(Entity ent, ref F var tileRef = _maps.GetTileRef(gridUid, grid, args.GridTile); var coords = _maps.ToCoordinates(tileRef, grid); - var spread = comp.Spread * grid.TileSize; var offset = new Vector2( - (_robustRandom.NextFloat() - 0.5f) * spread + grid.TileSize * 0.5f, - (_robustRandom.NextFloat() - 0.5f) * spread + grid.TileSize * 0.5f); + ((_robustRandom.NextFloat() - 0.5f) * comp.Spread + 0.5f) * grid.TileSize, + ((_robustRandom.NextFloat() - 0.5f) * comp.Spread + 0.5f) * grid.TileSize); - if (_netManager.IsServer) - Spawn(ent.Comp.EntityToSpawn, coords.Offset(offset)); + Spawn(ent.Comp.EntityToSpawn, coords.Offset(offset)); } private void OnAfterInteract(Entity ent, ref AfterInteractEvent args)