Implement f status
This commit is contained in:
		
				
					committed by
					
						
						Olof Larsson
					
				
			
			
				
	
			
			
			
						parent
						
							8322528652
						
					
				
				
					commit
					8e13c1c13f
				
			@@ -68,6 +68,7 @@ permissions:
 | 
				
			|||||||
  factions.seechunkold: {description: see the chunk you stand in, default: false}
 | 
					  factions.seechunkold: {description: see the chunk you stand in, default: false}
 | 
				
			||||||
  factions.sethome: {description: set the faction home, default: false}
 | 
					  factions.sethome: {description: set the faction home, default: false}
 | 
				
			||||||
  factions.setpower: {description: set power, default: false}
 | 
					  factions.setpower: {description: set power, default: false}
 | 
				
			||||||
 | 
					  factions.status: {description: show faction status, default: false}
 | 
				
			||||||
  factions.name: {description: set faction name, default: false}
 | 
					  factions.name: {description: set faction name, default: false}
 | 
				
			||||||
  factions.title: {description: set player title, default: false}
 | 
					  factions.title: {description: set player title, default: false}
 | 
				
			||||||
  factions.title.color: {description: set player title with color, default: false}
 | 
					  factions.title.color: {description: set player title with color, default: false}
 | 
				
			||||||
@@ -146,6 +147,7 @@ permissions:
 | 
				
			|||||||
      factions.seechunkold: true
 | 
					      factions.seechunkold: true
 | 
				
			||||||
      factions.sethome: true
 | 
					      factions.sethome: true
 | 
				
			||||||
      factions.setpower: true
 | 
					      factions.setpower: true
 | 
				
			||||||
 | 
					      factions.status: true
 | 
				
			||||||
      factions.name: true
 | 
					      factions.name: true
 | 
				
			||||||
      factions.title: true
 | 
					      factions.title: true
 | 
				
			||||||
      factions.title.color: true
 | 
					      factions.title.color: true
 | 
				
			||||||
