From 3951231fadecfbe63be89be987c937aa8fee3a9d Mon Sep 17 00:00:00 2001 From: Darkmajia Date: Thu, 12 Dec 2024 01:13:13 +0000 Subject: [PATCH] economy rebalance done yay yippie hooray --- .../Store/Systems/StoreSystem.Refund.cs | 4 +- .../Store/Systems/StoreSystem.Ui.cs | 20 ++++++- .../Changeling/ChangelingSystem.Abilities.cs | 10 ++-- .../Changeling/ChangelingSystem.cs | 55 ++++++++++++++++--- .../GameTicking/Rules/ChangelingRuleSystem.cs | 4 +- .../Store/Components/StoreComponent.cs | 13 +++++ .../Changeling/ChangelingComponent.cs | 3 + .../changeling/abilities/changeling.ftl | 1 + 8 files changed, 92 insertions(+), 18 deletions(-) diff --git a/Content.Server/Store/Systems/StoreSystem.Refund.cs b/Content.Server/Store/Systems/StoreSystem.Refund.cs index 04bd585ffcf75e..8f3b9a62ea1ce6 100644 --- a/Content.Server/Store/Systems/StoreSystem.Refund.cs +++ b/Content.Server/Store/Systems/StoreSystem.Refund.cs @@ -19,7 +19,7 @@ private void OnEntityRemoved(EntityUid uid, StoreRefundComponent component, EntR if (component.StoreEntity == null || _actions.TryGetActionData(uid, out _, false) || !TryComp(component.StoreEntity.Value, out var storeComp)) return; - DisableRefund(component.StoreEntity.Value, storeComp); + DisableRefund(uid, component.StoreEntity.Value, storeComp); } private void OnEntityInserted(EntityUid uid, StoreRefundComponent component, EntInsertedIntoContainerMessage args) @@ -27,7 +27,7 @@ private void OnEntityInserted(EntityUid uid, StoreRefundComponent component, Ent if (component.StoreEntity == null || _actions.TryGetActionData(uid, out _) || !TryComp(component.StoreEntity.Value, out var storeComp)) return; - DisableRefund(component.StoreEntity.Value, storeComp); + DisableRefund(uid, component.StoreEntity.Value, storeComp); } private void OnStoreTerminating(Entity ent, ref EntityTerminatingEvent args) diff --git a/Content.Server/Store/Systems/StoreSystem.Ui.cs b/Content.Server/Store/Systems/StoreSystem.Ui.cs index 6719035d09a9f0..62b80d7578371c 100644 --- a/Content.Server/Store/Systems/StoreSystem.Ui.cs +++ b/Content.Server/Store/Systems/StoreSystem.Ui.cs @@ -385,6 +385,9 @@ private void OnRequestRefund(EntityUid uid, StoreComponent component, StoreReque RefreshAllListings(component); component.BalanceSpent = new(); UpdateUserInterface(buyer, uid, component); + + var ev = new StoreRefundedEvent(); + RaiseLocalEvent(uid, ref ev, true); } private void HandleRefundComp(EntityUid uid, StoreComponent component, EntityUid purchase) @@ -400,15 +403,30 @@ private bool IsOnStartingMap(EntityUid store, StoreComponent component) return component.StartingMap == xform.MapUid; } + /// + /// Enables refunds for this store + /// + public void EnableRefund(EntityUid buyer, EntityUid store, StoreComponent? component = null) + { + if (!Resolve(store, ref component)) + return; + + component.RefundAllowed = true; + + UpdateUserInterface(buyer, store, component); + } + /// /// Disables refunds for this store /// - public void DisableRefund(EntityUid store, StoreComponent? component = null) + public void DisableRefund(EntityUid buyer, EntityUid store, StoreComponent? component = null) { if (!Resolve(store, ref component)) return; component.RefundAllowed = false; + + UpdateUserInterface(buyer, store, component); } } diff --git a/Content.Server/_Goobstation/Changeling/ChangelingSystem.Abilities.cs b/Content.Server/_Goobstation/Changeling/ChangelingSystem.Abilities.cs index a0e8564a17ab93..6fb69138a249f3 100644 --- a/Content.Server/_Goobstation/Changeling/ChangelingSystem.Abilities.cs +++ b/Content.Server/_Goobstation/Changeling/ChangelingSystem.Abilities.cs @@ -163,22 +163,20 @@ private void OnAbsorbDoAfter(EntityUid uid, ChangelingComponent comp, ref Absorb var popupOthers = Loc.GetString("changeling-absorb-end-others", ("user", Identity.Entity(uid, EntityManager)), ("target", Identity.Entity(target, EntityManager))); var bonusChemicals = 0f; - var bonusEvolutionPoints = 0f; + var bonusEvolutionPoints = 0; if (TryComp(target, out var targetComp)) { popupSelf = Loc.GetString("changeling-absorb-end-self-ling", ("target", Identity.Entity(target, EntityManager))); bonusChemicals += targetComp.MaxChemicals / 2; - bonusEvolutionPoints += 10; + bonusEvolutionPoints += 2; comp.MaxBiomass += targetComp.MaxBiomass / 2; } else { bonusChemicals += 10; - if (!reducedBiomass) - bonusEvolutionPoints += 2; - else + if (reducedBiomass) popupSelf = Loc.GetString("changeling-absorb-end-self-reduced-biomass", ("target", Identity.Entity(target, EntityManager))); } @@ -189,11 +187,13 @@ private void OnAbsorbDoAfter(EntityUid uid, ChangelingComponent comp, ref Absorb TryStealDNA(uid, target, comp, true); comp.TotalAbsorbedEntities++; comp.MaxChemicals += bonusChemicals; + comp.MaxEvolutionPoints += bonusEvolutionPoints; if (TryComp(args.User, out var store)) { _store.TryAddCurrency(new Dictionary { { "EvolutionPoint", bonusEvolutionPoints } }, args.User, store); _store.UpdateUserInterface(args.User, args.User, store); + _store.EnableRefund(uid, args.User, store); } if (_mind.TryGetMind(uid, out var mindId, out var mind)) diff --git a/Content.Server/_Goobstation/Changeling/ChangelingSystem.cs b/Content.Server/_Goobstation/Changeling/ChangelingSystem.cs index f6a10daa3e2cc4..a0bba7367b55ae 100644 --- a/Content.Server/_Goobstation/Changeling/ChangelingSystem.cs +++ b/Content.Server/_Goobstation/Changeling/ChangelingSystem.cs @@ -56,6 +56,8 @@ using Content.Shared.Jittering; using Content.Server.Explosion.EntitySystems; using System.Linq; +using Content.Server.Flash.Components; +using Content.Shared.Stealth.Components; namespace Content.Server.Changeling; @@ -122,9 +124,10 @@ public override void Initialize() SubscribeLocalEvent(OnMobStateChange); SubscribeLocalEvent(OnDamageChange); SubscribeLocalEvent(OnComponentRemove); - SubscribeLocalEvent(OnRefreshSpeed); + SubscribeLocalEvent(OnStoreRefunded); + SubscribeAbilities(); } @@ -631,15 +634,31 @@ public bool TryTransform(EntityUid target, ChangelingComponent comp, bool sting public void RemoveAllChangelingEquipment(EntityUid target, ChangelingComponent comp) { - // check if there's no entities or all entities are null - if (comp.Equipment.Values.Count == 0 - || comp.Equipment.Values.All(ent => ent == null ? true : false)) - return; + var playSound = false; + + // check if there's no entities in equipment, or all entities are null + if (comp.Equipment.Values.Count != 0 + || comp.Equipment.Values.All(ent => ent == null ? false : true)) + { + foreach (var equip in comp.Equipment.Values) + QueueDel(equip); + + comp.Equipment.Clear(); + playSound = true; + } + + // check if there's no entities in armor, or all entities are null + if (comp.ActiveArmor != null) + { + foreach (var armor in comp.ActiveArmor) + QueueDel(armor); - foreach (var equip in comp.Equipment.Values) - QueueDel(equip); + comp.ActiveArmor = null; + playSound = true; + } - PlayMeatySound(target, comp); + if (playSound) + PlayMeatySound(target, comp); } #endregion @@ -694,5 +713,25 @@ private void OnComponentRemove(Entity ent, ref ComponentRem RemoveAllChangelingEquipment(ent, ent.Comp); } + private void OnStoreRefunded(Entity ent, ref StoreRefundedEvent args) + { + var comp = EnsureComp(ent); + + RemoveAllChangelingEquipment(ent, comp); + comp.StrainedMusclesActive = false; + RemComp(ent); // augmented vision, yes this sucks. refactor one day i prommy - last online 9740 days ago + RemComp(ent); // chameleon skin. as above + RemComp(ent); // chameleon skin + + if (HasComp(ent)) + { + RemComp(ent); + _popup.PopupEntity(Loc.GetString("changeling-hivemind-end"), ent, ent, PopupType.MediumCaution); + } + + _speed.RefreshMovementSpeedModifiers(ent); + _store.DisableRefund(ent.Owner, ent, ent.Comp); + } + #endregion } diff --git a/Content.Server/_Goobstation/GameTicking/Rules/ChangelingRuleSystem.cs b/Content.Server/_Goobstation/GameTicking/Rules/ChangelingRuleSystem.cs index 48716d0f8adc73..b34c7d82d47044 100644 --- a/Content.Server/_Goobstation/GameTicking/Rules/ChangelingRuleSystem.cs +++ b/Content.Server/_Goobstation/GameTicking/Rules/ChangelingRuleSystem.cs @@ -70,14 +70,14 @@ public bool MakeChangeling(EntityUid target, ChangelingRuleComponent rule) _npcFaction.AddFaction(target, ChangelingFactionId); // make sure it's initial chems are set to max - EnsureComp(target); + var changelingComp = EnsureComp(target); // add store var store = EnsureComp(target); foreach (var category in rule.StoreCategories) store.Categories.Add(category); store.CurrencyWhitelist.Add(Currency); - store.Balance.Add(Currency, 10); + store.Balance.Add(Currency, changelingComp.MaxEvolutionPoints); rule.ChangelingMinds.Add(mindId); diff --git a/Content.Shared/Store/Components/StoreComponent.cs b/Content.Shared/Store/Components/StoreComponent.cs index 49d5614593edf3..281ba7edac655d 100644 --- a/Content.Shared/Store/Components/StoreComponent.cs +++ b/Content.Shared/Store/Components/StoreComponent.cs @@ -111,6 +111,19 @@ public sealed partial class StoreComponent : Component /// [ByRefEvent] public readonly record struct StoreRemovedEvent; +/// +/// Event that is broadcast when a store is refunded +/// +[ByRefEvent] +public readonly struct StoreRefundedEvent +{ + public EntityUid Uid { get; } + + public StoreRefundedEvent(EntityUid uid) + { + Uid = uid; + } +} /// /// Broadcast when an Entity with the is deleted diff --git a/Content.Shared/_Goobstation/Changeling/ChangelingComponent.cs b/Content.Shared/_Goobstation/Changeling/ChangelingComponent.cs index 087e061da9f395..28c7d9bd22e574 100644 --- a/Content.Shared/_Goobstation/Changeling/ChangelingComponent.cs +++ b/Content.Shared/_Goobstation/Changeling/ChangelingComponent.cs @@ -103,6 +103,9 @@ public sealed partial class ChangelingComponent : Component public float BiomassUpdateTimer = 0f; public float BiomassUpdateCooldown = 60f; + [DataField, AutoNetworkedField] + public int MaxEvolutionPoints = 10; + [ViewVariables(VVAccess.ReadOnly)] public List AbsorbedDNA = new(); /// diff --git a/Resources/Locale/en-US/_Goobstation/changeling/abilities/changeling.ftl b/Resources/Locale/en-US/_Goobstation/changeling/abilities/changeling.ftl index 8c6edd69c6dcd1..87bfc715531d47 100644 --- a/Resources/Locale/en-US/_Goobstation/changeling/abilities/changeling.ftl +++ b/Resources/Locale/en-US/_Goobstation/changeling/abilities/changeling.ftl @@ -70,3 +70,4 @@ changeling-chameleon-start = We adapt our skin to the environment. changeling-chameleon-end = Our skin no longer blends in. changeling-hivemind-start = We attune our brainwaves to match the greater hivemind. +changeling-hivemind-end = Our connection to the greater hivemind is severed.