using Content.Shared.Examine;
using Content.Shared.Localizations;
using Content.Shared.Roles;
+using Content.Shared.Verbs;
using Robust.Shared.Configuration;
using Robust.Shared.Prototypes;
+using Robust.Shared.Utility;
namespace Content.Shared.Contraband;
[Dependency] private readonly IConfigurationManager _configuration = default!;
[Dependency] private readonly IPrototypeManager _proto = default!;
[Dependency] private readonly SharedIdCardSystem _id = default!;
+ [Dependency] private readonly ExamineSystemShared _examine = default!;
private bool _contrabandExamineEnabled;
/// <inheritdoc/>
public override void Initialize()
{
- SubscribeLocalEvent<ContrabandComponent, ExaminedEvent>(OnExamined);
+ SubscribeLocalEvent<ContrabandComponent, GetVerbsEvent<ExamineVerb>>(OnDetailedExamine);
Subs.CVar(_configuration, CCVars.ContrabandExamine, SetContrabandExamine, true);
}
- private void SetContrabandExamine(bool val)
- {
- _contrabandExamineEnabled = val;
- }
-
public void CopyDetails(EntityUid uid, ContrabandComponent other, ContrabandComponent? contraband = null)
{
if (!Resolve(uid, ref contraband))
Dirty(uid, contraband);
}
- private void OnExamined(Entity<ContrabandComponent> ent, ref ExaminedEvent args)
+ private void OnDetailedExamine(EntityUid ent,ContrabandComponent component, ref GetVerbsEvent<ExamineVerb> args)
{
+
if (!_contrabandExamineEnabled)
return;
+ // CanAccess is not used here, because we want people to be able to examine legality in strip menu.
+ if (!args.CanInteract)
+ return;
+
// two strings:
// one, the actual informative 'this is restricted'
// then, the 'you can/shouldn't carry this around' based on the ID the user is wearing
-
- using (args.PushGroup(nameof(ContrabandComponent)))
+ var localizedDepartments = component.AllowedDepartments.Select(p => Loc.GetString("contraband-department-plural", ("department", Loc.GetString(_proto.Index(p).Name))));
+ var localizedJobs = component.AllowedJobs.Select(p => Loc.GetString("contraband-job-plural", ("job", _proto.Index(p).LocalizedName)));
+ var severity = _proto.Index(component.Severity);
+ String departmentExamineMessage;
+ if (severity.ShowDepartmentsAndJobs)
{
- var localizedDepartments = ent.Comp.AllowedDepartments.Select(p => Loc.GetString("contraband-department-plural", ("department", Loc.GetString(_proto.Index(p).Name))));
- var localizedJobs = ent.Comp.AllowedJobs.Select(p => Loc.GetString("contraband-job-plural", ("job", _proto.Index(p).LocalizedName)));
-
- var severity = _proto.Index(ent.Comp.Severity);
- if (severity.ShowDepartmentsAndJobs)
- {
- //creating a combined list of jobs and departments for the restricted text
- var list = ContentLocalizationManager.FormatList(localizedDepartments.Concat(localizedJobs).ToList());
+ //creating a combined list of jobs and departments for the restricted text
+ var list = ContentLocalizationManager.FormatList(localizedDepartments.Concat(localizedJobs).ToList());
+ // department restricted text
+ departmentExamineMessage = Loc.GetString("contraband-examine-text-Restricted-department", ("departments", list));
+ }
+ else
+ {
+ departmentExamineMessage = Loc.GetString(severity.ExamineText);
+ }
- // department restricted text
- args.PushMarkup(Loc.GetString("contraband-examine-text-Restricted-department", ("departments", list)));
- }
- else
+ // text based on ID card
+ List<ProtoId<DepartmentPrototype>> departments = new();
+ var jobId = "";
+ if (_id.TryFindIdCard(args.User, out var id))
+ {
+ departments = id.Comp.JobDepartments;
+ if (id.Comp.LocalizedJobTitle is not null)
{
- args.PushMarkup(Loc.GetString(severity.ExamineText));
+ jobId = id.Comp.LocalizedJobTitle;
}
+ }
- // text based on ID card
- List<ProtoId<DepartmentPrototype>> departments = new();
- var jobId = "";
+ String carryingMessage;
+ // either its fully restricted, you have no departments, or your departments dont intersect with the restricted departments
+ if (departments.Intersect(component.AllowedDepartments).Any()
+ || localizedJobs.Contains(jobId))
+ {
+ carryingMessage = Loc.GetString("contraband-examine-text-in-the-clear");
+ }
+ else
+ {
+ // otherwise fine to use :tm:
+ carryingMessage = Loc.GetString("contraband-examine-text-avoid-carrying-around");
+ }
- if (_id.TryFindIdCard(args.Examiner, out var id))
- {
- departments = id.Comp.JobDepartments;
- if (id.Comp.LocalizedJobTitle is not null)
- {
- jobId = id.Comp.LocalizedJobTitle;
- }
- }
+ var examineMarkup = GetContrabandExamine(departmentExamineMessage, carryingMessage);
+ _examine.AddDetailedExamineVerb(args,
+ component,
+ examineMarkup,
+ Loc.GetString("contraband-examinable-verb-text"),
+ "/Textures/Interface/VerbIcons/lock.svg.192dpi.png",
+ Loc.GetString("contraband-examinable-verb-message"));
+ }
- // for the jobs we compare the localized string in case you use an agent ID or custom job name that is not a prototype
- if (departments.Intersect(ent.Comp.AllowedDepartments).Any()
- || localizedJobs.Contains(jobId))
- {
- // you are allowed to use this!
- args.PushMarkup(Loc.GetString("contraband-examine-text-in-the-clear"));
- }
- else
- {
- // straight to jail!
- args.PushMarkup(Loc.GetString("contraband-examine-text-avoid-carrying-around"));
- }
- }
+ private FormattedMessage GetContrabandExamine(String deptMessage, String carryMessage)
+ {
+ var msg = new FormattedMessage();
+ msg.AddMarkupOrThrow(deptMessage);
+ msg.PushNewline();
+ msg.AddMarkupOrThrow(carryMessage);
+ return msg;
+ }
+
+ private void SetContrabandExamine(bool val)
+ {
+ _contrabandExamineEnabled = val;
}
}