@@ -245,6 +247,7 @@ permissions:
 | 
				
			|||||||
      factions.seechunk: true
 | 
					      factions.seechunk: true
 | 
				
			||||||
      factions.seechunkold: true
 | 
					      factions.seechunkold: true
 | 
				
			||||||
      factions.sethome: true
 | 
					      factions.sethome: true
 | 
				
			||||||
 | 
					      factions.status: true
 | 
				
			||||||
      factions.name: true
 | 
					      factions.name: true
 | 
				
			||||||
      factions.title: true
 | 
					      factions.title: true
 | 
				
			||||||
      factions.title.color: true
 | 
					      factions.title.color: true
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -68,6 +68,7 @@ public enum Perm
 | 
				
			|||||||
	SEECHUNKOLD("seechunkold"),
 | 
						SEECHUNKOLD("seechunkold"),
 | 
				
			||||||
	SETHOME("sethome"),
 | 
						SETHOME("sethome"),
 | 
				
			||||||
	SETPOWER("setpower"),
 | 
						SETPOWER("setpower"),
 | 
				
			||||||
 | 
						STATUS("status"),
 | 
				
			||||||
	NAME("name"),
 | 
						NAME("name"),
 | 
				
			||||||
	TITLE("title"),
 | 
						TITLE("title"),
 | 
				
			||||||
	TITLE_COLOR("title.color"),
 | 
						TITLE_COLOR("title.color"),
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,43 @@
 | 
				
			|||||||
 | 
					package com.massivecraft.factions;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Comparator;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.massivecraft.factions.entity.MPlayer;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public class PlayerInactivityComparator implements Comparator<MPlayer>
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						// INSTANCE & CONSTRUCT
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						private static PlayerInactivityComparator i = new PlayerInactivityComparator();
 | 
				
			||||||
 | 
						public static PlayerInactivityComparator get() { return i; }
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						// OVERRIDE: COMPARATOR
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						@Override
 | 
				
			||||||
 | 
						public int compare(MPlayer m1, MPlayer m2)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							// Null
 | 
				
			||||||
 | 
							if (m1 == null && m2 == null) return 0;
 | 
				
			||||||
 | 
							else if (m1 == null) return -1;
 | 
				
			||||||
 | 
							else if (m2 == null) return +1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// Online
 | 
				
			||||||
 | 
							boolean o1 = m1.isOnline();
 | 
				
			||||||
 | 
							boolean o2 = m2.isOnline();
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							if (o1 && o2) return 0;
 | 
				
			||||||
 | 
							else if (o1) return -1;
 | 
				
			||||||
 | 
							else if (o2) return +1;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							// Inactivity Time
 | 
				
			||||||
 | 
							long r1 = m1.getLastActivityMillis();
 | 
				
			||||||
 | 
							long r2 = m2.getLastActivityMillis();
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							return (int) (r1 - r2);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										44
									
								
								src/com/massivecraft/factions/PlayerPowerComparator.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								src/com/massivecraft/factions/PlayerPowerComparator.java
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,44 @@
 | 
				
			|||||||
 | 
					package com.massivecraft.factions;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Comparator;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.massivecraft.factions.entity.MPlayer;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public class PlayerPowerComparator implements Comparator<MPlayer>
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						// INSTANCE & CONSTRUCT
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						private static PlayerPowerComparator i = new PlayerPowerComparator();
 | 
				
			||||||
 | 
						public static PlayerPowerComparator get() { return i; }
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						// OVERRIDE: COMPARATOR
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						@Override
 | 
				
			||||||
 | 
						public int compare(MPlayer m1, MPlayer m2)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							int ret = 0;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							// Null
 | 
				
			||||||
 | 
							if (m1 == null && m2 == null) return 0;
 | 
				
			||||||
 | 
							else if (m1 == null) return -1;
 | 
				
			||||||
 | 
							else if (m2 == null) return +1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// Power
 | 
				
			||||||
 | 
							int p1 = m1.getPowerRounded();
 | 
				
			||||||
 | 
							int p2 = m2.getPowerRounded();
 | 
				
			||||||
 | 
							ret = p1 - p2;
 | 
				
			||||||
 | 
							if (ret != 0) return ret;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							// MaxPower
 | 
				
			||||||
 | 
							int max1 = m1.getPowerMaxRounded();
 | 
				
			||||||
 | 
							int max2 = m2.getPowerMaxRounded();
 | 
				
			||||||
 | 
							ret = max1 - max2;
 | 
				
			||||||
 | 
								
 | 
				
			||||||
 | 
							return ret;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -18,19 +18,16 @@ public class PlayerRoleComparator implements Comparator<MPlayer>
 | 
				
			|||||||
	// -------------------------------------------- //
 | 
						// -------------------------------------------- //
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	@Override
 | 
						@Override
 | 
				
			||||||
	public int compare(MPlayer o1, MPlayer o2)
 | 
						public int compare(MPlayer m1, MPlayer m2)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		int ret = 0;
 | 
					 | 
				
			||||||
		
 | 
					 | 
				
			||||||
		// Null
 | 
							// Null
 | 
				
			||||||
		if (o1 == null && o2 == null) ret = 0;
 | 
							if (m1 == null && m2 == null) return 0;
 | 
				
			||||||
		if (o1 == null) ret = -1;
 | 
							else if (m1 == null) return -1;
 | 
				
			||||||
		if (o2 == null) ret = +1;
 | 
							else if (m2 == null) return +1;
 | 
				
			||||||
		if (ret != 0) return ret;
 | 
					 | 
				
			||||||
		
 | 
							
 | 
				
			||||||
		// Rank
 | 
							// Rank
 | 
				
			||||||
		Rel r1 = o1.getRole();
 | 
							Rel r1 = m1.getRole();
 | 
				
			||||||
		Rel r2 = o2.getRole();
 | 
							Rel r2 = m2.getRole();
 | 
				
			||||||
		return r2.getValue() - r1.getValue();
 | 
							return r2.getValue() - r1.getValue();
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -38,6 +38,7 @@ public class CmdFactions extends FactionsCommand
 | 
				
			|||||||
	public CmdFactionsMoney cmdFactionsMoney = new CmdFactionsMoney();
 | 
						public CmdFactionsMoney cmdFactionsMoney = new CmdFactionsMoney();
 | 
				
			||||||
	public CmdFactionsSeeChunk cmdFactionsSeeChunk = new CmdFactionsSeeChunk();
 | 
						public CmdFactionsSeeChunk cmdFactionsSeeChunk = new CmdFactionsSeeChunk();
 | 
				
			||||||
	public CmdFactionsSeeChunkOld cmdFactionsSeeChunkOld = new CmdFactionsSeeChunkOld();
 | 
						public CmdFactionsSeeChunkOld cmdFactionsSeeChunkOld = new CmdFactionsSeeChunkOld();
 | 
				
			||||||
 | 
						public CmdFactionsStatus cmdFactionsStatus = new CmdFactionsStatus();
 | 
				
			||||||
	public CmdFactionsClaim cmdFactionsClaim = new CmdFactionsClaim();
 | 
						public CmdFactionsClaim cmdFactionsClaim = new CmdFactionsClaim();
 | 
				
			||||||
	public CmdFactionsUnclaim cmdFactionsUnclaim = new CmdFactionsUnclaim();
 | 
						public CmdFactionsUnclaim cmdFactionsUnclaim = new CmdFactionsUnclaim();
 | 
				
			||||||
	public CmdFactionsAccess cmdFactionsAccess = new CmdFactionsAccess();
 | 
						public CmdFactionsAccess cmdFactionsAccess = new CmdFactionsAccess();
 | 
				
			||||||
