adds autocomplete to the crew manifest command (#11829)
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
using System.Linq;
|
||||||
using Content.Server.Administration;
|
using Content.Server.Administration;
|
||||||
using Content.Server.EUI;
|
using Content.Server.EUI;
|
||||||
using Content.Server.GameTicking;
|
using Content.Server.GameTicking;
|
||||||
@@ -232,6 +233,13 @@ public sealed class CrewManifestCommand : IConsoleCommand
|
|||||||
public string Description => "Opens the crew manifest for the given station.";
|
public string Description => "Opens the crew manifest for the given station.";
|
||||||
public string Help => $"Usage: {Command} <entity uid>";
|
public string Help => $"Usage: {Command} <entity uid>";
|
||||||
|
|
||||||
|
[Dependency] private readonly IEntityManager _entityManager = default!;
|
||||||
|
|
||||||
|
public CrewManifestCommand()
|
||||||
|
{
|
||||||
|
IoCManager.InjectDependencies(this);
|
||||||
|
}
|
||||||
|
|
||||||
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
{
|
{
|
||||||
if (args.Length != 1)
|
if (args.Length != 1)
|
||||||
@@ -240,8 +248,6 @@ public sealed class CrewManifestCommand : IConsoleCommand
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var entMan = IoCManager.Resolve<IEntityManager>();
|
|
||||||
|
|
||||||
if (!EntityUid.TryParse(args[0], out var uid))
|
if (!EntityUid.TryParse(args[0], out var uid))
|
||||||
{
|
{
|
||||||
shell.WriteLine($"{args[0]} is not a valid entity UID.");
|
shell.WriteLine($"{args[0]} is not a valid entity UID.");
|
||||||
@@ -254,8 +260,28 @@ public sealed class CrewManifestCommand : IConsoleCommand
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var crewManifestSystem = entMan.EntitySysManager.GetEntitySystem<CrewManifestSystem>();
|
var crewManifestSystem = _entityManager.System<CrewManifestSystem>();
|
||||||
|
|
||||||
crewManifestSystem.OpenEui(uid, session);
|
crewManifestSystem.OpenEui(uid, session);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public CompletionResult GetCompletion(IConsoleShell shell, string[] args)
|
||||||
|
{
|
||||||
|
if (args.Length != 1)
|
||||||
|
{
|
||||||
|
return CompletionResult.Empty;
|
||||||
|
}
|
||||||
|
|
||||||
|
var stations = _entityManager
|
||||||
|
.System<StationSystem>()
|
||||||
|
.Stations
|
||||||
|
.Select(station =>
|
||||||
|
{
|
||||||
|
var meta = _entityManager.GetComponent<MetaDataComponent>(station);
|
||||||
|
|
||||||
|
return new CompletionOption(station.ToString(), meta.EntityName);
|
||||||
|
});
|
||||||
|
|
||||||
|
return CompletionResult.FromHintOptions(stations, null);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user