Delivery system now has the possibility of penalisation (#36660)
* Add new fields to DeliveryComponent for #36636 * Setting the baseSpesoPenalty for currently available deliveries * Small fixes * Basic delivery penalization * Penalty and reward multiplier calculation in place Also fixes an issue in SharedCargoSystem when opening a delivery in dev server due to trying to allocate cargo twice. * Calling penalty no longer happens on opening * Extract multiplier getting * Removing unused include * Changing method description. \n\n Not actually sure what I meant by the first one * Localising default delivery messages * Unused include removal * minor tweaks * slarti changes * forgot * stuffs * yippee * Locn't * doc * Apply suggestions from code review --------- Co-authored-by: ScarKy0 <106310278+ScarKy0@users.noreply.github.com> Co-authored-by: ScarKy0 <scarky0@onet.eu> Co-authored-by: slarticodefast <161409025+slarticodefast@users.noreply.github.com>
This commit is contained in:
@@ -210,9 +210,21 @@ public abstract class SharedDeliverySystem : EntitySystem
|
||||
|
||||
protected virtual void GrantSpesoReward(Entity<DeliveryComponent?> ent) { }
|
||||
|
||||
protected virtual void HandlePenalty(Entity<DeliveryComponent> ent, string? reason = null) { }
|
||||
|
||||
protected virtual void SpawnDeliveries(Entity<DeliverySpawnerComponent?> ent) { }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Used to gather the multiplier from all different delivery components.
|
||||
/// </summary>
|
||||
[ByRefEvent]
|
||||
public record struct GetDeliveryMultiplierEvent(float Multiplier)
|
||||
{
|
||||
// we can't use an optional parameter because the default parameterless constructor defaults everything
|
||||
public GetDeliveryMultiplierEvent() : this(1.0f) { }
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Event raised on the delivery when it is unlocked.
|
||||
/// </summary>
|
||||
|
||||
Reference in New Issue
Block a user