mirror of
https://github.com/CitizensDev/Citizens2.git
synced 2025-01-28 02:51:44 +01:00
Ugly scoreboard persistence
This commit is contained in:
parent
683ffc08f7
commit
9a998c149b
@ -42,6 +42,7 @@ import net.citizensnpcs.trait.CurrentLocation;
|
|||||||
import net.citizensnpcs.trait.Gravity;
|
import net.citizensnpcs.trait.Gravity;
|
||||||
import net.citizensnpcs.trait.HorseModifiers;
|
import net.citizensnpcs.trait.HorseModifiers;
|
||||||
import net.citizensnpcs.trait.LookClose;
|
import net.citizensnpcs.trait.LookClose;
|
||||||
|
import net.citizensnpcs.trait.NPCScoreboard;
|
||||||
import net.citizensnpcs.trait.NPCSkeletonType;
|
import net.citizensnpcs.trait.NPCSkeletonType;
|
||||||
import net.citizensnpcs.trait.OcelotModifiers;
|
import net.citizensnpcs.trait.OcelotModifiers;
|
||||||
import net.citizensnpcs.trait.Poses;
|
import net.citizensnpcs.trait.Poses;
|
||||||
@ -79,6 +80,7 @@ import org.bukkit.entity.Player;
|
|||||||
import org.bukkit.entity.Skeleton.SkeletonType;
|
import org.bukkit.entity.Skeleton.SkeletonType;
|
||||||
import org.bukkit.entity.Villager.Profession;
|
import org.bukkit.entity.Villager.Profession;
|
||||||
import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
|
import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
|
||||||
|
import org.bukkit.metadata.MetadataValue;
|
||||||
import org.bukkit.scoreboard.DisplaySlot;
|
import org.bukkit.scoreboard.DisplaySlot;
|
||||||
import org.bukkit.scoreboard.Objective;
|
import org.bukkit.scoreboard.Objective;
|
||||||
import org.bukkit.scoreboard.Scoreboard;
|
import org.bukkit.scoreboard.Scoreboard;
|
||||||
@ -270,7 +272,7 @@ public class NPCCommands {
|
|||||||
}
|
}
|
||||||
|
|
||||||
CommandSenderCreateNPCEvent event = sender instanceof Player ? new PlayerCreateNPCEvent((Player) sender, copy)
|
CommandSenderCreateNPCEvent event = sender instanceof Player ? new PlayerCreateNPCEvent((Player) sender, copy)
|
||||||
: new CommandSenderCreateNPCEvent(sender, copy);
|
: new CommandSenderCreateNPCEvent(sender, copy);
|
||||||
Bukkit.getPluginManager().callEvent(event);
|
Bukkit.getPluginManager().callEvent(event);
|
||||||
if (event.isCancelled()) {
|
if (event.isCancelled()) {
|
||||||
event.getNPC().destroy();
|
event.getNPC().destroy();
|
||||||
@ -346,7 +348,7 @@ public class NPCCommands {
|
|||||||
spawnLoc = args.getSenderLocation();
|
spawnLoc = args.getSenderLocation();
|
||||||
}
|
}
|
||||||
CommandSenderCreateNPCEvent event = sender instanceof Player ? new PlayerCreateNPCEvent((Player) sender, npc)
|
CommandSenderCreateNPCEvent event = sender instanceof Player ? new PlayerCreateNPCEvent((Player) sender, npc)
|
||||||
: new CommandSenderCreateNPCEvent(sender, npc);
|
: new CommandSenderCreateNPCEvent(sender, npc);
|
||||||
Bukkit.getPluginManager().callEvent(event);
|
Bukkit.getPluginManager().callEvent(event);
|
||||||
if (event.isCancelled()) {
|
if (event.isCancelled()) {
|
||||||
npc.destroy();
|
npc.destroy();
|
||||||
@ -1021,7 +1023,7 @@ public class NPCCommands {
|
|||||||
@Requirements(selected = true, ownership = true, types = { EntityType.CREEPER })
|
@Requirements(selected = true, ownership = true, types = { EntityType.CREEPER })
|
||||||
public void power(CommandContext args, CommandSender sender, NPC npc) {
|
public void power(CommandContext args, CommandSender sender, NPC npc) {
|
||||||
Messaging
|
Messaging
|
||||||
.sendTr(sender, npc.getTrait(Powered.class).toggle() ? Messages.POWERED_SET : Messages.POWERED_STOPPED);
|
.sendTr(sender, npc.getTrait(Powered.class).toggle() ? Messages.POWERED_SET : Messages.POWERED_STOPPED);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Command(
|
@Command(
|
||||||
@ -1044,7 +1046,7 @@ public class NPCCommands {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Command(aliases = { "npc" }, usage = "remove|rem (all|id|name)", desc = "Remove a NPC", modifiers = { "remove",
|
@Command(aliases = { "npc" }, usage = "remove|rem (all|id|name)", desc = "Remove a NPC", modifiers = { "remove",
|
||||||
"rem" }, min = 1, max = 2)
|
"rem" }, min = 1, max = 2)
|
||||||
@Requirements
|
@Requirements
|
||||||
public void remove(final CommandContext args, final CommandSender sender, NPC npc) throws CommandException {
|
public void remove(final CommandContext args, final CommandSender sender, NPC npc) throws CommandException {
|
||||||
if (args.argsLength() == 2) {
|
if (args.argsLength() == 2) {
|
||||||
@ -1135,16 +1137,22 @@ public class NPCCommands {
|
|||||||
permission = "citizens.npc.scoreboard")
|
permission = "citizens.npc.scoreboard")
|
||||||
@Requirements(selected = true, ownership = true, types = EntityType.PLAYER)
|
@Requirements(selected = true, ownership = true, types = EntityType.PLAYER)
|
||||||
public void scoreboard(CommandContext args, CommandSender sender, NPC npc) {
|
public void scoreboard(CommandContext args, CommandSender sender, NPC npc) {
|
||||||
Scoreboard main = Bukkit.getScoreboardManager().getMainScoreboard();
|
Iterable<MetadataValue> itr = npc.getEntity().getMetadata("citizens.scoreboard");
|
||||||
String objective = args.getString(1);
|
Scoreboard main;
|
||||||
String criteria = args.getString(2);
|
if (!itr.iterator().hasNext()) {
|
||||||
|
main = Bukkit.getScoreboardManager().getNewScoreboard();
|
||||||
|
} else {
|
||||||
|
main = (Scoreboard) itr.iterator().next().value();
|
||||||
|
}
|
||||||
|
String objective = Colorizer.parseColors(args.getString(1));
|
||||||
|
String criteria = Colorizer.parseColors(args.getString(2));
|
||||||
Objective obj = main.getObjective(objective);
|
Objective obj = main.getObjective(objective);
|
||||||
if (obj == null) {
|
if (obj == null) {
|
||||||
obj = Bukkit.getScoreboardManager().getMainScoreboard().registerNewObjective(objective, criteria);
|
obj = main.registerNewObjective(objective, criteria);
|
||||||
}
|
}
|
||||||
Player entity = (Player) npc.getEntity();
|
Player entity = (Player) npc.getEntity();
|
||||||
if (args.hasValueFlag("team")) {
|
if (args.hasValueFlag("team")) {
|
||||||
String team = args.getFlag("team");
|
String team = Colorizer.parseColors(args.getFlag("team"));
|
||||||
if (main.getPlayerTeam(entity) != null)
|
if (main.getPlayerTeam(entity) != null)
|
||||||
main.getPlayerTeam(entity).removePlayer(entity);
|
main.getPlayerTeam(entity).removePlayer(entity);
|
||||||
if (main.getTeam(team) == null)
|
if (main.getTeam(team) == null)
|
||||||
@ -1157,6 +1165,7 @@ public class NPCCommands {
|
|||||||
if (args.hasValueFlag("score")) {
|
if (args.hasValueFlag("score")) {
|
||||||
obj.getScore(entity).setScore(args.getFlagInteger("score"));
|
obj.getScore(entity).setScore(args.getFlagInteger("score"));
|
||||||
}
|
}
|
||||||
|
npc.getTrait(NPCScoreboard.class).persistObjective(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Command(
|
@Command(
|
||||||
|
@ -24,6 +24,7 @@ import net.citizensnpcs.trait.CurrentLocation;
|
|||||||
import net.citizensnpcs.trait.Gravity;
|
import net.citizensnpcs.trait.Gravity;
|
||||||
import net.citizensnpcs.trait.HorseModifiers;
|
import net.citizensnpcs.trait.HorseModifiers;
|
||||||
import net.citizensnpcs.trait.LookClose;
|
import net.citizensnpcs.trait.LookClose;
|
||||||
|
import net.citizensnpcs.trait.NPCScoreboard;
|
||||||
import net.citizensnpcs.trait.NPCSkeletonType;
|
import net.citizensnpcs.trait.NPCSkeletonType;
|
||||||
import net.citizensnpcs.trait.OcelotModifiers;
|
import net.citizensnpcs.trait.OcelotModifiers;
|
||||||
import net.citizensnpcs.trait.Poses;
|
import net.citizensnpcs.trait.Poses;
|
||||||
@ -63,6 +64,7 @@ public class CitizensTraitFactory implements TraitFactory {
|
|||||||
registerTrait(TraitInfo.create(Powered.class).withName("powered"));
|
registerTrait(TraitInfo.create(Powered.class).withName("powered"));
|
||||||
registerTrait(TraitInfo.create(Saddle.class).withName("saddle"));
|
registerTrait(TraitInfo.create(Saddle.class).withName("saddle"));
|
||||||
registerTrait(TraitInfo.create(Sheared.class).withName("sheared"));
|
registerTrait(TraitInfo.create(Sheared.class).withName("sheared"));
|
||||||
|
registerTrait(TraitInfo.create(NPCScoreboard.class).withName("npcscoreboard"));
|
||||||
registerTrait(TraitInfo.create(NPCSkeletonType.class).withName("skeletontype"));
|
registerTrait(TraitInfo.create(NPCSkeletonType.class).withName("skeletontype"));
|
||||||
registerTrait(TraitInfo.create(SlimeSize.class).withName("slimesize"));
|
registerTrait(TraitInfo.create(SlimeSize.class).withName("slimesize"));
|
||||||
registerTrait(TraitInfo.create(Spawned.class).withName("spawned"));
|
registerTrait(TraitInfo.create(Spawned.class).withName("spawned"));
|
||||||
|
107
src/main/java/net/citizensnpcs/trait/NPCScoreboard.java
Normal file
107
src/main/java/net/citizensnpcs/trait/NPCScoreboard.java
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
package net.citizensnpcs.trait;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import net.citizensnpcs.api.CitizensAPI;
|
||||||
|
import net.citizensnpcs.api.trait.Trait;
|
||||||
|
import net.citizensnpcs.api.util.DataKey;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.metadata.FixedMetadataValue;
|
||||||
|
import org.bukkit.scoreboard.DisplaySlot;
|
||||||
|
import org.bukkit.scoreboard.Objective;
|
||||||
|
import org.bukkit.scoreboard.Scoreboard;
|
||||||
|
import org.bukkit.scoreboard.Team;
|
||||||
|
|
||||||
|
public class NPCScoreboard extends Trait {
|
||||||
|
private Set<Objective> objectives;
|
||||||
|
private Scoreboard scoreboard;
|
||||||
|
private String team;
|
||||||
|
|
||||||
|
public NPCScoreboard() {
|
||||||
|
super("npcscoreboard");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkScoreboard() {
|
||||||
|
if (scoreboard == null) {
|
||||||
|
if (npc.isSpawned() && !npc.getEntity().getMetadata("citizens.scoreboard").isEmpty()) {
|
||||||
|
scoreboard = (Scoreboard) npc.getEntity().getMetadata("citizens.scoreboard").iterator().next().value();
|
||||||
|
} else {
|
||||||
|
scoreboard = Bukkit.getScoreboardManager().getNewScoreboard();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (npc.getEntity() instanceof Player && npc.getEntity().getMetadata("citizens.scoreboard").isEmpty()) {
|
||||||
|
npc.getEntity().setMetadata("citizens.scoreboard",
|
||||||
|
new FixedMetadataValue(CitizensAPI.getPlugin(), scoreboard));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void load(DataKey root) {
|
||||||
|
checkScoreboard();
|
||||||
|
if (root.keyExists("team")) {
|
||||||
|
team = root.getString("team");
|
||||||
|
}
|
||||||
|
if (!root.keyExists("objectives"))
|
||||||
|
return;
|
||||||
|
for (DataKey sub : root.getRelative("objectives").getSubKeys()) {
|
||||||
|
String objName = sub.name();
|
||||||
|
Objective objective;
|
||||||
|
if (scoreboard.getObjective(objName) != null) {
|
||||||
|
objective = scoreboard.getObjective(objName);
|
||||||
|
} else {
|
||||||
|
objective = scoreboard.registerNewObjective(objName, root.getString("criteria"));
|
||||||
|
}
|
||||||
|
objective.setDisplaySlot(DisplaySlot.valueOf(sub.getString("display")));
|
||||||
|
objectives.add(objective);
|
||||||
|
if (npc.isSpawned() && npc.getEntity() instanceof Player) {
|
||||||
|
objective.getScore((Player) npc.getEntity()).setScore(sub.getInt("score"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSpawn() {
|
||||||
|
if (npc.getEntity() instanceof Player && team != null) {
|
||||||
|
checkScoreboard();
|
||||||
|
scoreboard.getTeam(team).addPlayer((Player) npc.getEntity());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void persistObjective(Objective objective) {
|
||||||
|
if (!objectives.contains(objective)) {
|
||||||
|
objectives.add(objective);
|
||||||
|
}
|
||||||
|
Team playerTeam = objectives.iterator().next().getScoreboard().getPlayerTeam((Player) npc.getEntity());
|
||||||
|
if (team == null) {
|
||||||
|
team = playerTeam.getName();
|
||||||
|
}
|
||||||
|
if (scoreboard == null) {
|
||||||
|
scoreboard = objective.getScoreboard();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void save(DataKey root) {
|
||||||
|
root.removeKey("objectives");
|
||||||
|
root.removeKey("team");
|
||||||
|
if (objectives.isEmpty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (Objective objective : objectives) {
|
||||||
|
DataKey key = root.getRelative("objectives." + objective.getName());
|
||||||
|
key.setString("criteria", objective.getCriteria());
|
||||||
|
key.setString("display", objective.getDisplaySlot().name());
|
||||||
|
if (npc.getEntity() instanceof Player) {
|
||||||
|
key.setInt("score", objective.getScore((Player) npc.getEntity()).getScore());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (npc.getEntity() instanceof Player && team == null) {
|
||||||
|
team = objectives.iterator().next().getScoreboard().getPlayerTeam((Player) npc.getEntity()).getName();
|
||||||
|
}
|
||||||
|
if (team != null) {
|
||||||
|
root.setString("team", team);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user