Follow command and ahelp menu follow (#24142)
* Command & ahelp rename * Reviews * remove tpto
This commit is contained in:
@@ -14,7 +14,7 @@
|
|||||||
<Button Visible="False" Name="Kick" Text="{Loc 'admin-player-actions-kick'}" StyleClasses="OpenBoth" />
|
<Button Visible="False" Name="Kick" Text="{Loc 'admin-player-actions-kick'}" StyleClasses="OpenBoth" />
|
||||||
<Button Visible="False" Name="Ban" Text="{Loc 'admin-player-actions-ban'}" StyleClasses="OpenBoth" />
|
<Button Visible="False" Name="Ban" Text="{Loc 'admin-player-actions-ban'}" StyleClasses="OpenBoth" />
|
||||||
<Button Visible="False" Name="Respawn" Text="{Loc 'admin-player-actions-respawn'}" StyleClasses="OpenBoth" />
|
<Button Visible="False" Name="Respawn" Text="{Loc 'admin-player-actions-respawn'}" StyleClasses="OpenBoth" />
|
||||||
<Button Visible="False" Name="Teleport" Text="{Loc 'admin-player-actions-teleport'}" StyleClasses="OpenLeft" />
|
<Button Visible="False" Name="Follow" Text="{Loc 'admin-player-actions-follow'}" StyleClasses="OpenLeft" />
|
||||||
</BoxContainer>
|
</BoxContainer>
|
||||||
</BoxContainer>
|
</BoxContainer>
|
||||||
</SplitContainer>
|
</SplitContainer>
|
||||||
|
|||||||
@@ -138,10 +138,10 @@ namespace Content.Client.Administration.UI.Bwoink
|
|||||||
_console.ExecuteCommand($"kick \"{_currentPlayer.Username}\"");
|
_console.ExecuteCommand($"kick \"{_currentPlayer.Username}\"");
|
||||||
};
|
};
|
||||||
|
|
||||||
Teleport.OnPressed += _ =>
|
Follow.OnPressed += _ =>
|
||||||
{
|
{
|
||||||
if (_currentPlayer is not null)
|
if (_currentPlayer is not null)
|
||||||
_console.ExecuteCommand($"tpto \"{_currentPlayer.Username}\"");
|
_console.ExecuteCommand($"follow \"{_currentPlayer.NetEntity}\"");
|
||||||
};
|
};
|
||||||
|
|
||||||
Respawn.OnPressed += _ =>
|
Respawn.OnPressed += _ =>
|
||||||
@@ -204,8 +204,8 @@ namespace Content.Client.Administration.UI.Bwoink
|
|||||||
Respawn.Visible = _adminManager.CanCommand("respawn");
|
Respawn.Visible = _adminManager.CanCommand("respawn");
|
||||||
Respawn.Disabled = !Respawn.Visible || disabled;
|
Respawn.Disabled = !Respawn.Visible || disabled;
|
||||||
|
|
||||||
Teleport.Visible = _adminManager.CanCommand("tpto");
|
Follow.Visible = _adminManager.CanCommand("follow");
|
||||||
Teleport.Disabled = !Teleport.Visible || disabled;
|
Follow.Disabled = !Follow.Visible || disabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
private string FormatTabTitle(ItemList.Item li, PlayerInfo? pl = default)
|
private string FormatTabTitle(ItemList.Item li, PlayerInfo? pl = default)
|
||||||
|
|||||||
44
Content.Server/Administration/Commands/FollowCommand.cs
Normal file
44
Content.Server/Administration/Commands/FollowCommand.cs
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
using Content.Shared.Administration;
|
||||||
|
using Content.Shared.Follower;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.Enums;
|
||||||
|
|
||||||
|
namespace Content.Server.Administration.Commands;
|
||||||
|
|
||||||
|
[AdminCommand(AdminFlags.Admin)]
|
||||||
|
public sealed class FollowCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
[Dependency] private readonly IEntityManager _entManager = default!;
|
||||||
|
|
||||||
|
public string Command => "follow";
|
||||||
|
public string Description => Loc.GetString("add-uplink-command-description");
|
||||||
|
public string Help => Loc.GetString("add-uplink-command-help");
|
||||||
|
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
var player = shell.Player;
|
||||||
|
if (player == null)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-only-players-can-run-this-command"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (args.Length != 1)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-need-exactly-one-argument"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (player.Status != SessionStatus.InGame || player.AttachedEntity is not { Valid: true } playerEntity)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("shell-must-be-attached-to-entity"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var entity = args[0];
|
||||||
|
if (NetEntity.TryParse(entity, out var uidNet) && _entManager.TryGetEntity(uidNet, out var uid))
|
||||||
|
{
|
||||||
|
_entManager.System<FollowerSystem>().StartFollowingEntity(playerEntity, uid.Value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,2 @@
|
|||||||
|
follow-command-description = Makes you begin following an entity
|
||||||
|
follow-command-help = Usage: follow [netEntity]
|
||||||
@@ -8,5 +8,5 @@ admin-player-actions-spawn = Spawn here
|
|||||||
admin-player-spawn-failed = Failed to find valid coordinates
|
admin-player-spawn-failed = Failed to find valid coordinates
|
||||||
|
|
||||||
admin-player-actions-clone = Clone
|
admin-player-actions-clone = Clone
|
||||||
admin-player-actions-teleport = Teleport To
|
admin-player-actions-follow = Follow
|
||||||
admin-player-actions-confirm = Are you sure?
|
admin-player-actions-confirm = Are you sure?
|
||||||
|
|||||||
Reference in New Issue
Block a user