123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- package com.gmail.nossr50.commands;
- import com.gmail.nossr50.config.AdvancedConfig;
- 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.ChatColor;
- import org.bukkit.command.Command;
- import org.bukkit.command.CommandSender;
- import org.bukkit.command.TabExecutor;
- import org.bukkit.util.StringUtil;
- import java.util.ArrayList;
- import java.util.List;
- public class XprateCommand implements TabExecutor {
- private final double ORIGINAL_XP_RATE = mcMMO.getDynamicSettingsManager().getExperienceManager().getGlobalXpMult();
- @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);
- }
- mcMMO.p.getServer().broadcastMessage(LocaleLoader.getString("Commands.Event.Stop"));
- mcMMO.p.getServer().broadcastMessage(LocaleLoader.getString("Commands.Event.Stop.Subtitle"));
- mcMMO.p.toggleXpEventEnabled();
- }
- mcMMO.getDynamicSettingsManager().getExperienceManager().resetGlobalXpMult();
- 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;
- }
- mcMMO.getDynamicSettingsManager().getExperienceManager().setGlobalXpMult(newXpRate);
- if (mcMMO.p.isXPEventEnabled()) {
- if (AdvancedConfig.getInstance().useTitlesForXPEvent()) {
- NotificationManager.broadcastTitle(mcMMO.p.getServer(),
- LocaleLoader.getString("Commands.Event.Start"),
- LocaleLoader.getString("Commands.Event.XP", newXpRate),
- 10, 10 * 20, 20);
- }
- mcMMO.p.getServer().broadcastMessage(LocaleLoader.getString("Commands.Event.Start"));
- mcMMO.p.getServer().broadcastMessage(LocaleLoader.getString("Commands.Event.XP", newXpRate));
- } else {
- sender.sendMessage(LocaleLoader.getString("Commands.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<>(CommandUtils.RESET_OPTIONS.size()));
- case 2:
- return StringUtil.copyPartialMatches(args[1], CommandUtils.TRUE_FALSE_OPTIONS, new ArrayList<>(CommandUtils.TRUE_FALSE_OPTIONS.size()));
- default:
- return ImmutableList.of();
- }
- }
- }
|