2013-01-24 17:45:40 +01:00
|
|
|
package com.gmail.nossr50.util;
|
|
|
|
|
2013-02-18 17:41:44 +01:00
|
|
|
import java.text.DecimalFormat;
|
|
|
|
|
2013-01-24 17:45:40 +01:00
|
|
|
import org.bukkit.entity.Player;
|
2013-01-26 23:01:55 +01:00
|
|
|
import org.bukkit.plugin.PluginDescriptionFile;
|
2013-01-24 17:45:40 +01:00
|
|
|
|
2013-01-26 23:01:55 +01:00
|
|
|
import com.gmail.nossr50.mcMMO;
|
2013-02-13 14:15:38 +01:00
|
|
|
import com.gmail.nossr50.config.Config;
|
2013-01-24 17:45:40 +01:00
|
|
|
import com.gmail.nossr50.locale.LocaleLoader;
|
2013-02-18 17:41:44 +01:00
|
|
|
import com.gmail.nossr50.skills.utilities.PerksUtils;
|
2013-01-30 17:53:51 +01:00
|
|
|
import com.gmail.nossr50.skills.utilities.SkillType;
|
2013-01-24 17:45:40 +01:00
|
|
|
|
2013-01-26 23:01:55 +01:00
|
|
|
public final class Motd {
|
|
|
|
private static final String perkPrefix = LocaleLoader.getString("MOTD.PerksPrefix");
|
|
|
|
private static final PluginDescriptionFile pluginDescription = mcMMO.p.getDescription();
|
2013-01-24 17:45:40 +01:00
|
|
|
|
2013-01-26 23:01:55 +01:00
|
|
|
private Motd() {}
|
|
|
|
|
|
|
|
public static void displayAll(Player player) {
|
|
|
|
displayVersion(player, pluginDescription.getVersion());
|
|
|
|
displayHardcoreSettings(player);
|
|
|
|
displayXpPerks(player);
|
|
|
|
displayCooldownPerks(player);
|
|
|
|
displayActivationPerks(player);
|
|
|
|
displayLuckyPerks(player);
|
|
|
|
displayWebsite(player, pluginDescription.getWebsite());
|
2013-01-24 17:45:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display version info.
|
2013-01-26 23:01:55 +01:00
|
|
|
* @param player Target player
|
|
|
|
* @param version Plugin version
|
2013-01-24 17:45:40 +01:00
|
|
|
*/
|
2013-01-26 23:01:55 +01:00
|
|
|
public static void displayVersion(Player player, String version) {
|
2013-02-06 18:50:11 +01:00
|
|
|
player.sendMessage(LocaleLoader.getString("MOTD.Version", version));
|
2013-01-24 17:45:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display Hardcore Mode settings.
|
2013-01-26 23:01:55 +01:00
|
|
|
* @param player Target player
|
2013-01-24 17:45:40 +01:00
|
|
|
*/
|
2013-01-26 23:01:55 +01:00
|
|
|
public static void displayHardcoreSettings(Player player) {
|
2013-02-13 14:15:38 +01:00
|
|
|
if (Config.getInstance().getHardcoreEnabled()) {
|
|
|
|
if (Config.getInstance().getHardcoreVampirismEnabled()) {
|
2013-01-24 17:45:40 +01:00
|
|
|
player.sendMessage(LocaleLoader.getString("MOTD.Hardcore.VampireOn"));
|
2013-02-13 14:15:38 +01:00
|
|
|
player.sendMessage(LocaleLoader.getString("MOTD.Hardcore.Stats", Config.getInstance().getHardcoreDeathStatPenaltyPercentage()));
|
|
|
|
player.sendMessage(LocaleLoader.getString("MOTD.Vampire.Stats", Config.getInstance().getHardcoreVampirismStatLeechPercentage()));
|
2013-01-24 17:45:40 +01:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
player.sendMessage(LocaleLoader.getString("MOTD.Hardcore.VampireOff"));
|
2013-02-13 14:15:38 +01:00
|
|
|
player.sendMessage(LocaleLoader.getString("MOTD.Hardcore.Stats", Config.getInstance().getHardcoreDeathStatPenaltyPercentage()));
|
2013-01-24 17:45:40 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display XP perks.
|
2013-01-26 23:01:55 +01:00
|
|
|
* @param player Target player
|
2013-01-24 17:45:40 +01:00
|
|
|
*/
|
2013-01-26 23:01:55 +01:00
|
|
|
public static void displayXpPerks(Player player) {
|
2013-02-18 17:41:44 +01:00
|
|
|
player.sendMessage(perkPrefix + LocaleLoader.getString("Effects.Template", LocaleLoader.getString("Perks.xp.name"), LocaleLoader.getString("Perks.xp.desc", PerksUtils.handleXpPerks(player, 1))));
|
2013-01-24 17:45:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display cooldown perks.
|
2013-01-26 23:01:55 +01:00
|
|
|
* @param player Target player
|
2013-01-24 17:45:40 +01:00
|
|
|
*/
|
2013-01-26 23:01:55 +01:00
|
|
|
public static void displayCooldownPerks(Player player) {
|
2013-02-18 17:41:44 +01:00
|
|
|
double cooldownReduction = 1 - (PerksUtils.handleCooldownPerks(player, 12) / 12.0);
|
|
|
|
DecimalFormat percent = new DecimalFormat("##0.00%");
|
|
|
|
|
|
|
|
player.sendMessage(perkPrefix + LocaleLoader.getString("Effects.Template", LocaleLoader.getString("Perks.cooldowns.name"), LocaleLoader.getString("Perks.cooldowns.desc", percent.format(cooldownReduction))));
|
2013-01-24 17:45:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display activiation perks.
|
2013-01-26 23:01:55 +01:00
|
|
|
* @param player Target player
|
2013-01-24 17:45:40 +01:00
|
|
|
*/
|
2013-01-26 23:01:55 +01:00
|
|
|
public static void displayActivationPerks(Player player) {
|
2013-02-18 17:41:44 +01:00
|
|
|
player.sendMessage(perkPrefix + LocaleLoader.getString("Effects.Template", LocaleLoader.getString("Perks.activationtime.name"), LocaleLoader.getString("Perks.activationtime.desc", PerksUtils.handleActivationPerks(player, 0, 0))));
|
2013-01-24 17:45:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display "lucky" perks.
|
2013-01-26 23:01:55 +01:00
|
|
|
* @param player Target player
|
2013-01-24 17:45:40 +01:00
|
|
|
*/
|
2013-01-26 23:01:55 +01:00
|
|
|
public static void displayLuckyPerks(Player player) {
|
2013-01-24 17:45:40 +01:00
|
|
|
for (SkillType skill : SkillType.values()) {
|
|
|
|
if (Permissions.lucky(player, skill)) {
|
2013-02-02 08:55:49 +01:00
|
|
|
player.sendMessage(perkPrefix + LocaleLoader.getString("Effects.Template", LocaleLoader.getString("Perks.lucky.name"), LocaleLoader.getString("Perks.lucky.desc.login")));
|
2013-01-24 17:45:40 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display website info.
|
2013-01-26 23:01:55 +01:00
|
|
|
* @param player Target player
|
|
|
|
* @param website Plugin website
|
2013-01-24 17:45:40 +01:00
|
|
|
*/
|
2013-01-26 23:01:55 +01:00
|
|
|
public static void displayWebsite(Player player, String website) {
|
2013-02-02 08:55:49 +01:00
|
|
|
player.sendMessage(LocaleLoader.getString("MOTD.Website", website));
|
2013-01-24 17:45:40 +01:00
|
|
|
}
|
|
|
|
}
|