Skip to content

Commit

Permalink
Merge branch 'dev' into Stored-Component
Browse files Browse the repository at this point in the history
  • Loading branch information
louis1706 authored Dec 26, 2024
2 parents aadc1c4 + f7aa841 commit b360027
Show file tree
Hide file tree
Showing 50 changed files with 558 additions and 211 deletions.
12 changes: 9 additions & 3 deletions EXILED/Exiled.API/Features/Core/UserSettings/SettingBase.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// -----------------------------------------------------------------------
// -----------------------------------------------------------------------
// <copyright file="SettingBase.cs" company="ExMod Team">
// Copyright (c) ExMod Team. All rights reserved.
// Licensed under the CC BY-SA 3.0 license.
Expand Down Expand Up @@ -131,7 +131,7 @@ public string HintDescription
public Action<Player, SettingBase> OnChanged { get; set; }

/// <summary>
/// Tries ti get the setting with the specified id.
/// Tries to get the setting with the specified id.
/// </summary>
/// <param name="player">Player who has received the setting.</param>
/// <param name="id">Id of the setting.</param>
Expand Down Expand Up @@ -328,7 +328,13 @@ internal static void OnSettingUpdated(ReferenceHub hub, ServerSpecificSettingBas
}

setting = list.Find(x => x.Id == settingBase.SettingId);
setting.OriginalDefinition.OnChanged?.Invoke(player, setting);

if (setting.OriginalDefinition == null)
{
Settings.Add(Create(settingBase.OriginalDefinition));
}

setting.OriginalDefinition?.OnChanged?.Invoke(player, setting);
}
}
}
6 changes: 2 additions & 4 deletions EXILED/Exiled.API/Features/Items/Armor.cs
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,6 @@ public IEnumerable<BodyArmor.ArmorCategoryLimitModifier> CategoryLimits
{
Weight = Weight,
StaminaUseMultiplier = StaminaUseMultiplier,
RemoveExcessOnDrop = RemoveExcessOnDrop,
CategoryLimits = CategoryLimits,
StaminaRegenMultiplier = StaminaRegenMultiplier,
AmmoLimits = AmmoLimits,
Expand All @@ -159,14 +158,13 @@ public IEnumerable<BodyArmor.ArmorCategoryLimitModifier> CategoryLimits
};

