Transfer of Unlockable to MythicLib

This commit is contained in:
Ka0rX 2023-03-26 20:53:21 +01:00
parent 77d4f8e4e4
commit fbe4314649
14 changed files with 48 additions and 85 deletions

View File

@ -57,6 +57,7 @@ import java.util.logging.Level;
public class MMOCore extends JavaPlugin { public class MMOCore extends JavaPlugin {
public static MMOCore plugin; public static MMOCore plugin;
public final static String MMOCORE_ITEM_ID = "mmocore:";
public final WaypointManager waypointManager = new WaypointManager(); public final WaypointManager waypointManager = new WaypointManager();
public final SoundManager soundManager = new SoundManager(); public final SoundManager soundManager = new SoundManager();

View File

@ -38,7 +38,6 @@ import net.Indyuce.mmocore.party.provided.MMOCorePartyModule;
import net.Indyuce.mmocore.party.provided.Party; import net.Indyuce.mmocore.party.provided.Party;
import net.Indyuce.mmocore.player.ClassDataContainer; import net.Indyuce.mmocore.player.ClassDataContainer;
import net.Indyuce.mmocore.player.CombatHandler; import net.Indyuce.mmocore.player.CombatHandler;
import net.Indyuce.mmocore.player.Unlockable;
import net.Indyuce.mmocore.skill.ClassSkill; import net.Indyuce.mmocore.skill.ClassSkill;
import net.Indyuce.mmocore.skill.RegisteredSkill; import net.Indyuce.mmocore.skill.RegisteredSkill;
import net.Indyuce.mmocore.skill.cast.SkillCastingHandler; import net.Indyuce.mmocore.skill.cast.SkillCastingHandler;
@ -66,6 +65,8 @@ import java.util.*;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import static net.Indyuce.mmocore.MMOCore.MMOCORE_ITEM_ID;
public class PlayerData extends OfflinePlayerData implements Closable, ExperienceTableClaimer, ClassDataContainer { public class PlayerData extends OfflinePlayerData implements Closable, ExperienceTableClaimer, ClassDataContainer {
@ -112,15 +113,6 @@ public class PlayerData extends OfflinePlayerData implements Closable, Experienc
private final Map<SkillTreeNode, Integer> nodeLevels = new HashMap<>(); private final Map<SkillTreeNode, Integer> nodeLevels = new HashMap<>();
private final Map<String, Integer> skillTreePoints = new HashMap<>(); private final Map<String, Integer> skillTreePoints = new HashMap<>();
/**
* Saves all the items that have been unlocked so far by
* the player. This is used for:
* - waypoints
* - skills
*
* @see {@link Unlockable}
*/
private final Set<String> unlockedItems = new HashSet<>();
/** /**
* Saves the amount of times the player has claimed some * Saves the amount of times the player has claimed some
@ -374,16 +366,29 @@ public class PlayerData extends OfflinePlayerData implements Closable, Experienc
return result; return result;
} }
/**
* @return All the unlocked items that are handled by MMOCore (the ones that MMOCore saves & load by itself.
*/
@Override @Override
public Set<String> getUnlockedItems() { public Set<String> getMMOUnlockedItems() {
return new HashSet<>(unlockedItems); return mmoData.getUnlockedItems().stream().filter(key->key.startsWith(MMOCORE_ITEM_ID)).collect(Collectors.toSet());
} }
/**
* Used to change the value of the unlockedItems handled by mmocore.
* @param unlockedItems
*/
public void setUnlockedItems(Set<String> unlockedItems) { public void setUnlockedItems(Set<String> unlockedItems) {
this.unlockedItems.clear(); Set<String> mythicUnlockedItems=mmoData.getUnlockedItems()
this.unlockedItems.addAll(unlockedItems); .stream()
.filter((key)->!key.startsWith(MMOCORE_ITEM_ID))
.collect(Collectors.toSet());
mythicUnlockedItems.addAll(unlockedItems);
mmoData.setUnlockedItems(mythicUnlockedItems);
} }
public void resetTimesClaimed() { public void resetTimesClaimed() {
tableItemClaims.clear(); tableItemClaims.clear();
} }
@ -542,32 +547,6 @@ public class PlayerData extends OfflinePlayerData implements Closable, Experienc
return guild != null; return guild != null;
} }
/**
* @return If the item is unlocked by the player
* This is used for skills that can be locked & unlocked.
*/
public boolean hasUnlocked(Unlockable unlockable) {
return unlockedItems.contains(unlockable.getUnlockNamespacedKey());
}
/**
* Unlocks an item for the player. This is mainly used to unlock skills.
*
* @return If the item was already unlocked when calling this method
*/
public boolean unlock(Unlockable unlockable) {
return unlockedItems.add(unlockable.getUnlockNamespacedKey());
}
/**
* Locks an item for the player by removing it from the unlocked items map if it is present.
* This is mainly used to remove unlocked items when changing class or reallocating a skill tree.
*/
public void lock(Unlockable unlockable){
unlockedItems.remove(unlockable.getUnlockNamespacedKey());
}
public void setLevel(int level) { public void setLevel(int level) {
this.level = Math.max(1, level); this.level = Math.max(1, level);
@ -1149,6 +1128,13 @@ public class PlayerData extends OfflinePlayerData implements Closable, Experienc
// Update stats // Update stats
if (isOnline()) if (isOnline())
getStats().updateStats(); getStats().updateStats();
Bukkit.broadcastMessage("IN");
//Loads the classUnlockedSkills
profess.getSkills()
.stream()
.filter(ClassSkill::isUnlockedByDefault)
.forEach(skill->mmoData.unlock(skill.getSkill()));
} }
public boolean hasSkillBound(int slot) { public boolean hasSkillBound(int slot) {

View File

@ -124,7 +124,7 @@ public class SavedClassInformation {
data.getNodeLevels().forEach((node, level) -> nodeLevels.put(node.getFullId(), level)); data.getNodeLevels().forEach((node, level) -> nodeLevels.put(node.getFullId(), level));
data.getNodeTimesClaimed().forEach((key, val) -> nodeTimesClaimed.put(key, val)); data.getNodeTimesClaimed().forEach((key, val) -> nodeTimesClaimed.put(key, val));
data.mapBoundSkills().forEach((slot, skill) -> boundSkills.put(slot, skill)); data.mapBoundSkills().forEach((slot, skill) -> boundSkills.put(slot, skill));
data.getUnlockedItems().forEach(item->unlockedItems.add(item)); data.getMMOUnlockedItems().forEach(item->unlockedItems.add(item));
} }
public int getLevel() { public int getLevel() {

View File

@ -19,11 +19,11 @@ public class UnlockSkillTrigger extends Trigger implements Removable {
@Override @Override
public void apply(PlayerData player) { public void apply(PlayerData player) {
player.unlock(skill); player.getMMOPlayerData().unlock(skill);
} }
@Override @Override
public void remove(PlayerData playerData) { public void remove(PlayerData playerData) {
playerData.lock(skill); playerData.getMMOPlayerData().lock(skill);
} }
} }

View File

@ -103,16 +103,16 @@ public class SkillCommandTreeNode extends CommandTreeNode {
} }
PlayerData playerData = PlayerData.get(player); PlayerData playerData = PlayerData.get(player);
RegisteredSkill skill = MMOCore.plugin.skillManager.getSkill(args[4]); ClassSkill skill = playerData.getProfess().getSkill(args[4]);
if (skill == null) { if (skill == null) {
sender.sendMessage(ChatColor.RED + "Could not find the skill called " + args[4] + "."); sender.sendMessage(ChatColor.RED + "The player's class doesn't have a skill called " + args[4] + ".");
return CommandResult.FAILURE; return CommandResult.FAILURE;
} }
if (lock) if (lock)
playerData.lock(skill); playerData.getMMOPlayerData().lock(skill.getSkill());
else else
playerData.unlock(skill); playerData.getMMOPlayerData().unlock(skill.getSkill());
CommandVerbose.verbose(sender, CommandVerbose.CommandType.SKILL, "The skill " + skill.getName() + " is now " + (lock ? "locked" : "unlocked" + " for " + player.getName())); CommandVerbose.verbose(sender, CommandVerbose.CommandType.SKILL, "The skill " + skill.getSkill() + " is now " + (lock ? "locked" : "unlocked" + " for " + player.getName()));
return CommandResult.SUCCESS; return CommandResult.SUCCESS;
} }
} }

