mirror of
https://github.com/taoneill/war.git
synced 2025-01-07 00:08:25 +01:00
Allow changing all config options from UI
This commit is contained in:
parent
f1caca70f5
commit
f6b41bd015
@ -1,22 +1,20 @@
|
|||||||
package com.tommytony.war.config;
|
package com.tommytony.war.config;
|
||||||
|
|
||||||
|
import com.tommytony.war.War;
|
||||||
|
import com.tommytony.war.Warzone;
|
||||||
|
import com.tommytony.war.mapper.WarzoneYmlMapper;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
|
||||||
import java.util.EnumMap;
|
import java.util.EnumMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
import com.tommytony.war.mapper.WarzoneYmlMapper;
|
|
||||||
import org.bukkit.command.CommandSender;
|
|
||||||
import org.bukkit.configuration.ConfigurationSection;
|
|
||||||
|
|
||||||
import com.tommytony.war.War;
|
|
||||||
import com.tommytony.war.Warzone;
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
|
|
||||||
|
|
||||||
public class WarzoneConfigBag {
|
public class WarzoneConfigBag {
|
||||||
|
|
||||||
EnumMap<WarzoneConfig, Object> bag = new EnumMap<WarzoneConfig, Object>(WarzoneConfig.class);
|
|
||||||
private final Warzone warzone;
|
private final Warzone warzone;
|
||||||
|
EnumMap<WarzoneConfig, Object> bag = new EnumMap<WarzoneConfig, Object>(WarzoneConfig.class);
|
||||||
|
|
||||||
public WarzoneConfigBag(Warzone warzone) {
|
public WarzoneConfigBag(Warzone warzone) {
|
||||||
this.warzone = warzone;
|
this.warzone = warzone;
|
||||||
@ -27,6 +25,29 @@ public class WarzoneConfigBag {
|
|||||||
this.warzone = null;
|
this.warzone = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void afterUpdate(Warzone zone, CommandSender sender, String namedParamReturn, boolean wantsToPrint) {
|
||||||
|
WarzoneYmlMapper.save(zone);
|
||||||
|
|
||||||
|
String zoneReset = "Some changes may require a /resetzone. ";
|
||||||
|
if (zone.getWarzoneConfig().getBoolean(WarzoneConfig.RESETONCONFIGCHANGE)) {
|
||||||
|
zone.reinitialize(); // bring back team spawns etc
|
||||||
|
zoneReset = "Zone reset. ";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (wantsToPrint) {
|
||||||
|
War.war.msg(sender, "Warzone config saved. " + zoneReset + namedParamReturn + " " + War.war.printConfig(zone));
|
||||||
|
} else {
|
||||||
|
War.war.msg(sender, "Warzone config saved. " + zoneReset + namedParamReturn);
|
||||||
|
}
|
||||||
|
|
||||||
|
War.war.log(sender.getName() + " updated warzone " + zone.getName() + " configuration." + namedParamReturn, Level.INFO);
|
||||||
|
|
||||||
|
if (War.war.getWarHub() != null) { // maybe the zone was disabled/enabled
|
||||||
|
War.war.getWarHub().getVolume().resetBlocks();
|
||||||
|
War.war.getWarHub().initialize();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void put(WarzoneConfig config, Object value) {
|
public void put(WarzoneConfig config, Object value) {
|
||||||
bag.put(config, value);
|
bag.put(config, value);
|
||||||
}
|
}
|
||||||
@ -71,6 +92,10 @@ public class WarzoneConfigBag {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean contains(WarzoneConfig config) {
|
||||||
|
return this.bag.containsKey(config);
|
||||||
|
}
|
||||||
|
|
||||||
public void loadFrom(ConfigurationSection warzoneConfigSection) {
|
public void loadFrom(ConfigurationSection warzoneConfigSection) {
|
||||||
for (WarzoneConfig config : WarzoneConfig.values()) {
|
for (WarzoneConfig config : WarzoneConfig.values()) {
|
||||||
if (warzoneConfigSection.contains(config.toString())) {
|
if (warzoneConfigSection.contains(config.toString())) {
|
||||||
@ -133,27 +158,4 @@ public class WarzoneConfigBag {
|
|||||||
}
|
}
|
||||||
return returnMessage;
|
return returnMessage;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void afterUpdate(Warzone zone, CommandSender sender, String namedParamReturn, boolean wantsToPrint) {
|
|
||||||
WarzoneYmlMapper.save(zone);
|
|
||||||
|
|
||||||
String zoneReset = "Some changes may require a /resetzone. ";
|
|
||||||
if (zone.getWarzoneConfig().getBoolean(WarzoneConfig.RESETONCONFIGCHANGE)) {
|
|
||||||
zone.reinitialize(); // bring back team spawns etc
|
|
||||||
zoneReset = "Zone reset. ";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (wantsToPrint) {
|
|
||||||
War.war.msg(sender, "Warzone config saved. " + zoneReset + namedParamReturn + " " + War.war.printConfig(zone));
|
|
||||||
} else {
|
|
||||||
War.war.msg(sender, "Warzone config saved. " + zoneReset + namedParamReturn);
|
|
||||||
}
|
|
||||||
|
|
||||||
War.war.log(sender.getName() + " updated warzone " + zone.getName() + " configuration." + namedParamReturn, Level.INFO);
|
|
||||||
|
|
||||||
if (War.war.getWarHub() != null) { // maybe the zone was disabled/enabled
|
|
||||||
War.war.getWarHub().getVolume().resetBlocks();
|
|
||||||
War.war.getWarHub().initialize();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,21 +1,17 @@
|
|||||||
package com.tommytony.war.ui;
|
package com.tommytony.war.ui;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
|
||||||
import com.tommytony.war.Team;
|
import com.tommytony.war.Team;
|
||||||
import com.tommytony.war.War;
|
import com.tommytony.war.War;
|
||||||
import com.tommytony.war.Warzone;
|
import com.tommytony.war.Warzone;
|
||||||
import com.tommytony.war.config.TeamConfig;
|
|
||||||
import com.tommytony.war.config.TeamConfigBag;
|
import com.tommytony.war.config.TeamConfigBag;
|
||||||
import com.tommytony.war.mapper.WarzoneYmlMapper;
|
import com.tommytony.war.mapper.WarzoneYmlMapper;
|
||||||
import com.tommytony.war.volume.Volume;
|
import com.tommytony.war.volume.Volume;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.DyeColor;
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.Inventory;
|
import org.bukkit.inventory.Inventory;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.meta.ItemMeta;
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
import org.bukkit.material.Wool;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by Connor on 7/27/2017.
|
* Created by Connor on 7/27/2017.
|
||||||
@ -71,39 +67,8 @@ public class EditTeamUI extends ChestUI {
|
|||||||
War.war.msg(player, "Team " + team.getName() + " removed.");
|
War.war.msg(player, "Team " + team.getName() + " removed.");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
for (final TeamConfig option : TeamConfig.values()) {
|
final TeamConfigBag config = team.getTeamConfig();
|
||||||
if (option.getTitle() == null) {
|
UIConfigHelper.addTeamConfigOptions(this, player, inv, config, team, team.getZone(), i);
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (option.getConfigType() == Boolean.class) {
|
|
||||||
item = new Wool(team.getTeamConfig().resolveBoolean(option) ? DyeColor.LIME : DyeColor.RED).toItemStack(1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
team.getTeamConfig().put(option, !team.getTeamConfig().resolveBoolean(option));
|
|
||||||
TeamConfigBag.afterUpdate(team, player, option.name() + " set to " + team.getTeamConfig().resolveBoolean(option), false);
|
|
||||||
War.war.getUIManager().assignUI(player, new EditTeamUI(team));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
item = new ItemStack(Material.COMPASS, 1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
player.sendTitle(option.getTitle(), team.getTeamConfig().resolveValue(option).toString(), 10, 70, 20);
|
|
||||||
War.war.getUIManager().assignUI(player, new EditTeamUI(team));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,20 +1,13 @@
|
|||||||
package com.tommytony.war.ui;
|
package com.tommytony.war.ui;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
|
||||||
import com.tommytony.war.War;
|
import com.tommytony.war.War;
|
||||||
import com.tommytony.war.Warzone;
|
import com.tommytony.war.Warzone;
|
||||||
import com.tommytony.war.config.TeamConfig;
|
|
||||||
import com.tommytony.war.config.TeamConfigBag;
|
|
||||||
import com.tommytony.war.config.WarzoneConfig;
|
|
||||||
import com.tommytony.war.config.WarzoneConfigBag;
|
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.DyeColor;
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.Inventory;
|
import org.bukkit.inventory.Inventory;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.meta.ItemMeta;
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
import org.bukkit.material.Wool;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by Connor on 7/27/2017.
|
* Created by Connor on 7/27/2017.
|
||||||
@ -33,39 +26,7 @@ public class EditZoneConfigUI extends ChestUI {
|
|||||||
ItemMeta meta;
|
ItemMeta meta;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
for (final WarzoneConfig option : WarzoneConfig.values()) {
|
i = UIConfigHelper.addWarzoneConfigOptions(this, player, inv, zone.getWarzoneConfig(), zone, i);
|
||||||
if (option.getTitle() == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (option.getConfigType() == Boolean.class) {
|
|
||||||
item = new Wool(zone.getWarzoneConfig().getBoolean(option) ? DyeColor.LIME : DyeColor.RED).toItemStack(1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
zone.getWarzoneConfig().put(option, !zone.getWarzoneConfig().getBoolean(option));
|
|
||||||
WarzoneConfigBag.afterUpdate(zone, player, option.name() + " set to " + zone.getWarzoneConfig().getBoolean(option), false);
|
|
||||||
War.war.getUIManager().assignUI(player, new EditZoneConfigUI(zone));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
item = new ItemStack(Material.COMPASS, 1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
player.sendTitle(option.getTitle(), zone.getWarzoneConfig().getValue(option).toString(), 10, 70, 20);
|
|
||||||
War.war.getUIManager().assignUI(player, new EditZoneConfigUI(zone));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
item = new ItemStack(Material.STAINED_GLASS_PANE);
|
item = new ItemStack(Material.STAINED_GLASS_PANE);
|
||||||
meta = item.getItemMeta();
|
meta = item.getItemMeta();
|
||||||
meta.setDisplayName(">>>> Team Default Config >>>>");
|
meta.setDisplayName(">>>> Team Default Config >>>>");
|
||||||
@ -76,39 +37,7 @@ public class EditZoneConfigUI extends ChestUI {
|
|||||||
War.war.getUIManager().assignUI(player, new EditZoneConfigUI(zone));
|
War.war.getUIManager().assignUI(player, new EditZoneConfigUI(zone));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
for (final TeamConfig option : TeamConfig.values()) {
|
UIConfigHelper.addTeamConfigOptions(this, player, inv, zone.getTeamDefaultConfig(), null, zone, i);
|
||||||
if (option.getTitle() == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (option.getConfigType() == Boolean.class) {
|
|
||||||
item = new Wool(zone.getTeamDefaultConfig().resolveBoolean(option) ? DyeColor.LIME : DyeColor.RED).toItemStack(1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
zone.getTeamDefaultConfig().put(option, !zone.getTeamDefaultConfig().resolveBoolean(option));
|
|
||||||
WarzoneConfigBag.afterUpdate(zone, player, option.name() + " set to " + zone.getTeamDefaultConfig().resolveBoolean(option), false);
|
|
||||||
War.war.getUIManager().assignUI(player, new EditZoneConfigUI(zone));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
item = new ItemStack(Material.COMPASS, 1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
player.sendTitle(option.getTitle(), zone.getTeamDefaultConfig().resolveValue(option).toString(), 10, 70, 20);
|
|
||||||
War.war.getUIManager().assignUI(player, new EditZoneConfigUI(zone));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
338
war/src/main/java/com/tommytony/war/ui/UIConfigHelper.java
Normal file
338
war/src/main/java/com/tommytony/war/ui/UIConfigHelper.java
Normal file
@ -0,0 +1,338 @@
|
|||||||
|
package com.tommytony.war.ui;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableList;
|
||||||
|
import com.tommytony.war.Team;
|
||||||
|
import com.tommytony.war.War;
|
||||||
|
import com.tommytony.war.Warzone;
|
||||||
|
import com.tommytony.war.config.*;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.DyeColor;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.Inventory;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
|
import org.bukkit.material.Dye;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Connor on 7/28/2017.
|
||||||
|
*/
|
||||||
|
public class UIConfigHelper {
|
||||||
|
static int addTeamConfigOptions(final ChestUI ui, final Player player, Inventory inv, final TeamConfigBag config, final Team team, final Warzone warzone, int i) {
|
||||||
|
ItemStack item;
|
||||||
|
ItemMeta meta;
|
||||||
|
for (final TeamConfig option : TeamConfig.values()) {
|
||||||
|
if (option.getTitle() == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
String inheritance = "";
|
||||||
|
if (!config.contains(option) && warzone != null) {
|
||||||
|
if (warzone.getTeamDefaultConfig().contains(option)) {
|
||||||
|
inheritance = ChatColor.DARK_GRAY + "Inherited from warzone config defaults";
|
||||||
|
} else {
|
||||||
|
inheritance = ChatColor.DARK_GRAY + "Inherited from War config defaults";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String name = ChatColor.RESET + "" + ChatColor.YELLOW + option.getTitle();
|
||||||
|
String status = ChatColor.GRAY + "Currently: ";
|
||||||
|
String[] desc = option.getDescription().split("\n");
|
||||||
|
for (int j = 0; j < desc.length; j++) {
|
||||||
|
desc[j] = ChatColor.RESET + "" + ChatColor.GRAY + desc[j];
|
||||||
|
}
|
||||||
|
if (option.getConfigType() == Boolean.class) {
|
||||||
|
status += config.resolveBoolean(option) ? ChatColor.GREEN + "true" : ChatColor.DARK_GRAY + "false";
|
||||||
|
item = new Dye(config.resolveBoolean(option) ? DyeColor.LIME : DyeColor.GRAY).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
config.put(option, !config.resolveBoolean(option));
|
||||||
|
onTeamConfigUpdate(player, option, config, team, warzone);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if (option.getConfigType() == Integer.class || option.getConfigType() == Double.class || option.getConfigType() == String.class) {
|
||||||
|
status += ChatColor.LIGHT_PURPLE + config.resolveValue(option).toString();
|
||||||
|
item = new Dye(DyeColor.PURPLE).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
War.war.getUIManager().getPlayerMessage(player, "Type a new value for option " + option.name().toLowerCase() + ": ", new StringRunnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (option.getConfigType() == Integer.class) {
|
||||||
|
config.put(option, Integer.parseInt(this.getValue()));
|
||||||
|
} else if (option.getConfigType() == Double.class) {
|
||||||
|
config.put(option, Double.parseDouble(this.getValue()));
|
||||||
|
} else {
|
||||||
|
config.put(option, this.getValue());
|
||||||
|
}
|
||||||
|
onTeamConfigUpdate(player, option, config, team, warzone);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if (option.getConfigType() == FlagReturn.class) {
|
||||||
|
status += ChatColor.YELLOW + config.resolveValue(option).toString();
|
||||||
|
item = new Dye(DyeColor.PINK).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
FlagReturn next = FlagReturn.BOTH;
|
||||||
|
FlagReturn[] values = FlagReturn.values();
|
||||||
|
for (int i1 = 0; i1 < values.length; i1++) {
|
||||||
|
FlagReturn flagReturn = values[i1];
|
||||||
|
if (flagReturn == config.resolveFlagReturn() && i1 != values.length - 1) {
|
||||||
|
next = values[i1 + 1];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
config.put(option, next);
|
||||||
|
onTeamConfigUpdate(player, option, config, team, warzone);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if (option.getConfigType() == TeamSpawnStyle.class) {
|
||||||
|
status += ChatColor.YELLOW + config.resolveValue(option).toString();
|
||||||
|
item = new Dye(DyeColor.PINK).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
TeamSpawnStyle next = TeamSpawnStyle.INVISIBLE;
|
||||||
|
TeamSpawnStyle[] values = TeamSpawnStyle.values();
|
||||||
|
for (int i1 = 0; i1 < values.length; i1++) {
|
||||||
|
TeamSpawnStyle tss = values[i1];
|
||||||
|
if (tss == config.resolveSpawnStyle() && i1 != values.length - 1) {
|
||||||
|
next = values[i1 + 1];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
config.put(option, next);
|
||||||
|
onTeamConfigUpdate(player, option, config, team, warzone);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
status += ChatColor.RED + config.resolveValue(option).toString();
|
||||||
|
item = new ItemStack(Material.COMPASS, 1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void onTeamConfigUpdate(Player player, TeamConfig option, TeamConfigBag config, Team team, Warzone warzone) {
|
||||||
|
if (team != null) {
|
||||||
|
TeamConfigBag.afterUpdate(team, player, option.name() + " set to " + config.resolveValue(option).toString(), false);
|
||||||
|
War.war.getUIManager().assignUI(player, new EditTeamUI(team));
|
||||||
|
} else if (warzone != null) {
|
||||||
|
WarzoneConfigBag.afterUpdate(warzone, player, option.name() + " set to " + config.resolveValue(option).toString(), false);
|
||||||
|
War.war.getUIManager().assignUI(player, new EditZoneConfigUI(warzone));
|
||||||
|
} else {
|
||||||
|
WarConfigBag.afterUpdate(player, option.name() + " set to " + config.resolveValue(option).toString(), false);
|
||||||
|
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static int addWarzoneConfigOptions(final ChestUI ui, final Player player, Inventory inv, final WarzoneConfigBag config, final Warzone warzone, int i) {
|
||||||
|
ItemStack item;
|
||||||
|
ItemMeta meta;
|
||||||
|
for (final WarzoneConfig option : WarzoneConfig.values()) {
|
||||||
|
if (option.getTitle() == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
String inheritance = "";
|
||||||
|
if (!config.contains(option)) {
|
||||||
|
inheritance = ChatColor.DARK_GRAY + "Inherited from War config defaults";
|
||||||
|
}
|
||||||
|
|
||||||
|
String name = ChatColor.RESET + "" + ChatColor.YELLOW + option.getTitle();
|
||||||
|
String status = ChatColor.GRAY + "Currently: ";
|
||||||
|
String[] desc = option.getDescription().split("\n");
|
||||||
|
for (int j = 0; j < desc.length; j++) {
|
||||||
|
desc[j] = ChatColor.RESET + "" + ChatColor.GRAY + desc[j];
|
||||||
|
}
|
||||||
|
if (option.getConfigType() == Boolean.class) {
|
||||||
|
status += config.getBoolean(option) ? ChatColor.GREEN + "true" : ChatColor.DARK_GRAY + "false";
|
||||||
|
item = new Dye(config.getBoolean(option) ? DyeColor.LIME : DyeColor.GRAY).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
config.put(option, !config.getBoolean(option));
|
||||||
|
onWarzoneConfigUpdate(player, option, config, warzone);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if (option.getConfigType() == Integer.class || option.getConfigType() == Double.class || option.getConfigType() == String.class) {
|
||||||
|
status += ChatColor.LIGHT_PURPLE + config.getValue(option).toString();
|
||||||
|
item = new Dye(DyeColor.PURPLE).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
War.war.getUIManager().getPlayerMessage(player, "Type a new value for option " + option.name().toLowerCase() + ": ", new StringRunnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (option.getConfigType() == Integer.class) {
|
||||||
|
config.put(option, Integer.parseInt(this.getValue()));
|
||||||
|
} else if (option.getConfigType() == Double.class) {
|
||||||
|
config.put(option, Double.parseDouble(this.getValue()));
|
||||||
|
} else {
|
||||||
|
config.put(option, this.getValue());
|
||||||
|
}
|
||||||
|
onWarzoneConfigUpdate(player, option, config, warzone);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if (option.getConfigType() == ScoreboardType.class) {
|
||||||
|
status += ChatColor.YELLOW + config.getValue(option).toString();
|
||||||
|
item = new Dye(DyeColor.PINK).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
ScoreboardType next = ScoreboardType.NONE;
|
||||||
|
ScoreboardType[] values = ScoreboardType.values();
|
||||||
|
for (int i1 = 0; i1 < values.length; i1++) {
|
||||||
|
ScoreboardType st = values[i1];
|
||||||
|
if (st == config.getScoreboardType(option) && i1 != values.length - 1) {
|
||||||
|
next = values[i1 + 1];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
config.put(option, next);
|
||||||
|
onWarzoneConfigUpdate(player, option, config, warzone);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
status += ChatColor.RED + config.getValue(option).toString();
|
||||||
|
item = new ItemStack(Material.COMPASS, 1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).add(inheritance).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void onWarzoneConfigUpdate(Player player, WarzoneConfig option, WarzoneConfigBag config, Warzone warzone) {
|
||||||
|
if (warzone != null) {
|
||||||
|
WarzoneConfigBag.afterUpdate(warzone, player, option.name() + " set to " + config.getValue(option).toString(), false);
|
||||||
|
War.war.getUIManager().assignUI(player, new EditZoneConfigUI(warzone));
|
||||||
|
} else {
|
||||||
|
WarConfigBag.afterUpdate(player, option.name() + " set to " + config.getValue(option).toString(), false);
|
||||||
|
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static int addWarConfigOptions(final ChestUI ui, final Player player, Inventory inv, final WarConfigBag config, int i) {
|
||||||
|
ItemStack item;
|
||||||
|
ItemMeta meta;
|
||||||
|
for (final WarConfig option : WarConfig.values()) {
|
||||||
|
if (option.getTitle() == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
String name = ChatColor.RESET + "" + ChatColor.YELLOW + option.getTitle();
|
||||||
|
String status = ChatColor.GRAY + "Currently: ";
|
||||||
|
String[] desc = option.getDescription().split("\n");
|
||||||
|
for (int j = 0; j < desc.length; j++) {
|
||||||
|
desc[j] = ChatColor.RESET + "" + ChatColor.GRAY + desc[j];
|
||||||
|
}
|
||||||
|
if (option.getConfigType() == Boolean.class) {
|
||||||
|
status += config.getBoolean(option) ? ChatColor.GREEN + "true" : ChatColor.DARK_GRAY + "false";
|
||||||
|
item = new Dye(config.getBoolean(option) ? DyeColor.LIME : DyeColor.GRAY).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
config.put(option, !config.getBoolean(option));
|
||||||
|
onWarConfigUpdate(player, option, config);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if (option.getConfigType() == Integer.class || option.getConfigType() == Double.class || option.getConfigType() == String.class) {
|
||||||
|
status += ChatColor.LIGHT_PURPLE + config.getValue(option).toString();
|
||||||
|
item = new Dye(DyeColor.PURPLE).toItemStack(1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
War.war.getUIManager().getPlayerMessage(player, "Type a new value for option " + option.name().toLowerCase() + ": ", new StringRunnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (option.getConfigType() == Integer.class) {
|
||||||
|
config.put(option, Integer.parseInt(this.getValue()));
|
||||||
|
} else if (option.getConfigType() == Double.class) {
|
||||||
|
config.put(option, Double.parseDouble(this.getValue()));
|
||||||
|
} else {
|
||||||
|
config.put(option, this.getValue());
|
||||||
|
}
|
||||||
|
onWarConfigUpdate(player, option, config);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
status += ChatColor.RED + config.getValue(option).toString();
|
||||||
|
item = new ItemStack(Material.COMPASS, 1);
|
||||||
|
meta = item.getItemMeta();
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
meta.setLore(new ImmutableList.Builder<String>().add(desc).add(status).build());
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
ui.addItem(inv, i++, item, new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void onWarConfigUpdate(Player player, WarConfig option, WarConfigBag config) {
|
||||||
|
WarConfigBag.afterUpdate(player, option.name() + " set to " + config.getValue(option).toString(), false);
|
||||||
|
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
||||||
|
}
|
||||||
|
}
|
@ -1,19 +1,12 @@
|
|||||||
package com.tommytony.war.ui;
|
package com.tommytony.war.ui;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
|
||||||
import com.tommytony.war.War;
|
import com.tommytony.war.War;
|
||||||
import com.tommytony.war.config.TeamConfig;
|
|
||||||
import com.tommytony.war.config.WarConfig;
|
|
||||||
import com.tommytony.war.config.WarConfigBag;
|
|
||||||
import com.tommytony.war.config.WarzoneConfig;
|
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.DyeColor;
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.Inventory;
|
import org.bukkit.inventory.Inventory;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.meta.ItemMeta;
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
import org.bukkit.material.Wool;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by Connor on 7/27/2017.
|
* Created by Connor on 7/27/2017.
|
||||||
@ -25,39 +18,7 @@ public class WarAdminUI extends ChestUI {
|
|||||||
ItemMeta meta;
|
ItemMeta meta;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
for (final WarConfig option : WarConfig.values()) {
|
i = UIConfigHelper.addWarConfigOptions(this, player, inv, War.war.getWarConfig(), i);
|
||||||
if (option.getTitle() == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (option.getConfigType() == Boolean.class) {
|
|
||||||
item = new Wool(War.war.getWarConfig().getBoolean(option) ? DyeColor.LIME : DyeColor.RED).toItemStack(1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
War.war.getWarConfig().put(option, !War.war.getWarConfig().getBoolean(option));
|
|
||||||
WarConfigBag.afterUpdate(player, option.name() + " set to " + War.war.getWarConfig().getBoolean(option), false);
|
|
||||||
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
item = new ItemStack(Material.COMPASS, 1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
player.sendTitle(option.getTitle(), War.war.getWarConfig().getValue(option).toString(), 10, 70, 20);
|
|
||||||
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
item = new ItemStack(Material.STAINED_GLASS_PANE);
|
item = new ItemStack(Material.STAINED_GLASS_PANE);
|
||||||
meta = item.getItemMeta();
|
meta = item.getItemMeta();
|
||||||
meta.setDisplayName(">>>> Warzone Default Config >>>>");
|
meta.setDisplayName(">>>> Warzone Default Config >>>>");
|
||||||
@ -68,39 +29,7 @@ public class WarAdminUI extends ChestUI {
|
|||||||
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
for (final WarzoneConfig option : WarzoneConfig.values()) {
|
i = UIConfigHelper.addWarzoneConfigOptions(this, player, inv, War.war.getWarzoneDefaultConfig(), null, i);
|
||||||
if (option.getTitle() == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (option.getConfigType() == Boolean.class) {
|
|
||||||
item = new Wool(War.war.getWarzoneDefaultConfig().getBoolean(option) ? DyeColor.LIME : DyeColor.RED).toItemStack(1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
War.war.getWarzoneDefaultConfig().put(option, !War.war.getWarzoneDefaultConfig().getBoolean(option));
|
|
||||||
WarConfigBag.afterUpdate(player, option.name() + " set to " + War.war.getWarzoneDefaultConfig().getBoolean(option), false);
|
|
||||||
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
item = new ItemStack(Material.COMPASS, 1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
player.sendTitle(option.getTitle(), War.war.getWarzoneDefaultConfig().getValue(option).toString(), 10, 70, 20);
|
|
||||||
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
item = new ItemStack(Material.STAINED_GLASS_PANE);
|
item = new ItemStack(Material.STAINED_GLASS_PANE);
|
||||||
meta = item.getItemMeta();
|
meta = item.getItemMeta();
|
||||||
meta.setDisplayName(">>>> Team Default Config >>>>");
|
meta.setDisplayName(">>>> Team Default Config >>>>");
|
||||||
@ -111,39 +40,7 @@ public class WarAdminUI extends ChestUI {
|
|||||||
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
for (final TeamConfig option : TeamConfig.values()) {
|
UIConfigHelper.addTeamConfigOptions(this, player, inv, War.war.getTeamDefaultConfig(), null, null, i);
|
||||||
if (option.getTitle() == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (option.getConfigType() == Boolean.class) {
|
|
||||||
item = new Wool(War.war.getTeamDefaultConfig().resolveBoolean(option) ? DyeColor.LIME : DyeColor.RED).toItemStack(1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
War.war.getTeamDefaultConfig().put(option, !War.war.getTeamDefaultConfig().resolveBoolean(option));
|
|
||||||
WarConfigBag.afterUpdate(player, option.name() + " set to " + War.war.getTeamDefaultConfig().resolveBoolean(option), false);
|
|
||||||
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
item = new ItemStack(Material.COMPASS, 1);
|
|
||||||
meta = item.getItemMeta();
|
|
||||||
meta.setDisplayName(option.getTitle());
|
|
||||||
meta.setLore(ImmutableList.of(option.getDescription()));
|
|
||||||
item.setItemMeta(meta);
|
|
||||||
this.addItem(inv, i++, item, new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
player.sendTitle(option.getTitle(), War.war.getTeamDefaultConfig().resolveValue(option).toString(), 10, 70, 20);
|
|
||||||
War.war.getUIManager().assignUI(player, new WarAdminUI());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -91,6 +91,10 @@ zone.battle.resetprogress = Progression: {0}%, {1} secondes pass\u00e9...
|
|||||||
zone.battle.resetcomplete = Carte r\u00e9initialis\u00e9e en {0} secondes. Une nouvelle bataille va commencer !
|
zone.battle.resetcomplete = Carte r\u00e9initialis\u00e9e en {0} secondes. Une nouvelle bataille va commencer !
|
||||||
zone.bomb.broadcast = {0} a explos\u00e9 la base de l''\u00e9quipe {1}. L''\u00e9quipe {2} gagne 1 point.
|
zone.bomb.broadcast = {0} a explos\u00e9 la base de l''\u00e9quipe {1}. L''\u00e9quipe {2} gagne 1 point.
|
||||||
zone.cake.broadcast = {0} a ramen\u00e9 le g\u00e2teau {1} \u00e0 sa base. L''\u00e9quipe {2} gagne un point et r\u00e9cup\u00e8re toutes ses vies.
|
zone.cake.broadcast = {0} a ramen\u00e9 le g\u00e2teau {1} \u00e0 sa base. L''\u00e9quipe {2} gagne un point et r\u00e9cup\u00e8re toutes ses vies.
|
||||||
|
zone.capturepoint.addpoint=L''\u00e9quipe {0} gagne 1 point pour prot\u00e9ger du cap {1}.
|
||||||
|
zone.capturepoint.lose=L''\u00e9quipe {0} a perdu le contr\u00f4le du cap {1}.
|
||||||
|
zone.capturepoint.contest=L''\u00e9quipe {1} conteste le cap {0} !
|
||||||
|
zone.capturepoint.capture=L''\u00e9quipe {0} s''est empar\u00e9e du cap {1}, gagnant 1 point.
|
||||||
zone.flagcapture.broadcast = {0} a ramen\u00e9 le drapeau de l''\u00e9quipe {1} \u00e0 sa base ! L''\u00e9quipe {2} gagne 1 point.
|
zone.flagcapture.broadcast = {0} a ramen\u00e9 le drapeau de l''\u00e9quipe {1} \u00e0 sa base ! L''\u00e9quipe {2} gagne 1 point.
|
||||||
zone.flagreturn.deadlock = Vous ne pouvez pas rapporter un drapeau ennemi alors que votre propre drapeau a \u00e9t\u00e9 vol\u00e9 !
|
zone.flagreturn.deadlock = Vous ne pouvez pas rapporter un drapeau ennemi alors que votre propre drapeau a \u00e9t\u00e9 vol\u00e9 !
|
||||||
zone.flagreturn.flag = Vous devez captuer le drapeau enemie \u00e0 votre drapeau d'\u00e9quipe.
|
zone.flagreturn.flag = Vous devez captuer le drapeau enemie \u00e0 votre drapeau d'\u00e9quipe.
|
||||||
@ -108,6 +112,7 @@ zone.score.board404 = Le tableau des scores n'est pas activ\u00e9 dans cette zon
|
|||||||
zone.score.empty = Vous ne pourrez pas marquer de point tant qu'aucun joueur n'aura rejoint une autre \u00e9quipe.
|
zone.score.empty = Vous ne pourrez pas marquer de point tant qu'aucun joueur n'aura rejoint une autre \u00e9quipe.
|
||||||
zone.spawn.minplayers = Vous ne pouvez pas quitter votre base s''il n''y a pas au moins {0} joueurs dans au moins {1} \u00e9quipes.
|
zone.spawn.minplayers = Vous ne pouvez pas quitter votre base s''il n''y a pas au moins {0} joueurs dans au moins {1} \u00e9quipes.
|
||||||
zone.spawn.timer = Vous devez attendre {0} secondes pour quitter votre base !
|
zone.spawn.timer = Vous devez attendre {0} secondes pour quitter votre base !
|
||||||
|
zone.spawn.timer.title=Attendez {0} secondes...
|
||||||
zone.steal.bomb.broadcast = {0} s''est empar\u00e9 de la bombe {1} !
|
zone.steal.bomb.broadcast = {0} s''est empar\u00e9 de la bombe {1} !
|
||||||
zone.steal.bomb.notice = Vous avez la bombe {0}. Atteignez la base d''une \u00e9quipe ennemie pour gagner des points. Si vous vous faites toucher, vous exploserez !
|
zone.steal.bomb.notice = Vous avez la bombe {0}. Atteignez la base d''une \u00e9quipe ennemie pour gagner des points. Si vous vous faites toucher, vous exploserez !
|
||||||
zone.steal.bomb.prevent = Emp\u00eachez {0} d''atteindre votre base avec la bombe !
|
zone.steal.bomb.prevent = Emp\u00eachez {0} d''atteindre votre base avec la bombe !
|
||||||
|
Loading…
Reference in New Issue
Block a user