Arena pickers is a feature that only exists with this plugin and permits you to accomplish a wide variety of creative things.
By this, you're able to either select a specific set of arenas or one explicit one. You generally differentiate between an Arena Picker and an Arena Selector. The Arena Selector is the most common variant and can be used almost everywhere where you're able to add a name of an arena.
Alright, but what can I exactly do with that?
One usage is for example to use it within /bw join <arena selector>
. You could for instance make the player automatically join the next best available duo arena or make him automatically spectate an arena. The possibility is endless.
An other usage would be to use it within arenas gui. You might not want to display all arenas within that one. You can filter out which arenas you don't want to be displayed using an arena picker.
Commands normally do NOT send a reason why or if the arena selector didn't work. It might tell for instance tell that the given arena hasn't been found, even tho you've inserted an arena selector, but it doesn't explicitly tell you that there's something wrong with your selector. You might want to check your logs as errors and warnings will be thrown in there. Furthermore, you might want to use
/bw debug 2 <arena selector>
as that command exactly tells you if your query is valid or not.
An arena picker generally has the following format: [thruth functions]
while the brackets are being kept.
If you've programmed before you might be familar with thruth functions. They're basically a way for you to check if a property or multiple properties have the needed conditions to pass the test.
An example: [ingame_players=2]
This will check if there are exactly two players in a game.
You may connect further conditions using a &
or |
symbol.
&: AND. The left and right truth functions must be true
|: OR. Either the left, the right or both truth functions must be true
The name of the arena has to be either "Sandstorm" or "Castle".
The arena must be in lobby state and be a duo mode.
The arena with the name "Castle" may pass when it has at least one player inside it. Otherwise only the arena "Castle" may pass.
The arenas with the name "ArenaA" or "ArenaB" may pass if they are in the lobby state.
Just as in math, you'd check the insides of brackets prior others. This is useful to simplify larger statement.
There are multiple logical ways you can use to compare two things other than the =
symbol. This includes:
=
Are equal!=
Are not equal>
Number: Greater than | String: Starts with and ignore letter case<
Number: Less than | String: Ends with and ignore letter case>=
Number: Greather than or equaln | String: Starts with (letter casing must match as well)<=
Number: Less than or equaln | String: Ends with (letter casing must match as well)~
Number: Integer parts are equal (e.g. 4.31~4.52) | String: Match with letter casing ignored (e.g. "banana"~"BaNaNa")There are some variables/properties of an arena you compare with.
display_name
String The name of the arena that'll be shown to the general public. You may use the custom names feature to make the arena appear with something else. If no custom name has been set, display_name will return the same thing as name (below)name
String The exact unique name of the arenaplayers_per_team
Number The amount of players per teamteams
Number The amount of existing teamsmin_players
Number The minimum amount of players needed to start a matchmax_players
Number The maximum amount of players that may join to playingame_players
Number The amount of players who are currently playing inside the arenaremaining_players
Number The amount of left players until the arena is full (basically max_players minus ingame_players)status
Number The state of the arena. You can differentiate between:type
String The type of the arena. Read more info here. You may differentiate between: world, region, votinggame_world
String The name of the world in which the game is being held in (not the lobby world!)cloned_arena_name
String The name of the arena from which the clone has been created from. "NOT_CLONED" if the arena is not clonedserver_channel_name
String The name of the server on which the arena is located on. The name is equal to the one you have configured in BungeeCord's configurations. It likely only makes sense to use this together with the Enhanced ProxySync addon. In case you are running standalone mode (without BungeeCord), this variable will output LOCAL instead.server_playing_arenas_count
Number Get the amount of arenas that have at least 1 player on the server the arena is on. Can be useful to avoid overfilling a serverThe types (String, Number...) of the variables are important and must be kept in mind when comparing between them. E.g. string has to be put in quotes (like for instance [name="Sandstorm"]).
Tip: Use
/bw arena info <arena> picker
to see a list of all the values of your arena
The arena selector now allows you to select one or none from the arenas you filtered using you the Arena Picker.
The format is the following: %type[arena picker]%
. Keep the percentage and bracket symbols here as well.
Example: %best[status=2]%
Literally picks a random arena from the filtered ones without any logic.
Chooses the best arena for somebody to play in.
Basically, the same as the "best" type, with the only difference that it'll firstly look for existing non-voting arenas.
Can be useful when you'd like to players automatically join a running arena instead of a voting one when for instance using auto-join or a Cloud System.
Example: %best_prefer_non_voting[status=3 | type="voting"]%
-> Firstly looks for running arenas and tries to join them as a spectator. If there are none, then it'll look for voting arenas.
It firstly looks for arenas that are currently running. This may be useful in case you e.g. only want to have one active arena at a time.