@@ -67,6 +68,7 @@ public class CmdFactions extends FactionsCommand
 | 
				
			|||||||
		this.addSubCommand(this.cmdFactionsList);
 | 
							this.addSubCommand(this.cmdFactionsList);
 | 
				
			||||||
		this.addSubCommand(this.cmdFactionsFaction);
 | 
							this.addSubCommand(this.cmdFactionsFaction);
 | 
				
			||||||
		this.addSubCommand(this.cmdFactionsPlayer);
 | 
							this.addSubCommand(this.cmdFactionsPlayer);
 | 
				
			||||||
 | 
							this.addSubCommand(this.cmdFactionsStatus);
 | 
				
			||||||
		this.addSubCommand(this.cmdFactionsJoin);
 | 
							this.addSubCommand(this.cmdFactionsJoin);
 | 
				
			||||||
		this.addSubCommand(this.cmdFactionsLeave);
 | 
							this.addSubCommand(this.cmdFactionsLeave);
 | 
				
			||||||
		this.addSubCommand(this.cmdFactionsHome);
 | 
							this.addSubCommand(this.cmdFactionsHome);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										119
									
								
								src/com/massivecraft/factions/cmd/CmdFactionsStatus.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										119
									
								
								src/com/massivecraft/factions/cmd/CmdFactionsStatus.java
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,119 @@
 | 
				
			|||||||
 | 
					package com.massivecraft.factions.cmd;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Collections;
 | 
				
			||||||
 | 
					import java.util.Comparator;
 | 
				
			||||||
 | 
					import java.util.LinkedHashMap;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.massivecraft.factions.Perm;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.PlayerInactivityComparator;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.cmd.arg.ARFaction;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.cmd.arg.ARSortMPlayer;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.entity.Faction;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.entity.MPerm;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.entity.MPlayer;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.cmd.MassiveCommandException;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.cmd.arg.ARInteger;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.cmd.req.ReqHasPerm;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.pager.PagerSimple;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.pager.Stringifier;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.util.TimeDiffUtil;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.util.TimeUnit;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.util.Txt;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public class CmdFactionsStatus extends FactionsCommand
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						// CONSTRUCT
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						public CmdFactionsStatus()
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							// Aliases
 | 
				
			||||||
 | 
							this.addAliases("s", "status");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// Args
 | 
				
			||||||
 | 
							this.addOptionalArg("page", "1");
 | 
				
			||||||
 | 
							this.addOptionalArg("faction", "you");
 | 
				
			||||||
 | 
							this.addOptionalArg("sort by", "time");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// Requirements
 | 
				
			||||||
 | 
							this.addRequirements(ReqHasPerm.get(Perm.STATUS.node));
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						// OVERRIDE
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						@Override
 | 
				
			||||||
 | 
						public void perform() throws MassiveCommandException
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							// Args
 | 
				
			||||||
 | 
							Integer pageHumanBased = this.arg(0, ARInteger.get(), 1);
 | 
				
			||||||
 | 
							Faction faction = this.arg(1, ARFaction.get(), msenderFaction);
 | 
				
			||||||
 | 
							Comparator<MPlayer> sortedBy = this.arg(2, ARSortMPlayer.get(), PlayerInactivityComparator.get());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// MPerm
 | 
				
			||||||
 | 
							if ( ! MPerm.getPermStatus().has(msender, faction, true)) return;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							// Sort list
 | 
				
			||||||
 | 
							final List<MPlayer> mplayers = faction.getMPlayers();
 | 
				
			||||||
 | 
							Collections.sort(mplayers, sortedBy);
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							// Create Pager
 | 
				
			||||||
 | 
							final PagerSimple<MPlayer> pager = new PagerSimple<MPlayer>(mplayers, sender);
 | 
				
			||||||
 | 
							String pagerTitle = Txt.parse("<i>Status of %s<i>.", faction.describeTo(msender, true));
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							// Use Pager
 | 
				
			||||||
 | 
							List<String> messages = pager.getPageTxt(pageHumanBased, pagerTitle, new Stringifier<MPlayer>(){
 | 
				
			||||||
 | 
								
 | 
				
			||||||
 | 
								@Override
 | 
				
			||||||
 | 
								public String toString(MPlayer mplayer)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									// Name
 | 
				
			||||||
 | 
									String displayName = mplayer.getNameAndSomething(msender.getColorTo(mplayer).toString(), "");
 | 
				
			||||||
 | 
									int length = 15 - displayName.length();
 | 
				
			||||||
 | 
									length = length <= 0 ? 1 : length;
 | 
				
			||||||
 | 
									String whiteSpace = Txt.repeat(" ", length);
 | 
				
			||||||
 | 
									
 | 
				
			||||||
 | 
									// Power
 | 
				
			||||||
 | 
									double currentPower = mplayer.getPower();
 | 
				
			||||||
 | 
									double maxPower = mplayer.getPowerMax();
 | 
				
			||||||
 | 
									String color;
 | 
				
			||||||
 | 
									double percent = currentPower / maxPower;
 | 
				
			||||||
 | 
									
 | 
				
			||||||
 | 
									if (percent > 0.75)
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										color = "<green>";
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									else if (percent > 0.5)
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										color = "<yellow>";
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									else if (percent > 0.25)
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										color = "<rose>";
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									else
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										color = "<red>";
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								
 | 
				
			||||||
 | 
									String power = Txt.parse("<art>Power: %s%.0f<gray>/<green>%.0f", Txt.parse(color), currentPower, maxPower);
 | 
				
			||||||
 | 
									
 | 
				
			||||||
 | 
									// Time
 | 
				
			||||||
 | 
									long lastActiveMillis = mplayer.getLastActivityMillis() - System.currentTimeMillis();
 | 
				
			||||||
 | 
									LinkedHashMap<TimeUnit, Long> activeTimes = TimeDiffUtil.limit(TimeDiffUtil.unitcounts(lastActiveMillis, TimeUnit.getAllButMillis()), 3);
 | 
				
			||||||
 | 
									String lastActive = mplayer.isOnline() ? Txt.parse("<lime>Online right now.") : Txt.parse("<i>Last active: " + TimeDiffUtil.formatedMinimal(activeTimes, "<i>"));
 | 
				
			||||||
 | 
									
 | 
				
			||||||
 | 
									return Txt.parse("%s%s %s %s", displayName, whiteSpace, power, lastActive);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							});
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							// Send message
 | 
				
			||||||
 | 
							sendMessage(messages);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										64
									
								
								src/com/massivecraft/factions/cmd/arg/ARSortMPlayer.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								src/com/massivecraft/factions/cmd/arg/ARSortMPlayer.java
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,64 @@
 | 
				
			|||||||
 | 
					package com.massivecraft.factions.cmd.arg;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Collection;
 | 
				
			||||||
 | 
					import java.util.Comparator;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.bukkit.command.CommandSender;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.massivecraft.factions.PlayerInactivityComparator;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.PlayerPowerComparator;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.PlayerRoleComparator;
 | 
				
			||||||
 | 
					import com.massivecraft.factions.entity.MPlayer;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.cmd.arg.ARAbstractSelect;
 | 
				
			||||||
 | 
					import com.massivecraft.massivecore.util.MUtil;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public class ARSortMPlayer extends ARAbstractSelect<Comparator<MPlayer>>
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						// INSTANCE & CONSTRUCT
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						private static ARSortMPlayer i = new ARSortMPlayer();
 | 
				
			||||||
 | 
						public static ARSortMPlayer get() { return i; }
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						// OVERRIDE
 | 
				
			||||||
 | 
						// -------------------------------------------- //
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						@Override
 | 
				
			||||||
 | 
						public String typename()
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							return "player sorter";
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						@Override
 | 
				
			||||||
 | 
						public Comparator<MPlayer> select(String sortedBy, CommandSender sender)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							sortedBy = sortedBy.toLowerCase();
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							if (sortedBy.startsWith("r"))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								// Sort by rank
 | 
				
			||||||
 | 
								return PlayerRoleComparator.get();
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (sortedBy.startsWith("p"))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								// Sort by power
 | 
				
			||||||
 | 
								return PlayerPowerComparator.get();
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else if (sortedBy.startsWith("t"))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								// Sort by time
 | 
				
			||||||
 | 
								return PlayerInactivityComparator.get();
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							return null;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						@Override
 | 
				
			||||||
 | 
						public Collection<String> altNames(CommandSender sender)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							return MUtil.list("rank", "power", "time");
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -50,6 +50,7 @@ public class MPerm extends Entity<MPerm> implements Prioritized, Registerable
 | 
				
			|||||||
	public final static transient String ID_DISBAND = "disband";
 | 
						public final static transient String ID_DISBAND = "disband";
 | 
				
			||||||
	public final static transient String ID_FLAGS = "flags";
 | 
						public final static transient String ID_FLAGS = "flags";
 | 
				
			||||||
	public final static transient String ID_PERMS = "perms";
 | 
						public final static transient String ID_PERMS = "perms";
 | 
				
			||||||
 | 
						public final static transient String ID_STATUS = "status";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	public final static transient int PRIORITY_BUILD = 1000;
 | 
						public final static transient int PRIORITY_BUILD = 1000;
 | 
				
			||||||
	public final static transient int PRIORITY_PAINBUILD = 2000;
 | 
						public final static transient int PRIORITY_PAINBUILD = 2000;
 | 
				
			||||||
