add change id command (resolves #98)
This commit is contained in:
		
							parent
							
								
									600810ab97
								
							
						
					
					
						commit
						11b81ba5fc
					
				
					 4 changed files with 48 additions and 0 deletions
				
			
		|  | @ -296,6 +296,7 @@ public class ZNpcsPlus { | |||
|                 .addSubcommand("setlocation", new SetLocationCommand(npcRegistry)) | ||||
|                 .addSubcommand("lookatme", new LookAtMeCommand(npcRegistry)) | ||||
|                 .addSubcommand("setrotation", new SetRotationCommand(npcRegistry)) | ||||
|                 .addSubcommand("changeid", new ChangeIdCommand(npcRegistry)) | ||||
|                 .addSubcommand("property", new MultiCommand(bootstrap.loadHelpMessage("property")) | ||||
|                         .addSubcommand("set", new PropertySetCommand(npcRegistry)) | ||||
|                         .addSubcommand("remove", new PropertyRemoveCommand(npcRegistry))) | ||||
|  |  | |||
|  | @ -0,0 +1,36 @@ | |||
| package lol.pyr.znpcsplus.commands; | ||||
| 
 | ||||
| import lol.pyr.director.adventure.command.CommandContext; | ||||
| import lol.pyr.director.adventure.command.CommandHandler; | ||||
| import lol.pyr.director.common.command.CommandExecutionException; | ||||
| import lol.pyr.znpcsplus.npc.NpcEntryImpl; | ||||
| import lol.pyr.znpcsplus.npc.NpcRegistryImpl; | ||||
| import net.kyori.adventure.text.Component; | ||||
| import net.kyori.adventure.text.format.NamedTextColor; | ||||
| 
 | ||||
| import java.util.Collections; | ||||
| import java.util.List; | ||||
| 
 | ||||
| public class ChangeIdCommand implements CommandHandler { | ||||
|     private final NpcRegistryImpl npcRegistry; | ||||
| 
 | ||||
|     public ChangeIdCommand(NpcRegistryImpl npcRegistry) { | ||||
|         this.npcRegistry = npcRegistry; | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public void run(CommandContext context) throws CommandExecutionException { | ||||
|         context.setUsage(context.getLabel() + " changeid <old> <new>"); | ||||
|         NpcEntryImpl old = context.parse(NpcEntryImpl.class); | ||||
|         String newId = context.popString(); | ||||
|         if (npcRegistry.getById(newId) != null) context.halt(Component.text("There is already an npc with the new id you have provided", NamedTextColor.RED)); | ||||
|         npcRegistry.switchIds(old.getId(), newId); | ||||
|         context.send(Component.text("Npc's id changed to " + newId.toLowerCase(), NamedTextColor.GREEN)); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public List<String> suggest(CommandContext context) throws CommandExecutionException { | ||||
|         if (context.argSize() == 1) return context.suggestCollection(npcRegistry.getModifiableIds()); | ||||
|         return Collections.emptyList(); | ||||
|     } | ||||
| } | ||||
|  | @ -161,6 +161,16 @@ public class NpcRegistryImpl implements NpcRegistry { | |||
|         storage.deleteNpc(entry); | ||||
|     } | ||||
| 
 | ||||
|     public void switchIds(String oldId, String newId) { | ||||
|         NpcEntryImpl entry = getById(oldId); | ||||
|         delete(oldId); | ||||
|         NpcEntryImpl newEntry = new NpcEntryImpl(newId, entry.getNpc()); | ||||
|         newEntry.setSave(entry.isSave()); | ||||
|         newEntry.setProcessed(entry.isProcessed()); | ||||
|         newEntry.setAllowCommandModification(entry.isAllowCommandModification()); | ||||
|         register(newEntry); | ||||
|     } | ||||
| 
 | ||||
|     public void unload() { | ||||
|         npcList.forEach(npcEntry -> npcEntry.getNpc().delete()); | ||||
|     } | ||||
|  |  | |||
|  | @ -4,6 +4,7 @@ | |||
| 
 | ||||
|  <gold>* <yellow>/npc create <id> <type> | ||||
|  <gold>* <yellow>/npc delete <id> | ||||
|  <gold>* <yellow>/npc changeid <old> <new> | ||||
|  <gold>* <yellow>/npc toggle <id> | ||||
|  <gold>* <yellow>/npc list | ||||
|  <gold>* <yellow>/npc type <id> <type> | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue