Merge pull request #489 from CoderCow/patch-1
Region Command Improvements, Fixed /who
This commit is contained in:
commit
6fa744e2b5
1 changed files with 63 additions and 72 deletions
|
|
@ -2819,64 +2819,26 @@ namespace TShockAPI
|
|||
break;
|
||||
case "list":
|
||||
{
|
||||
//How many regions per page
|
||||
const int pagelimit = 15;
|
||||
//How many regions per line
|
||||
const int perline = 5;
|
||||
//Pages start at 0 but are displayed and parsed at 1
|
||||
int page = 0;
|
||||
int pageNumber;
|
||||
if (!PaginationTools.TryParsePageNumber(args.Parameters, 1, args.Player, out pageNumber))
|
||||
return;
|
||||
|
||||
List<string> regionNames = new List<string>(TShock.Regions.Regions.Count);
|
||||
regionNames.AddRange(
|
||||
TShock.Regions.Regions.Where(r => r.WorldID == Main.worldID.ToString()).Select(r => r.Name)
|
||||
);
|
||||
|
||||
if (args.Parameters.Count > 1)
|
||||
{
|
||||
if (!int.TryParse(args.Parameters[1], out page) || page < 1)
|
||||
{
|
||||
args.Player.SendMessage(string.Format("Invalid page number ({0})", page), Color.Red);
|
||||
return;
|
||||
}
|
||||
page--; //Substract 1 as pages are parsed starting at 1 and not 0
|
||||
PaginationTools.SendPage(
|
||||
args.Player, pageNumber, PaginationTools.BuildLinesFromTerms(regionNames),
|
||||
new PaginationTools.Settings
|
||||
{
|
||||
HeaderFormat = "List of Regions ({0}/{1})",
|
||||
FooterFormat = "Type /region list {0} for more.",
|
||||
NothingToDisplayString = "There are currently no regions defined."
|
||||
}
|
||||
);
|
||||
|
||||
var regions = TShock.Regions.ListAllRegions(Main.worldID.ToString());
|
||||
|
||||
// Are there even any regions to display?
|
||||
if (regions.Count == 0)
|
||||
{
|
||||
args.Player.SendMessage("There are currently no regions defined.", Color.Red);
|
||||
return;
|
||||
}
|
||||
|
||||
//Check if they are trying to access a page that doesn't exist.
|
||||
int pagecount = regions.Count / pagelimit;
|
||||
if (page > pagecount)
|
||||
{
|
||||
args.Player.SendMessage(string.Format("Page number exceeds pages ({0}/{1})", page + 1, pagecount + 1), Color.Red);
|
||||
return;
|
||||
}
|
||||
|
||||
//Display the current page and the number of pages.
|
||||
args.Player.SendMessage(string.Format("Current Regions ({0}/{1}):", page + 1, pagecount + 1), Color.Green);
|
||||
|
||||
//Add up to pagelimit names to a list
|
||||
var nameslist = new List<string>();
|
||||
for (int i = (page * pagelimit); (i < ((page * pagelimit) + pagelimit)) && i < regions.Count; i++)
|
||||
{
|
||||
nameslist.Add(regions[i].Name);
|
||||
}
|
||||
|
||||
//convert the list to an array for joining
|
||||
var names = nameslist.ToArray();
|
||||
for (int i = 0; i < names.Length; i += perline)
|
||||
{
|
||||
args.Player.SendMessage(string.Join(", ", names, i, Math.Min(names.Length - i, perline)), Color.Yellow);
|
||||
}
|
||||
|
||||
if (page < pagecount)
|
||||
{
|
||||
args.Player.SendMessage(string.Format("Type /region list {0} for more regions.", (page + 2)), Color.Yellow);
|
||||
}
|
||||
|
||||
break;
|
||||
break;
|
||||
}
|
||||
case "info":
|
||||
{
|
||||
|
|
@ -3024,6 +2986,31 @@ namespace TShockAPI
|
|||
}
|
||||
break;
|
||||
}
|
||||
case "tp":
|
||||
{
|
||||
if (!args.Player.Group.HasPermission(Permissions.tp))
|
||||
{
|
||||
args.Player.SendErrorMessage("You don't have the necessary permission to do that.");
|
||||
break;
|
||||
}
|
||||
if (args.Parameters.Count <= 1)
|
||||
{
|
||||
args.Player.SendErrorMessage("Invalid syntax! Proper syntax: /region tp [region].");
|
||||
break;
|
||||
}
|
||||
|
||||
string regionName = string.Join(" ", args.Parameters.Skip(1));
|
||||
Region region = TShock.Regions.GetRegionByName(regionName);
|
||||
if (region == null)
|
||||
{
|
||||
args.Player.SendErrorMessage("Region \"{0}\" does not exist.", regionName);
|
||||
break;
|
||||
}
|
||||
|
||||
args.Player.Teleport(region.Area.Center.X, region.Area.Center.Y + 3);
|
||||
|
||||
break;
|
||||
}
|
||||
case "help":
|
||||
default:
|
||||
{
|
||||
|
|
@ -3034,24 +3021,27 @@ namespace TShockAPI
|
|||
if (!PaginationTools.TryParsePageNumber(args.Parameters, pageParamIndex, args.Player, out pageNumber))
|
||||
return;
|
||||
|
||||
List<string> lines = new List<string> {
|
||||
"set [1/2] - Sets the temporary region points.",
|
||||
"clear - Clears the temporary region points.",
|
||||
"define [name] - Defines the region with the given name.",
|
||||
"delete [name] - Deletes the given region.",
|
||||
"name - Shows the name of the region at the given point.",
|
||||
"list - Lists all regions.",
|
||||
"resize [region] [u/d/l/r] [amount] - Resizes a region.",
|
||||
"allow [user] [region] - Allows a user to a region.",
|
||||
"remove [user] [region] - Removes a user from a region.",
|
||||
"allowg [group] [region] - Allows a user group to a region.",
|
||||
"removeg [group] [region] - Removes a user group from a region.",
|
||||
"info [region] - Displays several information about the given region.",
|
||||
"protect [name] [true/false] - Sets whether the tiles inside the region are protected or not.",
|
||||
"z [name] [#] - Sets the z-order of the region.",
|
||||
};
|
||||
if (args.Player.Group.HasPermission(Permissions.tp))
|
||||
lines.Add("tp [region] - Teleports you to the given region's center.");
|
||||
|
||||
PaginationTools.SendPage(
|
||||
args.Player, pageNumber, new[]
|
||||
{
|
||||
"set [1/2] - Sets the temporary region points.",
|
||||
"clear - Clears the temporary region points.",
|
||||
"define [name] - Defines the region.",
|
||||
"delete [name] - Deletes the given region.",
|
||||
"name - Shows the name of the region at the given point.",
|
||||
"list - Lists all regions.",
|
||||
"resize [region] [u/d/l/r] [amount] - Resizes a region.",
|
||||
"allow [user] [region] - Allows a user to a region.",
|
||||
"remove [user] [region] - Removes a user from a region.",
|
||||
"allowg [group] [region] - Allows a user group to a region.",
|
||||
"removeg [group] [region] - Removes a user group from a region.",
|
||||
"info [region] - Displays several information about the given region.",
|
||||
"protect [name] [true/false] - Sets whether the tiles inside the region are protected or not.",
|
||||
"z [name] [#] - Sets the z-order of the region.",
|
||||
},
|
||||
args.Player, pageNumber, lines,
|
||||
new PaginationTools.Settings
|
||||
{
|
||||
HeaderFormat = "Available Region Sub-Commands ({0}/{1}):",
|
||||
|
|
@ -3169,7 +3159,8 @@ namespace TShockAPI
|
|||
|
||||
args.Player.SendSuccessMessage("Online Players ({0}/{1})", TShock.Utils.ActivePlayers(), TShock.Config.MaxSlots);
|
||||
PaginationTools.SendPage(
|
||||
args.Player, pageNumber, TShock.Utils.GetPlayers(displayIdsRequested), new PaginationTools.Settings
|
||||
args.Player, pageNumber, PaginationTools.BuildLinesFromTerms(TShock.Utils.GetPlayers(displayIdsRequested)),
|
||||
new PaginationTools.Settings
|
||||
{
|
||||
IncludeHeader = false,
|
||||
FooterFormat = string.Format("Type /who {0}{{0}} for more.", displayIdsRequested ? "-i " : string.Empty)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue