123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- package com.gmail.nossr50.commands;
- import com.gmail.nossr50.config.AdvancedConfig;
- import com.gmail.nossr50.config.Config;
- import com.gmail.nossr50.config.experience.ExperienceConfig;
- import com.gmail.nossr50.locale.LocaleLoader;
- import com.gmail.nossr50.mcMMO;
- import com.gmail.nossr50.util.Permissions;
- import com.gmail.nossr50.util.StringUtils;
- import com.gmail.nossr50.util.commands.CommandUtils;
- import com.gmail.nossr50.util.player.NotificationManager;
- import com.google.common.collect.ImmutableList;
- import org.bukkit.Bukkit;
- import org.bukkit.ChatColor;
- import org.bukkit.command.Command;
- import org.bukkit.command.CommandSender;
- import org.bukkit.command.TabExecutor;
- import org.bukkit.entity.Player;
- import org.bukkit.util.StringUtil;
- import java.security.Permission;
- import java.util.ArrayList;
- import java.util.List;
- public class XprateCommand implements TabExecutor {
- private final double ORIGINAL_XP_RATE = ExperienceConfig.getInstance().getExperienceGainsGlobalMultiplier();
- @Override
- public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
- switch (args.length) {
- case 1:
- if (!args[0].equalsIgnoreCase("reset") && !args[0].equalsIgnoreCase("clear")) {
- return false;
- }
- if (!Permissions.xprateReset(sender)) {
- sender.sendMessage(command.getPermissionMessage());
- return true;
- }
- if (mcMMO.p.isXPEventEnabled()) {
- if(AdvancedConfig.getInstance().useTitlesForXPEvent())
- {
- NotificationManager.broadcastTitle(mcMMO.p.getServer(),
- LocaleLoader.getString("Commands.Event.Stop"),
- LocaleLoader.getString("Commands.Event.Stop.Subtitle"),
- 10, 10*20, 20);
- }
- if(Config.getInstance().broadcastEventMessages())
- {
- mcMMO.p.getServer().broadcastMessage(LocaleLoader.getString("Commands.Event.Stop"));
- mcMMO.p.getServer().broadcastMessage(LocaleLoader.getString("Commands.Event.Stop.Subtitle"));
- }
- for(Player player : Bukkit.getServer().getOnlinePlayers())
- {
- if(player.isOp() || Permissions.adminChat(player))
- {
- String senderName = LocaleLoader.getString("Server.ConsoleName");
- if(sender instanceof Player)
- {
- senderName = ((Player) sender).getDisplayName();
- }
- sender.sendMessage(LocaleLoader.getString("XPRate.AdminDetails.End", senderName));
- }
- }
- sender.sendMessage(LocaleLoader.getString("XPRate.End"));
- mcMMO.p.toggleXpEventEnabled();
- }
- ExperienceConfig.getInstance().setExperienceGainsGlobalMultiplier(ORIGINAL_XP_RATE);
- return true;
- case 2:
- if (CommandUtils.isInvalidInteger(sender, args[0])) {
- return true;
- }
- if (!Permissions.xprateSet(sender)) {
- sender.sendMessage(command.getPermissionMessage());
- return true;
- }
- if (CommandUtils.shouldDisableToggle(args[1])) {
- mcMMO.p.setXPEventEnabled(false);
- }
- else if (CommandUtils.shouldEnableToggle(args[1])) {
- mcMMO.p.setXPEventEnabled(true);
- }
- else {
- return false;
- }
- int newXpRate = Integer.parseInt(args[0]);
- if(newXpRate < 0)
- {
- sender.sendMessage(ChatColor.RED+LocaleLoader.getString("Commands.NegativeNumberWarn"));
- return true;
- }
- ExperienceConfig.getInstance().setExperienceGainsGlobalMultiplier(newXpRate);
- if(AdvancedConfig.getInstance().useTitlesForXPEvent())
- {
- NotificationManager.broadcastTitle(mcMMO.p.getServer(),
- LocaleLoader.getString("Commands.Event.Start"),
- LocaleLoader.getString("Commands.Event.XP", newXpRate),
- 10, 10*20, 20);
- }
- if(Config.getInstance().broadcastEventMessages())
- {
- mcMMO.p.getServer().broadcastMessage(LocaleLoader.getString("Commands.Event.Start"));
- mcMMO.p.getServer().broadcastMessage(LocaleLoader.getString("Commands.Event.XP", newXpRate));
- }
- for(Player player : Bukkit.getServer().getOnlinePlayers())
- {
- if(player.isOp() || Permissions.adminChat(player))
- {
- String senderName = LocaleLoader.getString("Server.ConsoleName");
- if(sender instanceof Player)
- {
- senderName = ((Player) sender).getDisplayName();
- }
- sender.sendMessage(LocaleLoader.getString("XPRate.AdminDetails.Start", senderName, newXpRate));
- }
- }
- sender.sendMessage(LocaleLoader.getString("XPRate.Modified", newXpRate));
- return true;
- default:
- return false;
- }
- }
- @Override
- public List<String> onTabComplete(CommandSender sender, Command command, String alias, String[] args) {
- switch (args.length) {
- case 1:
- if (StringUtils.isInt(args[0])) {
- return ImmutableList.of();
- }
- return StringUtil.copyPartialMatches(args[0], CommandUtils.RESET_OPTIONS, new ArrayList<String>(CommandUtils.RESET_OPTIONS.size()));
- case 2:
- return StringUtil.copyPartialMatches(args[1], CommandUtils.TRUE_FALSE_OPTIONS, new ArrayList<String>(CommandUtils.TRUE_FALSE_OPTIONS.size()));
- default:
- return ImmutableList.of();
- }
- }
- }
|