@@ -75,6 +76,7 @@ public class MPerm extends Entity<MPerm> implements Prioritized, Registerable
 | 
				
			|||||||
	public final static transient int PRIORITY_DISBAND = 21000;
 | 
						public final static transient int PRIORITY_DISBAND = 21000;
 | 
				
			||||||
	public final static transient int PRIORITY_FLAGS = 22000;
 | 
						public final static transient int PRIORITY_FLAGS = 22000;
 | 
				
			||||||
	public final static transient int PRIORITY_PERMS = 23000;
 | 
						public final static transient int PRIORITY_PERMS = 23000;
 | 
				
			||||||
 | 
						public final static transient int PRIORITY_STATUS = 24000;
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	// -------------------------------------------- //
 | 
						// -------------------------------------------- //
 | 
				
			||||||
	// META: CORE
 | 
						// META: CORE
 | 
				
			||||||
@@ -114,6 +116,7 @@ public class MPerm extends Entity<MPerm> implements Prioritized, Registerable
 | 
				
			|||||||
		getPermKick();
 | 
							getPermKick();
 | 
				
			||||||
		getPermTitle();
 | 
							getPermTitle();
 | 
				
			||||||
		getPermHome();
 | 
							getPermHome();
 | 
				
			||||||
 | 
							getPermStatus();
 | 
				
			||||||
		getPermSethome();
 | 
							getPermSethome();
 | 
				
			||||||
		getPermDeposit();
 | 
							getPermDeposit();
 | 
				
			||||||
		getPermWithdraw();
 | 
							getPermWithdraw();
 | 
				
			||||||
