2016-04-14 16:24:03 +00:00
|
|
|
package me.mrCookieSlime.Slimefun.Objects;
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Iterator;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.UUID;
|
|
|
|
|
|
|
|
import me.mrCookieSlime.CSCoreLibPlugin.Configuration.Config;
|
|
|
|
import me.mrCookieSlime.CSCoreLibPlugin.Configuration.Variable;
|
|
|
|
import me.mrCookieSlime.CSCoreLibPlugin.general.Particles.FireworkShow;
|
|
|
|
import me.mrCookieSlime.Slimefun.SlimefunStartup;
|
|
|
|
import me.mrCookieSlime.Slimefun.Events.ResearchUnlockEvent;
|
|
|
|
import me.mrCookieSlime.Slimefun.Objects.SlimefunItem.SlimefunItem;
|
|
|
|
import me.mrCookieSlime.Slimefun.Setup.Messages;
|
2017-06-23 11:06:08 +00:00
|
|
|
import me.mrCookieSlime.Slimefun.api.Slimefun;
|
2016-04-14 16:24:03 +00:00
|
|
|
|
|
|
|
import org.bukkit.Bukkit;
|
|
|
|
import org.bukkit.ChatColor;
|
2017-06-23 11:06:08 +00:00
|
|
|
import org.bukkit.GameMode;
|
2016-04-14 16:24:03 +00:00
|
|
|
import org.bukkit.Sound;
|
|
|
|
import org.bukkit.command.CommandSender;
|
|
|
|
import org.bukkit.entity.Player;
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Statically handles researches. Represents a research, which is linked to one
|
|
|
|
* {@link SlimefunItem} or more and ask for XP levels to unlock this/these item(s).
|
|
|
|
* <p>
|
|
|
|
* See {@link #Research(int, String, int)} to create a research.
|
|
|
|
*
|
|
|
|
* @author TheBusyBiscuit
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public class Research {
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Whether researching is enabled or not
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
|
|
|
public static boolean enabled;
|
|
|
|
/**
|
|
|
|
* Contains all the registered researches
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static List<Research> list = new ArrayList<Research>();
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Contains all the players (UUIDs) that are currently unlocking a research
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static List<UUID> researching = new ArrayList<UUID>();
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Whether researching in creative is free
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
|
|
|
public static boolean creative_research = true;
|
2016-04-14 16:24:03 +00:00
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
private int id;
|
|
|
|
private String name;
|
|
|
|
private List<SlimefunItem> items;
|
|
|
|
private int cost;
|
2016-04-14 16:24:03 +00:00
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* The constructor for a Research.
|
|
|
|
* <p>
|
|
|
|
* Create a new research by calling {@link #Research(int, String, int)}, then
|
|
|
|
* bind this research to the Slimefun items you want by calling
|
|
|
|
* {@link #addItems(SlimefunItem...)}. Once you're finished, call {@link #register()}
|
|
|
|
* to register it.
|
|
|
|
* <p>
|
|
|
|
* To speed up, directly setup the research by calling
|
|
|
|
* {@link Slimefun#registerResearch(Research, org.bukkit.inventory.ItemStack...)}.
|
|
|
|
*
|
|
|
|
* @param id Unique integer ID for this research, used for {@link #getByID(int)} and to
|
|
|
|
* register it in Researches.yml
|
|
|
|
* @param name Display name of the research
|
|
|
|
* @param cost Cost in XP levels to unlock the research
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
|
|
|
public Research(int id, String name, int cost) {
|
2016-04-14 16:24:03 +00:00
|
|
|
this.id = id;
|
|
|
|
this.name = name;
|
2017-06-23 11:06:08 +00:00
|
|
|
this.cost = cost;
|
2016-04-14 16:24:03 +00:00
|
|
|
this.items = new ArrayList<SlimefunItem>();
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Gets the ID of the research
|
|
|
|
*
|
|
|
|
* @return ID of the research
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public int getID() {
|
2017-06-23 11:06:08 +00:00
|
|
|
return id;
|
2016-04-14 16:24:03 +00:00
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Gets the display name of the research
|
|
|
|
*
|
|
|
|
* @return The display name of the research
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public String getName() {
|
2017-06-23 11:06:08 +00:00
|
|
|
return name;
|
2016-04-14 16:24:03 +00:00
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Gets the cost in XP levels to unlock the research
|
|
|
|
*
|
|
|
|
* @return The cost in XP levels of the research
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
* @deprecated Moved to {@link #getCost()}
|
|
|
|
*/
|
|
|
|
@Deprecated
|
2016-04-14 16:24:03 +00:00
|
|
|
public int getLevel() {
|
2017-06-23 11:06:08 +00:00
|
|
|
return cost;
|
2016-04-14 16:24:03 +00:00
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Sets the cost in XP levels to unlock the research
|
|
|
|
*
|
|
|
|
* @param level Cost in XP levels
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
* @deprecated Moved to {@link #setCost(int)}
|
|
|
|
*/
|
|
|
|
@Deprecated
|
2016-04-14 16:24:03 +00:00
|
|
|
public void setLevel(int level) {
|
2017-06-23 11:06:08 +00:00
|
|
|
this.cost = level;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the cost in XP levels to unlock the research
|
|
|
|
*
|
|
|
|
* @return The cost in XP levels of the research
|
|
|
|
* @since 4.1.10
|
|
|
|
*/
|
|
|
|
public int getCost() {
|
|
|
|
return cost;
|
2016-04-14 16:24:03 +00:00
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Sets the cost in XP levels to unlock the research
|
|
|
|
*
|
|
|
|
* @param cost Cost in XP levels
|
|
|
|
*
|
|
|
|
* @since 4.1.10
|
|
|
|
*/
|
|
|
|
public void setCost(int cost) {
|
|
|
|
this.cost = cost;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Bind the specified Slimefun items to the research
|
|
|
|
*
|
|
|
|
* @param items {@link SlimefunItem} to bind to the research
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public void addItems(SlimefunItem... items) {
|
|
|
|
for (SlimefunItem item: items) {
|
|
|
|
if (item != null) item.bindToResearch(this);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Gets the list of the Slimefun items bound to the research
|
|
|
|
*
|
|
|
|
* @return the Slimefun items bound to the research
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public List<SlimefunItem> getEffectedItems() {
|
2017-06-23 11:06:08 +00:00
|
|
|
return items;
|
2016-04-14 16:24:03 +00:00
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Convenience method to check if the player unlocked this research
|
|
|
|
*
|
|
|
|
* @param p Player to check
|
|
|
|
* @return true if he unlocked the research, otherwise false
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
* @see #hasUnlocked(UUID)
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public boolean hasUnlocked(Player p) {
|
|
|
|
return hasUnlocked(p.getUniqueId());
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Checks if the player unlocked this research
|
|
|
|
*
|
|
|
|
* @param uuid UUID of the player to check
|
|
|
|
* @return true if he unlocked the research, otherwise false
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
* @see #hasUnlocked(Player)
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public boolean hasUnlocked(UUID uuid) {
|
|
|
|
if (!enabled) return true;
|
|
|
|
if (!SlimefunStartup.getResearchCfg().getBoolean(this.id + ".enabled")) return true;
|
|
|
|
return new Config(new File("data-storage/Slimefun/Players/" + uuid.toString() + ".yml")).contains("researches." + this.id);
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Checks if the player can unlock this research
|
|
|
|
*
|
|
|
|
* @param p Player to check
|
|
|
|
* @return true if he can unlock the research, otherwise false
|
|
|
|
*
|
|
|
|
* @since 4.1.10
|
|
|
|
*/
|
|
|
|
public boolean canUnlock(Player p) {
|
|
|
|
if (!enabled) return true;
|
|
|
|
if (!SlimefunStartup.getResearchCfg().getBoolean(this.id + ".enabled")) return true;
|
|
|
|
return (p.getGameMode() == GameMode.CREATIVE && Research.creative_research) || p.getLevel() >= this.cost;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Locks the research for the specified player
|
|
|
|
*
|
|
|
|
* @param p Player to lock the research
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public void lock(Player p) {
|
|
|
|
Config cfg = new Config(new File("data-storage/Slimefun/Players/" + p.getUniqueId() + ".yml"));
|
|
|
|
cfg.setValue("researches." + id, null);
|
|
|
|
cfg.save();
|
|
|
|
Messages.local.sendTranslation(p, "commands.research.reset-target", true);
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Unlocks the research for the specified player
|
|
|
|
*
|
|
|
|
* @param p Player to unlock the research
|
|
|
|
* @param instant Whether to unlock the research instantly
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public void unlock(final Player p, boolean instant) {
|
|
|
|
if (!hasUnlocked(p)) {
|
|
|
|
ResearchUnlockEvent event = new ResearchUnlockEvent(p, this);
|
|
|
|
Bukkit.getPluginManager().callEvent(event);
|
|
|
|
if (!event.isCancelled()) {
|
|
|
|
final int research = this.id;
|
|
|
|
if (instant) {
|
|
|
|
Config cfg = new Config(new File("data-storage/Slimefun/Players/" + p.getUniqueId() + ".yml"));
|
|
|
|
cfg.setValue("researches." + research, true);
|
|
|
|
cfg.save();
|
|
|
|
Messages.local.sendTranslation(p, "messages.unlocked", true, new Variable("%research%", getName()));
|
2017-06-19 12:14:26 +00:00
|
|
|
if(SlimefunStartup.getCfg().getBoolean("options.research-give-fireworks")) FireworkShow.launchRandom(p, 1);
|
2016-04-14 16:24:03 +00:00
|
|
|
}
|
|
|
|
else if (!researching.contains(p.getUniqueId())){
|
|
|
|
researching.add(p.getUniqueId());
|
|
|
|
Messages.local.sendTranslation(p, "messages.research.start", true, new Variable("%research%", getName()));
|
|
|
|
Bukkit.getScheduler().scheduleSyncDelayedTask(SlimefunStartup.instance, new Runnable() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
p.playSound(p.getLocation(), Sound.ENTITY_BAT_TAKEOFF, 0.7F, 1F);
|
2016-04-15 13:58:29 +00:00
|
|
|
Messages.local.sendTranslation(p, "messages.research.progress", true, new Variable("%research%", getName()), new Variable("%progress%", "23%"));
|
2016-04-14 16:24:03 +00:00
|
|
|
Bukkit.getScheduler().scheduleSyncDelayedTask(SlimefunStartup.instance, new Runnable() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
p.playSound(p.getLocation(), Sound.ENTITY_BAT_TAKEOFF, 0.7F, 1F);
|
2016-04-15 13:58:29 +00:00
|
|
|
Messages.local.sendTranslation(p, "messages.research.progress", true, new Variable("%research%", getName()), new Variable("%progress%", "44%"));
|
2016-04-14 16:24:03 +00:00
|
|
|
Bukkit.getScheduler().scheduleSyncDelayedTask(SlimefunStartup.instance, new Runnable() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
p.playSound(p.getLocation(), Sound.ENTITY_BAT_TAKEOFF, 0.7F, 1F);
|
2016-04-15 13:58:29 +00:00
|
|
|
Messages.local.sendTranslation(p, "messages.research.progress", true, new Variable("%research%", getName()), new Variable("%progress%", "57%"));
|
2016-04-14 16:24:03 +00:00
|
|
|
Bukkit.getScheduler().scheduleSyncDelayedTask(SlimefunStartup.instance, new Runnable() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
p.playSound(p.getLocation(), Sound.ENTITY_BAT_TAKEOFF, 0.7F, 1F);
|
2016-04-15 13:58:29 +00:00
|
|
|
Messages.local.sendTranslation(p, "messages.research.progress", true, new Variable("%research%", getName()), new Variable("%progress%", "92%"));
|
2016-04-14 16:24:03 +00:00
|
|
|
Bukkit.getScheduler().scheduleSyncDelayedTask(SlimefunStartup.instance, new Runnable() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
Config cfg = new Config(new File("data-storage/Slimefun/Players/" + p.getUniqueId() + ".yml"));
|
|
|
|
cfg.setValue("researches." + research, true);
|
|
|
|
cfg.save();
|
|
|
|
Messages.local.sendTranslation(p, "messages.unlocked", true, new Variable("%research%", getName()));
|
2017-06-19 12:14:26 +00:00
|
|
|
if(SlimefunStartup.getCfg().getBoolean("options.research-unlock-fireworks")) FireworkShow.launchRandom(p, 1);
|
2016-04-14 16:24:03 +00:00
|
|
|
researching.remove(p.getUniqueId());
|
|
|
|
}
|
|
|
|
}, 20L);
|
|
|
|
}
|
|
|
|
}, 20L);
|
|
|
|
}
|
|
|
|
}, 20L);
|
|
|
|
}
|
|
|
|
}, 20L);
|
|
|
|
}
|
|
|
|
}, 20L);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Registers the research
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public void register() {
|
|
|
|
SlimefunStartup.getResearchCfg().setDefaultValue("enable-researching", true);
|
|
|
|
|
|
|
|
if (SlimefunStartup.getResearchCfg().contains(this.getID() + ".enabled") && !SlimefunStartup.getResearchCfg().getBoolean(this.getID() + ".enabled")) {
|
|
|
|
Iterator<SlimefunItem> iterator = items.iterator();
|
|
|
|
while (iterator.hasNext()) {
|
|
|
|
SlimefunItem item = iterator.next();
|
|
|
|
if (item != null) item.bindToResearch(null);
|
|
|
|
iterator.remove();
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
SlimefunStartup.getResearchCfg().setDefaultValue(this.getID() + ".name", this.getName());
|
2017-06-23 11:06:08 +00:00
|
|
|
SlimefunStartup.getResearchCfg().setDefaultValue(this.getID() + ".cost", this.getCost());
|
2016-04-14 16:24:03 +00:00
|
|
|
SlimefunStartup.getResearchCfg().setDefaultValue(this.getID() + ".enabled", true);
|
|
|
|
|
|
|
|
this.name = SlimefunStartup.getResearchCfg().getString(this.getID() + ".name");
|
2017-06-23 11:06:08 +00:00
|
|
|
this.cost = SlimefunStartup.getResearchCfg().getInt(this.getID() + ".cost");
|
2016-04-14 16:24:03 +00:00
|
|
|
|
|
|
|
list.add(this);
|
|
|
|
if (SlimefunStartup.getCfg().getBoolean("options.print-out-loading")) System.out.println("[Slimefun] Loaded Research \"" + this.getName() + "\"");
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Gets the list of all registered researches
|
|
|
|
*
|
|
|
|
* @return The list of registered researches
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static List<Research> list() {
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Gets if the specified player is currently unlocking a research
|
|
|
|
*
|
|
|
|
* @param p Player to check
|
|
|
|
* @return true if the player is unlocking a research, otherwise false
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static boolean isResearching(Player p) {
|
|
|
|
return researching.contains(p.getUniqueId());
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Sends the research statistics and title of the specified player to the command sender
|
|
|
|
*
|
|
|
|
* @param sender CommandSender to send the statistics
|
|
|
|
* @param p Player to get the statistics
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
* @see #getTitle(Player, List)
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static void sendStats(CommandSender sender, Player p) {
|
|
|
|
List<Research> researched = new ArrayList<Research>();
|
|
|
|
int levels = 0;
|
|
|
|
for (Research r: list()) {
|
|
|
|
if (r.hasUnlocked(p)) {
|
|
|
|
researched.add(r);
|
|
|
|
levels = levels + r.getLevel();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
String progress = String.valueOf(Math.round(((researched.size() * 100.0f) / list().size()) * 100.0f) / 100.0f);
|
|
|
|
if (Float.parseFloat(progress) < 16.0F) progress = "&4" + progress + " &r% ";
|
|
|
|
else if (Float.parseFloat(progress) < 32.0F) progress = "&c" + progress + " &r% ";
|
|
|
|
else if (Float.parseFloat(progress) < 48.0F) progress = "&6" + progress + " &r% ";
|
|
|
|
else if (Float.parseFloat(progress) < 64.0F) progress = "&e" + progress + " &r% ";
|
|
|
|
else if (Float.parseFloat(progress) < 80.0F) progress = "&2" + progress + " &r% ";
|
|
|
|
else progress = "&a" + progress + " &r% ";
|
|
|
|
|
|
|
|
sender.sendMessage("");
|
|
|
|
sender.sendMessage(ChatColor.translateAlternateColorCodes('&', "&7Statistics for Player: &b" + p.getName()));
|
|
|
|
sender.sendMessage("");
|
|
|
|
sender.sendMessage(ChatColor.translateAlternateColorCodes('&', "&7Title: &b" + getTitle(p, researched)));
|
|
|
|
sender.sendMessage(ChatColor.translateAlternateColorCodes('&', "&7Research Progress: " + progress + "&e(" + researched.size() + " / " + list().size() + ")"));
|
|
|
|
sender.sendMessage(ChatColor.translateAlternateColorCodes('&', "&7Total XP Levels spent: &b" + levels));
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Gets the title of the specified player
|
|
|
|
*
|
|
|
|
* @param p Player to get the rank
|
|
|
|
* @param researched List of the player's unlocked researches
|
|
|
|
* @return the title of the specified player
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
* @see #sendStats(CommandSender, Player)
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static String getTitle(Player p, List<Research> researched) {
|
|
|
|
int index = Math.round(Float.valueOf(String.valueOf(Math.round(((researched.size() * 100.0f) / list().size()) * 100.0f) / 100.0f)) / 100.0F) * SlimefunStartup.getCfg().getStringList("research-ranks").size();
|
|
|
|
if (index > 0) index--;
|
|
|
|
return SlimefunStartup.getCfg().getStringList("research-ranks").get(index);
|
|
|
|
}
|
2017-06-23 11:06:08 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Attempts to get the research with the given ID
|
|
|
|
*
|
|
|
|
* @param id ID of the research to get
|
|
|
|
* @return Research if found, or null
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static Research getByID(int id) {
|
|
|
|
for (Research research: list) {
|
|
|
|
if (research.getID() == id) return research;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-06-23 11:06:08 +00:00
|
|
|
/**
|
|
|
|
* Gets the list of unlocked researches for a player using his UUID
|
|
|
|
*
|
|
|
|
* @param uuid UUID of the player
|
|
|
|
* @return the list of unlocked researches for the player
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
* @see #getResearches(String)
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static List<Research> getResearches(UUID uuid) {
|
|
|
|
List<Research> researched = new ArrayList<Research>();
|
|
|
|
for (Research r: list()) {
|
|
|
|
if (r.hasUnlocked(uuid)) researched.add(r);
|
|
|
|
}
|
|
|
|
return researched;
|
|
|
|
}
|
2017-06-23 11:06:08 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Convenience method to get the list of unlocked researches
|
|
|
|
* for a player using his UUID (specified as a String)
|
|
|
|
*
|
|
|
|
* @param uuid String representing the UUID of the player
|
|
|
|
* @return the list of unlocked researches for the player
|
|
|
|
*
|
|
|
|
* @since 4.0
|
|
|
|
* @see #getResearches(UUID)
|
|
|
|
*/
|
2016-04-14 16:24:03 +00:00
|
|
|
public static List<Research> getResearches(String uuid) {
|
|
|
|
return getResearches(UUID.fromString(uuid));
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|