/// <inheritdoc/>
internal override void ReadPickupInfo(Pickup pickup)
internal override void ReadPickupInfoBefore(Pickup pickup)
{
base.ReadPickupInfo(pickup);
base.ReadPickupInfoBefore(pickup);
if (pickup is Pickups.BodyArmorPickup armorPickup)
{
HelmetEfficacy = armorPickup.HelmetEfficacy;
VestEfficacy = armorPickup.VestEfficacy;
RemoveExcessOnDrop = armorPickup.RemoveExcessOnDrop;
StaminaUseMultiplier = armorPickup.StaminaUseMultiplier;
StaminaRegenMultiplier = armorPickup.StaminaRegenMultiplier;
AmmoLimits = armorPickup.AmmoLimits;
Expand Down
4 changes: 2 additions & 2 deletions EXILED/Exiled.API/Features/Items/ExplosiveGrenade.cs
Original file line number Diff line number Diff line change
Expand Up @@ -162,9 +162,9 @@ public ExplosionGrenadeProjectile SpawnActive(Vector3 position, Player owner = n
};

/// <inheritdoc/>
internal override void ReadPickupInfo(Pickup pickup)
internal override void ReadPickupInfoBefore(Pickup pickup)
{
base.ReadPickupInfo(pickup);
base.ReadPickupInfoBefore(pickup);
if (pickup is ExplosiveGrenadePickup explosiveGrenadePickup)
{
MaxRadius = explosiveGrenadePickup.MaxRadius;
Expand Down
4 changes: 2 additions & 2 deletions EXILED/Exiled.API/Features/Items/Firearm.cs
Original file line number Diff line number Diff line change
Expand Up @@ -699,9 +699,9 @@ internal override void ChangeOwner(Player oldOwner, Player newOwner)
}

/// <inheritdoc/>
internal override void ReadPickupInfo(Pickup pickup)
internal override void ReadPickupInfoBefore(Pickup pickup)
{
base.ReadPickupInfo(pickup);
base.ReadPickupInfoBefore(pickup);

if (pickup is FirearmPickup firearmPickup)
{
Expand Down
4 changes: 2 additions & 2 deletions EXILED/Exiled.API/Features/Items/FlashGrenade.cs
Original file line number Diff line number Diff line change
Expand Up @@ -139,9 +139,9 @@ public FlashbangProjectile SpawnActive(Vector3 position, Player owner = null)
public override string ToString() => $"{Type} ({Serial}) [{Weight}] *{Scale}* |{FuseTime}|";

/// <inheritdoc/>
internal override void ReadPickupInfo(Pickup pickup)
internal override void ReadPickupInfoBefore(Pickup pickup)
{
base.ReadPickupInfo(pickup);
base.ReadPickupInfoBefore(pickup);
if (pickup is FlashGrenadePickup flashGrenadePickup)
{
MinimalDurationEffect = flashGrenadePickup.MinimalDurationEffect;
Expand Down
20 changes: 19 additions & 1 deletion EXILED/Exiled.API/Features/Items/Item.cs
Original file line number Diff line number Diff line change
Expand Up @@ -429,12 +429,30 @@ internal virtual void ChangeOwner(Player oldOwner, Player newOwner)
/// Helper method for saving data between items and pickups.
/// </summary>
/// <param name="pickup"><see cref="Pickup"/>-related data to give to the <see cref="Item"/>.</param>
internal virtual void ReadPickupInfo(Pickup pickup)
/// <remarks>
/// Analog to <see cref="ReadPickupInfoAfter(Pickup)"/>, but it is called before item initialization.
/// <see cref="ItemBase.OnAdded(ItemPickupBase)"/>.
/// </remarks>
/// <see cref="ReadPickupInfoAfter"/>
internal virtual void ReadPickupInfoBefore(Pickup pickup)
{
if (pickup is not null)
{
Scale = pickup.Scale;
}
}

/// <summary>
/// Helper method for saving data between items and pickups.
/// </summary>
/// <param name="pickup"><see cref="Pickup"/>-related data to give to the <see cref="Item"/>.</param>
/// <remarks>
/// Analog to <see cref="ReadPickupInfoAfter(Pickup)"/>, but it is called after item initialization.
/// <see cref="ItemBase.OnAdded(ItemPickupBase)"/>.
/// </remarks>
/// <see cref="ReadPickupInfoBefore"/>
internal virtual void ReadPickupInfoAfter(Pickup pickup)
{
}
}
}
4 changes: 2 additions & 2 deletions EXILED/Exiled.API/Features/Items/Jailbird.cs
Original file line number Diff line number Diff line change
Expand Up @@ -185,9 +185,9 @@ public void Break()
public override string ToString() => $"{Type} ({Serial}) [{Weight}] *{Scale}*";

/// <inheritdoc/>
internal override void ReadPickupInfo(Pickup pickup)
internal override void ReadPickupInfoBefore(Pickup pickup)
{
base.ReadPickupInfo(pickup);
base.ReadPickupInfoBefore(pickup);
if (pickup is JailbirdPickup jailbirdPickup)
{
MeleeDamage = jailbirdPickup.MeleeDamage;
Expand Down
4 changes: 2 additions & 2 deletions EXILED/Exiled.API/Features/Items/Keycard.cs
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,9 @@ public KeycardPermissions Permissions
public override string ToString() => $"{Type} ({Serial}) [{Weight}] *{Scale}* |{Permissions}|";

/// <inheritdoc/>
internal override void ReadPickupInfo(Pickup pickup)
internal override void ReadPickupInfoBefore(Pickup pickup)
{
base.ReadPickupInfo(pickup);
base.ReadPickupInfoBefore(pickup);
if (pickup is KeycardPickup keycardPickup)
{
Permissions = keycardPickup.Permissions;
Expand Down
4 changes: 2 additions & 2 deletions EXILED/Exiled.API/Features/Items/Scp244.cs
Original file line number Diff line number Diff line change
Expand Up @@ -119,9 +119,9 @@ public override Pickup CreatePickup(Vector3 position, Quaternion? rotation = nul
public override string ToString() => $"{Type} ({Serial}) [{Weight}] *{Scale}* -{Primed}-";

/// <inheritdoc/>
internal override void ReadPickupInfo(Pickup pickup)
internal override void ReadPickupInfoBefore(Pickup pickup)
{
base.ReadPickupInfo(pickup);
base.ReadPickupInfoBefore(pickup);
if (pickup is Scp244Pickup scp244)
{
Health = scp244.Health;
Expand Down
4 changes: 2 additions & 2 deletions EXILED/Exiled.API/Features/Items/Usable.cs
Original file line number Diff line number Diff line change
Expand Up @@ -136,9 +136,9 @@ public virtual void Use()
}

/// <inheritdoc/>
internal override void ReadPickupInfo(Pickup pickup)
internal override void ReadPickupInfoBefore(Pickup pickup)
{
base.ReadPickupInfo(pickup);
base.ReadPickupInfoBefore(pickup);
if (pickup is UsablePickup usablePickup)
{
UseTime = usablePickup.UseTime;
Expand Down
3 changes: 1 addition & 2 deletions EXILED/Exiled.API/Features/Pickups/BodyArmorPickup.cs
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ internal BodyArmorPickup(ItemType type)
/// <summary>
/// Gets or sets a value indicating whether excess ammo should be removed when the armor is dropped.
/// </summary>
[Obsolete("Propetry is internal, and controls armor remove logic for clearing inventory")]
public bool RemoveExcessOnDrop { get; set; }

/// <summary>
Expand Down Expand Up @@ -132,7 +133,6 @@ internal override void ReadItemInfo(Item item)
{
helmetEfficacy = armoritem.HelmetEfficacy;
vestEfficacy = armoritem.VestEfficacy;
RemoveExcessOnDrop = armoritem.RemoveExcessOnDrop;
StaminaUseMultiplier = armoritem.StaminaUseMultiplier;
StaminaRegenMultiplier = armoritem.StaminaRegenMultiplier;
AmmoLimits = armoritem.AmmoLimits;
Expand All @@ -148,7 +148,6 @@ protected override void InitializeProperties(ItemBase itemBase)
{
helmetEfficacy = armoritem.HelmetEfficacy;
vestEfficacy = armoritem.VestEfficacy;
RemoveExcessOnDrop = !armoritem.DontRemoveExcessOnDrop;
StaminaUseMultiplier = armoritem._staminaUseMultiplier;
StaminaRegenMultiplier = armoritem.StaminaRegenMultiplier;
AmmoLimits = armoritem.AmmoLimits.Select(limit => (ArmorAmmoLimit)limit);
Expand Down
9 changes: 6 additions & 3 deletions EXILED/Exiled.API/Features/Pickups/FirearmPickup.cs
Original file line number Diff line number Diff line change
Expand Up @@ -138,9 +138,12 @@ public override void Spawn()
/// <inheritdoc/>
internal override void ReadItemInfo(Items.Item item)
{
Items.Firearm firearm = (Items.Firearm)item;
MaxAmmo = firearm.PrimaryMagazine.ConstantMaxAmmo;
AmmoDrain = firearm.AmmoDrain;
if (item is Items.Firearm firearm)
{
MaxAmmo = firearm.PrimaryMagazine.ConstantMaxAmmo;
AmmoDrain = firearm.AmmoDrain;
}

base.ReadItemInfo(item);
}

Expand Down
8 changes: 4 additions & 4 deletions EXILED/Exiled.API/Features/Player.cs
Original file line number Diff line number Diff line change
Expand Up @@ -789,7 +789,7 @@ public bool IsIntercomMuted
/// <summary>
/// Gets a value indicating whether the player is speaking.
/// </summary>
public bool IsSpeaking => Role is Roles.IVoiceRole voiceRole && voiceRole.VoiceModule.IsSpeaking;
public bool IsSpeaking => Role is Roles.IVoiceRole voiceRole && voiceRole.VoiceModule.ServerIsSending;

/// <summary>
/// Gets the player's voice color.
Expand Down Expand Up @@ -2781,7 +2781,7 @@ public void AddItem(Firearm item, IEnumerable<AttachmentIdentifier> identifiers)
/// <param name="pickup">The <see cref="Pickup"/> of the item to be added.</param>
/// <param name="addReason">The reason the item was added.</param>
/// <returns>The <see cref="Item"/> that was added.</returns>
public Item AddItem(Pickup pickup, ItemAddReason addReason = ItemAddReason.Undefined) => Item.Get(Inventory.ServerAddItem(pickup.Type, addReason, pickup.Serial, pickup.Base));
public Item AddItem(Pickup pickup, ItemAddReason addReason = ItemAddReason.AdminCommand) => Item.Get(Inventory.ServerAddItem(pickup.Type, addReason, pickup.Serial, pickup.Base));

/// <summary>
/// Adds an item to the player's inventory.
Expand All @@ -2791,7 +2791,7 @@ public void AddItem(Firearm item, IEnumerable<AttachmentIdentifier> identifiers)
/// <returns>The <see cref="Item"/> that was added.</returns>
public Item AddItem(FirearmPickup pickup, IEnumerable<AttachmentIdentifier> identifiers)
{
Firearm firearm = Item.Get<Firearm>(Inventory.ServerAddItem(pickup.Type, ItemAddReason.Undefined, pickup.Serial, pickup.Base));
Firearm firearm = Item.Get<Firearm>(Inventory.ServerAddItem(pickup.Type, ItemAddReason.AdminCommand, pickup.Serial, pickup.Base));

if (identifiers is not null)
firearm.AddAttachment(identifiers);
Expand Down Expand Up @@ -3714,7 +3714,7 @@ public override bool Equals(object obj)
/// <inheritdoc />
public override int GetHashCode()
{
return ReferenceHub.GetHashCode();
return base.GetHashCode();
}

/// <summary>
Expand Down
2 changes: 0 additions & 2 deletions EXILED/Exiled.API/Features/Room.cs
Original file line number Diff line number Diff line change
Expand Up @@ -517,8 +517,6 @@ private void InternalCreate()
Log.Error($"[ROOMTYPE UNKNOWN] {this} Name : {gameObject?.name} Shape : {Identifier?.Shape}");
#endif

RoomLightControllersValue.AddRange(gameObject.GetComponentsInChildren<RoomLightController>());

RoomLightControllers = RoomLightControllersValue.AsReadOnly();

GetComponentsInChildren<BreakableWindow>().ForEach(component =>
Expand Down
2 changes: 1 addition & 1 deletion EXILED/Exiled.API/Features/TeslaGate.cs
Original file line number Diff line number Diff line change
Expand Up @@ -261,7 +261,7 @@ public void ForceTrigger()
/// </summary>
/// <param name="player">The <see cref="Player"/> to check.</param>
/// <returns><see langword="true"/> if the given <see cref="Player"/> is in the hurt range of the tesla gate; otherwise, <see langword="false"/>.</returns>
public bool IsPlayerInHurtRange(Player player) => player is not null && Vector3.Distance(Position, player.Position) <= Base.sizeOfTrigger * 2.2f;
public bool IsPlayerInHurtRange(Player player) => player is not null && Base.killers.Any(x => new Bounds(x.transform.position, Base.sizeOfKiller).Contains(player.Position));

/// <summary>
/// Gets a value indicating whether the <see cref="Player"/> is in the idle range of a specific tesla gate.
Expand Down
34 changes: 33 additions & 1 deletion EXILED/Exiled.API/Features/Toys/Speaker.cs
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,14 @@

namespace Exiled.API.Features.Toys
{
using System.Collections.Generic;

using AdminToys;
using Enums;
using Exiled.API.Interfaces;
using UnityEngine;
using VoiceChat.Networking;
using VoiceChat.Playbacks;

/// <summary>
/// A wrapper class for <see cref="SpeakerToy"/>.
Expand Down Expand Up @@ -44,7 +48,7 @@ internal Speaker(SpeakerToy speakerToy)
public float Volume
{
get => Base.NetworkVolume;
set => Base.NetworkVolume = value;
set => Base.NetworkVolume = Mathf.Clamp01(value);
}

/// <summary>
Expand Down Expand Up @@ -86,6 +90,15 @@ public float MinDistance
set => Base.NetworkMinDistance = value;
}

/// <summary>
/// Gets or sets the controller ID of speaker.
/// </summary>
public byte ControllerId
{
get => Base.NetworkControllerId;
set => Base.NetworkControllerId = value;
}

/// <summary>
/// Creates a new <see cref="Speaker"/>.
/// </summary>
Expand All @@ -108,5 +121,24 @@ public static Speaker Create(Vector3? position, Vector3? rotation, Vector3? scal

return speaker;
}

/// <summary>
/// Plays audio through this speaker.
/// </summary>
/// <param name="message">An <see cref="AudioMessage"/> instance.</param>
/// <param name="targets">Targets who will hear the audio. If <c>null</c>, audio will be sent to all players.</param>
public static void Play(AudioMessage message, IEnumerable<Player> targets = null)
{
foreach (Player target in targets ?? Player.List)
target.Connection.Send(message);
}

/// <summary>
/// Plays audio through this speaker.
/// </summary>
/// <param name="samples">Audio samples.</param>
/// <param name="length">The length of the samples array.</param>
/// <param name="targets">Targets who will hear the audio. If <c>null</c>, audio will be sent to all players.</param>
public void Play(byte[] samples, int? length = null, IEnumerable<Player> targets = null) => Play(new AudioMessage(ControllerId, samples, length ?? samples.Length), targets);
}
}
2 changes: 1 addition & 1 deletion EXILED/Exiled.Events/EventArgs/Interfaces/IItemEvent.cs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ namespace Exiled.Events.EventArgs.Interfaces
/// <summary>
/// Event args used for all <see cref="API.Features.Items.Item" /> related events.
/// </summary>
public interface IItemEvent : IExiledEvent
public interface IItemEvent : IPlayerEvent
{
/// <summary>
/// Gets the <see cref="API.Features.Items.Item" /> triggering the event.
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
// -----------------------------------------------------------------------
// <copyright file="ChangingMicroHIDPickupStateEventArgs.cs" company="ExMod Team">
// Copyright (c) ExMod Team. All rights reserved.
// Licensed under the CC BY-SA 3.0 license.
// </copyright>
// -----------------------------------------------------------------------

namespace Exiled.Events.EventArgs.Item
{
using Exiled.API.Features.Pickups;

using Interfaces;
using InventorySystem.Items.MicroHID.Modules;
using InventorySystem.Items.Pickups;

/// <summary>
/// Contains all information before MicroHID pickup state is changed.
/// </summary>
public class ChangingMicroHIDPickupStateEventArgs : IDeniableEvent, IPickupEvent
{
/// <summary>
/// Initializes a new instance of the <see cref="ChangingMicroHIDPickupStateEventArgs" /> class.
/// </summary>
/// <param name="microHID">
/// <inheritdoc cref="MicroHID" />
/// </param>
/// <param name="newPhase">
/// <inheritdoc cref="NewPhase" />
/// </param>
/// <param name="isAllowed">
/// <inheritdoc cref="IsAllowed" />
/// </param>
public ChangingMicroHIDPickupStateEventArgs(ItemPickupBase microHID, MicroHidPhase newPhase, bool isAllowed = true)
{
MicroHID = Pickup.Get<MicroHIDPickup>(microHID);
NewPhase = newPhase;
IsAllowed = isAllowed;
}

/// <summary>
/// Gets the MicroHID instance.
/// </summary>
public MicroHIDPickup MicroHID { get; }

/// <summary>
/// Gets or sets the new MicroHID state.
/// </summary>
public MicroHidPhase NewPhase { get; set; }

/// <summary>
/// Gets or sets a value indicating whether the MicroHID state can be changed.
/// </summary>
public bool IsAllowed { get; set; }

/// <inheritdoc/>
public Pickup Pickup => MicroHID;
}
}
Loading

0 comments on commit b360027

Please sign in to comment.