From 8ab4a452eca1f692847b0b6f155d1ddc278f5424 Mon Sep 17 00:00:00 2001 From: noverd Date: Fri, 19 Apr 2024 08:15:51 +0300 Subject: [PATCH 1/4] =?UTF-8?q?=D0=A0=D0=B0=D0=BD=D0=B4=D0=BE=D0=BC=D0=BD?= =?UTF-8?q?=D0=BE=D0=B5=20=D1=81=D0=BE=D0=B1=D1=8B=D1=82=D0=B8=D0=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../RandomShipyardErrorRuleComponent.cs | 22 ++++ .../Events/RandomShipyardErrorRule.cs | 124 ++++++++++++++++++ Resources/Prototypes/_NF/Events/events.yml | 19 ++- 3 files changed, 164 insertions(+), 1 deletion(-) create mode 100644 Content.Server/_NF/GameRule/Events/Components/RandomShipyardErrorRuleComponent.cs create mode 100644 Content.Server/_NF/GameRule/Events/RandomShipyardErrorRule.cs diff --git a/Content.Server/_NF/GameRule/Events/Components/RandomShipyardErrorRuleComponent.cs b/Content.Server/_NF/GameRule/Events/Components/RandomShipyardErrorRuleComponent.cs new file mode 100644 index 00000000000..2c3be236f37 --- /dev/null +++ b/Content.Server/_NF/GameRule/Events/Components/RandomShipyardErrorRuleComponent.cs @@ -0,0 +1,22 @@ +namespace Content.Server._NF.GameRule.Events.Components; + +[RegisterComponent, Access(typeof(RandomShipyardErrorRule))] +public sealed partial class RandomShipyardErrorRuleComponent : Component +{ + /// + /// Min vessels count for spawning + /// + [DataField("minGridCount")] + public int MinGridsCount = 2; + /// + /// Man vessels count for spawning + /// + [DataField("maxGridCount")] + public int MaxGridsCount = 5; + + /// + /// The grid in question, set after starting the event + /// + [DataField("gridUid")] + public List GridUids = new(); +} diff --git a/Content.Server/_NF/GameRule/Events/RandomShipyardErrorRule.cs b/Content.Server/_NF/GameRule/Events/RandomShipyardErrorRule.cs new file mode 100644 index 00000000000..ab46c64300a --- /dev/null +++ b/Content.Server/_NF/GameRule/Events/RandomShipyardErrorRule.cs @@ -0,0 +1,124 @@ +using System.Linq; +using System.Numerics; +using Content.Server._NF.GameRule.Events.Components; +using Content.Server.Cargo.Components; +using Content.Server.Cargo.Systems; +using Robust.Server.GameObjects; +using Robust.Server.Maps; +using Robust.Shared.Map; +using Content.Server.GameTicking.Rules.Components; +using Content.Server.Shuttles.Components; +using Content.Server.Shuttles.Systems; +using Content.Server.StationEvents.Events; +using Content.Shared.Humanoid; +using Content.Shared.Mobs.Components; +using Content.Shared.Shipyard.Prototypes; +using Robust.Shared.Prototypes; +using Robust.Shared.Random; + +namespace Content.Server._NF.GameRule.Events; + +public sealed class RandomShipyardErrorRule : StationEventSystem +{ + [Dependency] private readonly IMapManager _mapManager = default!; + [Dependency] private readonly MapLoaderSystem _map = default!; + [Dependency] private readonly ShuttleSystem _shuttle = default!; + [Dependency] private readonly IRobustRandom _random = default!; + [Dependency] private readonly SharedTransformSystem _transform = default!; + [Dependency] private readonly PricingSystem _pricing = default!; + [Dependency] private readonly CargoSystem _cargo = default!; + [Dependency] private readonly IPrototypeManager _proto = default!; + + private List<(Entity Entity, EntityUid MapUid, Vector2 LocalPosition)> _playerMobs = new(); + + protected override void Started(EntityUid uid, RandomShipyardErrorRuleComponent component, + GameRuleComponent gameRule, + GameRuleStartedEvent args) + { + base.Started(uid, component, gameRule, args); + var vesselPrototypes = _proto.EnumeratePrototypes(); + var prototypes = vesselPrototypes as VesselPrototype[] ?? vesselPrototypes.ToArray(); + var rnd = new Random(); + var vesselCount = rnd.Next(component.MinGridsCount, component.MaxGridsCount); + + for (var i = 0; i < vesselCount; i++) + { + var index = rnd.Next(0, prototypes.Count()); + var gridPath = prototypes.ElementAt(index).ShuttlePath.ToString(); + var shuttleMap = _mapManager.CreateMap(); + var options = new MapLoadOptions + { + LoadMap = true, + }; + if (!_map.TryLoad(shuttleMap, gridPath, out var gridUids, options)) + return; + component.GridUids.Add(gridUids[0]); + if (component.GridUids.Last() is not { } gridUid) + return; + _shuttle.SetIFFColor(gridUid, new Color(rnd.Next(256), rnd.Next(256), rnd.Next(256), 0)); + var offset = _random.NextVector2(1800f, 2000f); + var mapId = GameTicker.DefaultMap; + var coords = new MapCoordinates(offset, mapId); + var location = Spawn(null, coords); + if (TryComp(component.GridUids.Last(), out var shuttle)) + { + _shuttle.FTLTravel(gridUid, shuttle, location, 5.5f, 55f); + } + } + } + + protected override void Ended( + EntityUid uid, + RandomShipyardErrorRuleComponent component, + GameRuleComponent gameRule, + GameRuleEndedEvent args) + { + base.Ended(uid, component, gameRule, args); + foreach (var gridId in component.GridUids) + { + + + if (!EntityManager.TryGetComponent(gridId, out var gridTransform)) + { + Log.Error("bluespace error objective was missing transform component"); + return; + } + + if (gridTransform.GridUid is not EntityUid gridUid) + { + Log.Error("bluespace error has no associated grid?"); + return; + } + + var gridValue = _pricing.AppraiseGrid(gridUid, null); + + var mobQuery = AllEntityQuery(); + _playerMobs.Clear(); + + while (mobQuery.MoveNext(out var mobUid, out _, out _, out var xform)) + { + if (xform.GridUid == null || xform.MapUid == null || xform.GridUid != gridUid) + continue; + + // Can't parent directly to map as it runs grid traversal. + _playerMobs.Add(((mobUid, xform), xform.MapUid.Value, _transform.GetWorldPosition(xform))); + _transform.DetachParentToNull(mobUid, xform); + } + + // Deletion has to happen before grid traversal re-parents players. + Del(gridUid); + + foreach (var mob in _playerMobs) + { + _transform.SetCoordinates(mob.Entity.Owner, new EntityCoordinates(mob.MapUid, mob.LocalPosition)); + } + + + var query = EntityQuery(); + foreach (var account in query) + { + _cargo.DeductFunds(account, (int) -gridValue); + } + } + } +} diff --git a/Resources/Prototypes/_NF/Events/events.yml b/Resources/Prototypes/_NF/Events/events.yml index a39ee0a9ae6..2dd5d25de5f 100644 --- a/Resources/Prototypes/_NF/Events/events.yml +++ b/Resources/Prototypes/_NF/Events/events.yml @@ -215,4 +215,21 @@ duration: 1800 maxDuration: 2400 - type: BluespaceErrorRule - gridPath: /Maps/_NF/Bluespace/bloodmoon.yml \ No newline at end of file + gridPath: /Maps/_NF/Bluespace/bloodmoon.yml + +- type: entity + id: ShipyardRandomVesselError + parent: BaseGameRule + noSpawn: true + components: + - type: StationEvent + startAnnouncement: Из-за ошибки в программном обеспечении верфи, некоторые новые суда были случайно отправлены в данный сектор. + startAudio: + path: /Audio/Misc/notice1.ogg + earliestStart: 80 + minimumPlayers: 30 + weight: 8 + startDelay: 10 + duration: 1800 + maxDuration: 2400 + - type: RandomShipyardErrorRule From 61bd8158fb608d9224f1f596bfba1385b3c20319 Mon Sep 17 00:00:00 2001 From: Kill_Me_I_Noobs <118206719+Vonsant@users.noreply.github.com> Date: Fri, 19 Apr 2024 10:00:46 +0300 Subject: [PATCH 2/4] Update events.yml --- Resources/Prototypes/_NF/Events/events.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Resources/Prototypes/_NF/Events/events.yml b/Resources/Prototypes/_NF/Events/events.yml index 2dd5d25de5f..9dc9e0e3a0f 100644 --- a/Resources/Prototypes/_NF/Events/events.yml +++ b/Resources/Prototypes/_NF/Events/events.yml @@ -216,7 +216,7 @@ maxDuration: 2400 - type: BluespaceErrorRule gridPath: /Maps/_NF/Bluespace/bloodmoon.yml - +// Corvax-start - type: entity id: ShipyardRandomVesselError parent: BaseGameRule @@ -233,3 +233,4 @@ duration: 1800 maxDuration: 2400 - type: RandomShipyardErrorRule +//Corvax-end From 46e98f9f6bd3a78aa7f207815407bcb643899753 Mon Sep 17 00:00:00 2001 From: Kill_Me_I_Noobs <118206719+Vonsant@users.noreply.github.com> Date: Fri, 19 Apr 2024 10:01:26 +0300 Subject: [PATCH 3/4] Update events.yml --- Resources/Prototypes/_NF/Events/events.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/Resources/Prototypes/_NF/Events/events.yml b/Resources/Prototypes/_NF/Events/events.yml index 9dc9e0e3a0f..4dc50e0c98c 100644 --- a/Resources/Prototypes/_NF/Events/events.yml +++ b/Resources/Prototypes/_NF/Events/events.yml @@ -216,6 +216,7 @@ maxDuration: 2400 - type: BluespaceErrorRule gridPath: /Maps/_NF/Bluespace/bloodmoon.yml + // Corvax-start - type: entity id: ShipyardRandomVesselError From 4153dca4797448c9f8ce70e2eefd88bde7b1b20d Mon Sep 17 00:00:00 2001 From: Kill_Me_I_Noobs <118206719+Vonsant@users.noreply.github.com> Date: Fri, 19 Apr 2024 10:12:35 +0300 Subject: [PATCH 4/4] Update events.yml --- Resources/Prototypes/_NF/Events/events.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Resources/Prototypes/_NF/Events/events.yml b/Resources/Prototypes/_NF/Events/events.yml index 4dc50e0c98c..6659624e9fe 100644 --- a/Resources/Prototypes/_NF/Events/events.yml +++ b/Resources/Prototypes/_NF/Events/events.yml @@ -217,7 +217,7 @@ - type: BluespaceErrorRule gridPath: /Maps/_NF/Bluespace/bloodmoon.yml -// Corvax-start +# Corvax-start - type: entity id: ShipyardRandomVesselError parent: BaseGameRule @@ -234,4 +234,4 @@ duration: 1800 maxDuration: 2400 - type: RandomShipyardErrorRule -//Corvax-end +# Corvax-end