* hell 💀 * you're right i'm dumb * use the beautiful protoid and or in localization 🥩 * 🙏
50 lines
1.9 KiB
C#
50 lines
1.9 KiB
C#
using System.Linq;
|
|
using Content.Shared.Chemistry.Reagent;
|
|
using Content.Shared.Mobs;
|
|
using Content.Shared.Mobs.Components;
|
|
using Content.Shared.Localizations;
|
|
using Robust.Shared.Prototypes;
|
|
using Content.Shared.Mind;
|
|
using Content.Shared.Mind.Components;
|
|
using Content.Shared.Roles;
|
|
using Content.Shared.Roles.Jobs;
|
|
using Content.Shared.Station;
|
|
using Robust.Shared.Serialization.TypeSerializers.Implementations.Custom.Prototype;
|
|
using Robust.Shared.IoC;
|
|
|
|
namespace Content.Server.Chemistry.ReagentEffectConditions
|
|
{
|
|
public sealed partial class JobCondition : ReagentEffectCondition
|
|
{
|
|
[DataField(required: true)] public List<ProtoId<JobPrototype>> Job;
|
|
|
|
public override bool Condition(ReagentEffectArgs args)
|
|
{
|
|
args.EntityManager.TryGetComponent<MindContainerComponent>(args.SolutionEntity, out var mindContainer);
|
|
if (mindContainer != null && mindContainer.Mind != null)
|
|
{
|
|
var prototypeManager = IoCManager.Resolve<IPrototypeManager>();
|
|
if (args.EntityManager.TryGetComponent<JobComponent>(mindContainer?.Mind, out var comp) && prototypeManager.TryIndex(comp.Prototype, out var prototype))
|
|
{
|
|
foreach (var jobId in Job)
|
|
{
|
|
if (prototype.ID == jobId)
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
public override string GuidebookExplanation(IPrototypeManager prototype)
|
|
{
|
|
var localizedNames = Job.Select(jobId => prototype.Index(jobId).LocalizedName).ToList();
|
|
return Loc.GetString("reagent-effect-condition-guidebook-job-condition", ("job", ContentLocalizationManager.FormatListToOr(localizedNames)));
|
|
}
|
|
}
|
|
}
|
|
|