@@ -137,6 +140,7 @@ public class MPerm extends Entity<MPerm> implements Prioritized, Registerable
 | 
				
			|||||||
	public static MPerm getPermDesc() { return getCreative(PRIORITY_DESC, ID_DESC, ID_DESC, "set description", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
						public static MPerm getPermDesc() { return getCreative(PRIORITY_DESC, ID_DESC, ID_DESC, "set description", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
				
			||||||
	public static MPerm getPermMotd() { return getCreative(PRIORITY_MOTD, ID_MOTD, ID_MOTD, "set motd", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
						public static MPerm getPermMotd() { return getCreative(PRIORITY_MOTD, ID_MOTD, ID_MOTD, "set motd", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
				
			||||||
	public static MPerm getPermInvite() { return getCreative(PRIORITY_INVITE, ID_INVITE, ID_INVITE, "invite players", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
						public static MPerm getPermInvite() { return getCreative(PRIORITY_INVITE, ID_INVITE, ID_INVITE, "invite players", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
				
			||||||
 | 
						public static MPerm getPermStatus() { return getCreative(PRIORITY_STATUS, ID_STATUS, ID_STATUS, "show status", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
				
			||||||
	public static MPerm getPermKick() { return getCreative(PRIORITY_KICK, ID_KICK, ID_KICK, "kick members", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
						public static MPerm getPermKick() { return getCreative(PRIORITY_KICK, ID_KICK, ID_KICK, "kick members", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
				
			||||||
	public static MPerm getPermTitle() { return getCreative(PRIORITY_TITLE, ID_TITLE, ID_TITLE, "set titles", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
						public static MPerm getPermTitle() { return getCreative(PRIORITY_TITLE, ID_TITLE, ID_TITLE, "set titles", MUtil.set(Rel.LEADER, Rel.OFFICER), false, true, true); }
 | 
				
			||||||
	public static MPerm getPermHome() { return getCreative(PRIORITY_HOME, ID_HOME, ID_HOME, "teleport home", MUtil.set(Rel.LEADER, Rel.OFFICER, Rel.MEMBER, Rel.RECRUIT, Rel.ALLY), false, true, true); }
 | 
						public static MPerm getPermHome() { return getCreative(PRIORITY_HOME, ID_HOME, ID_HOME, "teleport home", MUtil.set(Rel.LEADER, Rel.OFFICER, Rel.MEMBER, Rel.RECRUIT, Rel.ALLY), false, true, true); }
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user