View File

@ -322,10 +322,11 @@ public class SkillList extends EditableInventory {
public SkillViewerInventory(PlayerData playerData, EditableInventory editable) { public SkillViewerInventory(PlayerData playerData, EditableInventory editable) {
super(playerData, editable); super(playerData, editable);
Bukkit.broadcastMessage("UNLOCKED");
playerData.getMMOPlayerData().getUnlockedItems().forEach(str->Bukkit.broadcastMessage(str));
skills = playerData.getProfess().getSkills() skills = playerData.getProfess().getSkills()
.stream() .stream()
.filter((classSkill)->playerData.hasUnlocked(classSkill.getSkill())) .filter((classSkill)->playerData.getMMOPlayerData().hasUnlocked(classSkill.getSkill()))
.collect(Collectors.toList()); .collect(Collectors.toList());
skillSlots = getEditable().getByFunction("skill").getSlots(); skillSlots = getEditable().getByFunction("skill").getSlots();
Validate.notNull(getEditable().getByFunction("slot"), "Your skill GUI config file is out-of-date, please regenerate it."); Validate.notNull(getEditable().getByFunction("slot"), "Your skill GUI config file is out-of-date, please regenerate it.");

View File

@ -12,7 +12,6 @@ import net.Indyuce.mmocore.manager.data.PlayerDataManager;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.UUID; import java.util.UUID;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -64,7 +63,7 @@ public class MySQLPlayerDataManager extends PlayerDataManager {
updater.addData("professions", data.getCollectionSkills().toJsonString()); updater.addData("professions", data.getCollectionSkills().toJsonString());
updater.addData("quests", data.getQuestData().toJsonString()); updater.addData("quests", data.getQuestData().toJsonString());
updater.addData("class_info", createClassInfoData(data).toString()); updater.addData("class_info", createClassInfoData(data).toString());
updater.addJSONArray("unlocked_items", data.getUnlockedItems()); updater.addJSONArray("unlocked_items", data.getMMOUnlockedItems());
if (logout) if (logout)
updater.addData("is_saved", 1); updater.addData("is_saved", 1);
@ -91,7 +90,7 @@ public class MySQLPlayerDataManager extends PlayerDataManager {
classinfo.addProperty("stamina", info.getStamina()); classinfo.addProperty("stamina", info.getStamina());
classinfo.addProperty("stellium", info.getStellium()); classinfo.addProperty("stellium", info.getStellium());
JsonArray array = new JsonArray(); JsonArray array = new JsonArray();
for (String unlockedItem : playerData.getUnlockedItems()) { for (String unlockedItem : playerData.getMMOUnlockedItems()) {
array.add(unlockedItem); array.add(unlockedItem);
} }
classinfo.add("unlocked-items", array); classinfo.add("unlocked-items", array);

View File

@ -159,7 +159,7 @@ public class YAMLPlayerDataManager extends PlayerDataManager {
data.getItemClaims().forEach((key, times) -> config.set("times-claimed." + key, times)); data.getItemClaims().forEach((key, times) -> config.set("times-claimed." + key, times));
data.mapBoundSkills().forEach((slot, skill) -> config.set("bound-skills." + slot, skill)); data.mapBoundSkills().forEach((slot, skill) -> config.set("bound-skills." + slot, skill));
config.set("unlocked-items", data.getUnlockedItems().stream().collect(Collectors.toList())); config.set("unlocked-items", data.getMMOUnlockedItems().stream().collect(Collectors.toList()));
config.set("attribute", null); config.set("attribute", null);
config.createSection("attribute"); config.createSection("attribute");
data.getAttributes().save(config.getConfigurationSection("attribute")); data.getAttributes().save(config.getConfigurationSection("attribute"));

View File

@ -1,11 +1,8 @@
package net.Indyuce.mmocore.player; package net.Indyuce.mmocore.player;
import io.lumine.mythic.lib.player.skill.PassiveSkill;
import net.Indyuce.mmocore.api.player.profess.SavedClassInformation; import net.Indyuce.mmocore.api.player.profess.SavedClassInformation;
import net.Indyuce.mmocore.skill.ClassSkill;
import net.Indyuce.mmocore.skilltree.SkillTreeNode; import net.Indyuce.mmocore.skilltree.SkillTreeNode;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -50,5 +47,5 @@ public interface ClassDataContainer {
Map<String, Integer> getNodeTimesClaimed(); Map<String, Integer> getNodeTimesClaimed();
Set<String> getUnlockedItems(); Set<String> getMMOUnlockedItems();
} }

View File

@ -120,7 +120,7 @@ public class DefaultPlayerData implements ClassDataContainer {
} }
@Override @Override
public Set<String> getUnlockedItems() { public Set<String> getMMOUnlockedItems() {
return new HashSet<>(); return new HashSet<>();
} }

View File

@ -1,22 +0,0 @@
package net.Indyuce.mmocore.player;
import net.Indyuce.mmocore.api.player.PlayerData;
/**
* Some item that can be unlocked. All unlockables are saved in the
* same list in the player data. This useful list can be used for:
* - waypoints
* - skill tree nodes
* - skills using skill books? TODO
* - external plugins that implement other unlockable items
*
* @see {@link PlayerData#unlock(Unlockable)} and {@link PlayerData#hasUnlocked(Unlockable)}
*/
public interface Unlockable {
/**
* Format being used is the minecraft's default namespaced
* key format, e.g "skill_tree:strength_1_5" for readability
*/
String getUnlockNamespacedKey();
}

View File

@ -1,12 +1,13 @@
package net.Indyuce.mmocore.skill; package net.Indyuce.mmocore.skill;
import io.lumine.mythic.lib.UtilityMethods; import io.lumine.mythic.lib.UtilityMethods;
import io.lumine.mythic.lib.player.Unlockable;
import io.lumine.mythic.lib.skill.handler.SkillHandler; import io.lumine.mythic.lib.skill.handler.SkillHandler;
import io.lumine.mythic.lib.skill.trigger.TriggerType; import io.lumine.mythic.lib.skill.trigger.TriggerType;
import net.Indyuce.mmocore.MMOCore;
import net.Indyuce.mmocore.api.util.MMOCoreUtils; import net.Indyuce.mmocore.api.util.MMOCoreUtils;
import net.Indyuce.mmocore.api.util.math.formula.IntegerLinearValue; import net.Indyuce.mmocore.api.util.math.formula.IntegerLinearValue;
import net.Indyuce.mmocore.api.util.math.formula.LinearValue; import net.Indyuce.mmocore.api.util.math.formula.LinearValue;
import net.Indyuce.mmocore.player.Unlockable;
import org.bukkit.configuration.ConfigurationSection; import org.bukkit.configuration.ConfigurationSection;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
@ -59,7 +60,7 @@ public class RegisteredSkill implements Unlockable {
@Override @Override
public String getUnlockNamespacedKey() { public String getUnlockNamespacedKey() {
return "registered_skill:" + handler.getId().toLowerCase(); return MMOCore.MMOCORE_ITEM_ID+"skill:" + handler.getId().toLowerCase();
} }
public SkillHandler<?> getHandler() { public SkillHandler<?> getHandler() {

View File

@ -2,10 +2,10 @@ package net.Indyuce.mmocore.waypoint;
import io.lumine.mythic.lib.api.MMOLineConfig; import io.lumine.mythic.lib.api.MMOLineConfig;
import io.lumine.mythic.lib.api.util.PostLoadObject; import io.lumine.mythic.lib.api.util.PostLoadObject;
import io.lumine.mythic.lib.player.Unlockable;
import net.Indyuce.mmocore.MMOCore; import net.Indyuce.mmocore.MMOCore;
import net.Indyuce.mmocore.loot.chest.condition.Condition; import net.Indyuce.mmocore.loot.chest.condition.Condition;
import net.Indyuce.mmocore.loot.chest.condition.ConditionInstance; import net.Indyuce.mmocore.loot.chest.condition.ConditionInstance;
import net.Indyuce.mmocore.player.Unlockable;
import org.apache.commons.lang.Validate; import org.apache.commons.lang.Validate;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Location; import org.bukkit.Location;

View File

@ -46,7 +46,7 @@ items:
- '&eCosts 1 skill reallocation point.' - '&eCosts 1 skill reallocation point.'
- '&e◆ Skill Reallocation Points: &6{points}' - '&e◆ Skill Reallocation Points: &6{points}'
skill-slot: slot:
slots: [ 8,17,26,35,44,53 ] slots: [ 8,17,26,35,44,53 ]
function: slot function: slot
item: BOOK item: BOOK