mirror of
https://github.com/TotalFreedomMC/PlayerParticles.git
synced 2025-07-06 14:01:28 +00:00
216 lines
10 KiB
Java
216 lines
10 KiB
Java
package dev.esophose.playerparticles.command;
|
|
|
|
import dev.esophose.playerparticles.PlayerParticles;
|
|
import dev.esophose.playerparticles.manager.DataManager;
|
|
import dev.esophose.playerparticles.manager.LocaleManager;
|
|
import dev.esophose.playerparticles.manager.ParticleStyleManager;
|
|
import dev.esophose.playerparticles.manager.PermissionManager;
|
|
import dev.esophose.playerparticles.particles.PPlayer;
|
|
import dev.esophose.playerparticles.particles.ParticleEffect;
|
|
import dev.esophose.playerparticles.particles.ParticleEffect.NoteColor;
|
|
import dev.esophose.playerparticles.particles.ParticleEffect.OrdinaryColor;
|
|
import dev.esophose.playerparticles.particles.ParticleEffect.ParticleProperty;
|
|
import dev.esophose.playerparticles.particles.ParticleGroup;
|
|
import dev.esophose.playerparticles.particles.ParticlePair;
|
|
import dev.esophose.playerparticles.styles.ParticleStyle;
|
|
import dev.esophose.playerparticles.util.ParticleUtils;
|
|
import dev.esophose.playerparticles.util.StringPlaceholders;
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
import org.bukkit.Material;
|
|
import org.bukkit.entity.Player;
|
|
import org.bukkit.util.StringUtil;
|
|
|
|
public class AddCommandModule implements CommandModule {
|
|
|
|
public void onCommandExecute(PPlayer pplayer, String[] args) {
|
|
if (args.length < 2) {
|
|
CommandModule.printUsage(pplayer, this);
|
|
return;
|
|
}
|
|
|
|
PermissionManager permissionManager = PlayerParticles.getInstance().getManager(PermissionManager.class);
|
|
LocaleManager localeManager = PlayerParticles.getInstance().getManager(LocaleManager.class);
|
|
|
|
int maxParticlesAllowed = permissionManager.getMaxParticlesAllowed(pplayer.getPlayer());
|
|
if (pplayer.getActiveParticles().size() >= maxParticlesAllowed) {
|
|
localeManager.sendMessage(pplayer, "add-reached-max", StringPlaceholders.single("amount", maxParticlesAllowed));
|
|
return;
|
|
}
|
|
|
|
ParticleEffect effect = ParticleEffect.fromName(args[0]);
|
|
if (effect == null) {
|
|
localeManager.sendMessage(pplayer, "effect-invalid", StringPlaceholders.single("effect", args[0]));
|
|
return;
|
|
} else if (!permissionManager.hasEffectPermission(pplayer.getPlayer(), effect)) {
|
|
localeManager.sendMessage(pplayer, "effect-no-permission", StringPlaceholders.single("effect", effect.getName()));
|
|
return;
|
|
}
|
|
|
|
ParticleStyle style = ParticleStyle.fromName(args[1]);
|
|
if (style == null) {
|
|
localeManager.sendMessage(pplayer, "style-invalid", StringPlaceholders.single("style", args[1]));
|
|
return;
|
|
} else if (!permissionManager.hasStylePermission(pplayer.getPlayer(), style)) {
|
|
localeManager.sendMessage(pplayer, "style-no-permission", StringPlaceholders.single("style", args[1]));
|
|
return;
|
|
}
|
|
|
|
Material itemData = null;
|
|
Material blockData = null;
|
|
OrdinaryColor colorData = null;
|
|
NoteColor noteColorData = null;
|
|
|
|
if (args.length > 2) {
|
|
if (effect.hasProperty(ParticleProperty.COLORABLE)) {
|
|
if (effect == ParticleEffect.NOTE) {
|
|
if (args[2].equalsIgnoreCase("rainbow")) {
|
|
noteColorData = new NoteColor(99);
|
|
} else if (args[2].equalsIgnoreCase("random")) {
|
|
noteColorData = new NoteColor(98);
|
|
} else {
|
|
int note;
|
|
try {
|
|
note = Integer.parseInt(args[2]);
|
|
} catch (Exception e) {
|
|
localeManager.sendMessage(pplayer, "data-invalid-note");
|
|
return;
|
|
}
|
|
|
|
if (note < 0 || note > 24) {
|
|
localeManager.sendMessage(pplayer, "data-invalid-note");
|
|
return;
|
|
}
|
|
|
|
noteColorData = new NoteColor(note);
|
|
}
|
|
} else {
|
|
if (args[2].equalsIgnoreCase("rainbow")) {
|
|
colorData = new OrdinaryColor(999, 999, 999);
|
|
} else if (args[2].equalsIgnoreCase("random")) {
|
|
colorData = new OrdinaryColor(998, 998, 998);
|
|
} else {
|
|
int r, g, b;
|
|
|
|
try {
|
|
r = Integer.parseInt(args[2]);
|
|
g = Integer.parseInt(args[3]);
|
|
b = Integer.parseInt(args[4]);
|
|
} catch (Exception e) {
|
|
localeManager.sendMessage(pplayer, "data-invalid-color");
|
|
return;
|
|
}
|
|
|
|
if (r < 0 || r > 255 || g < 0 || g > 255 || b < 0 || b > 255) {
|
|
localeManager.sendMessage(pplayer, "data-invalid-color");
|
|
return;
|
|
}
|
|
|
|
colorData = new OrdinaryColor(r, g, b);
|
|
}
|
|
}
|
|
} else if (effect.hasProperty(ParticleProperty.REQUIRES_MATERIAL_DATA)) {
|
|
if (effect == ParticleEffect.BLOCK || effect == ParticleEffect.FALLING_DUST) {
|
|
try {
|
|
blockData = ParticleUtils.closestMatch(args[2]);
|
|
if (blockData == null || !blockData.isBlock()) throw new Exception();
|
|
} catch (Exception e) {
|
|
localeManager.sendMessage(pplayer, "data-invalid-block");
|
|
return;
|
|
}
|
|
} else if (effect == ParticleEffect.ITEM) {
|
|
try {
|
|
itemData = ParticleUtils.closestMatch(args[2]);
|
|
if (itemData == null || itemData.isBlock()) throw new Exception();
|
|
} catch (Exception e) {
|
|
localeManager.sendMessage(pplayer, "data-invalid-item");
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
ParticleGroup group = pplayer.getActiveParticleGroup();
|
|
ParticlePair newParticle = new ParticlePair(pplayer.getUniqueId(), pplayer.getNextActiveParticleId(), effect, style, itemData, blockData, colorData, noteColorData);
|
|
group.getParticles().add(newParticle);
|
|
PlayerParticles.getInstance().getManager(DataManager.class).saveParticleGroup(pplayer.getUniqueId(), group);
|
|
|
|
StringPlaceholders addParticlePlaceholders = StringPlaceholders.builder("effect", newParticle.getEffect().getName())
|
|
.addPlaceholder("style", newParticle.getStyle().getName())
|
|
.addPlaceholder("data", newParticle.getDataString()).build();
|
|
localeManager.sendMessage(pplayer, "add-particle-applied", addParticlePlaceholders);
|
|
|
|
if (PlayerParticles.getInstance().getManager(ParticleStyleManager.class).isCustomHandled(newParticle.getStyle())) {
|
|
localeManager.sendMessage(pplayer, "style-event-spawning-info", StringPlaceholders.single("style", newParticle.getStyle().getName()));
|
|
}
|
|
}
|
|
|
|
public List<String> onTabComplete(PPlayer pplayer, String[] args) {
|
|
Player p = pplayer.getPlayer();
|
|
List<String> matches = new ArrayList<>();
|
|
PermissionManager permissionManager = PlayerParticles.getInstance().getManager(PermissionManager.class);
|
|
|
|
if (args.length <= 1) { // Effect name
|
|
if (args.length == 0) matches = permissionManager.getEffectNamesUserHasPermissionFor(p);
|
|
else StringUtil.copyPartialMatches(args[0], permissionManager.getEffectNamesUserHasPermissionFor(p), matches);
|
|
} else if (args.length == 2) { // Style name
|
|
StringUtil.copyPartialMatches(args[1], permissionManager.getStyleNamesUserHasPermissionFor(p), matches);
|
|
} else { // Data
|
|
ParticleEffect effect = ParticleEffect.fromName(args[0]);
|
|
if (effect != null) {
|
|
if (effect.hasProperty(ParticleProperty.COLORABLE)) {
|
|
List<String> possibleValues = new ArrayList<>();
|
|
if (effect == ParticleEffect.NOTE) { // Note data
|
|
if (args.length == 3) {
|
|
possibleValues.add("<0-24>");
|
|
possibleValues.add("rainbow");
|
|
possibleValues.add("random");
|
|
}
|
|
} else { // Color data
|
|
if (args.length <= 5 && !args[2].equalsIgnoreCase("rainbow") && !args[2].equalsIgnoreCase("random")) {
|
|
possibleValues.add("<0-255>");
|
|
}
|
|
if (args.length <= 4 && !args[2].equalsIgnoreCase("rainbow") && !args[2].equalsIgnoreCase("random")) {
|
|
possibleValues.add("<0-255> <0-255>");
|
|
}
|
|
if (args.length <= 3) {
|
|
possibleValues.add("<0-255> <0-255> <0-255>");
|
|
possibleValues.add("rainbow");
|
|
possibleValues.add("random");
|
|
}
|
|
}
|
|
StringUtil.copyPartialMatches(args[args.length - 1], possibleValues, matches);
|
|
} else if (args.length == 3 && effect.hasProperty(ParticleProperty.REQUIRES_MATERIAL_DATA)) {
|
|
if (effect == ParticleEffect.BLOCK || effect == ParticleEffect.FALLING_DUST) { // Block material
|
|
StringUtil.copyPartialMatches(args[2], ParticleUtils.getAllBlockMaterials(), matches);
|
|
} else if (effect == ParticleEffect.ITEM) { // Item material
|
|
StringUtil.copyPartialMatches(args[2], ParticleUtils.getAllItemMaterials(), matches);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return matches;
|
|
}
|
|
|
|
public String getName() {
|
|
return "add";
|
|
}
|
|
|
|
public String getDescriptionKey() {
|
|
return "command-description-add";
|
|
}
|
|
|
|
public String getArguments() {
|
|
return "<effect> <style> [data]";
|
|
}
|
|
|
|
public boolean requiresEffects() {
|
|
return true;
|
|
}
|
|
|
|
public boolean canConsoleExecute() {
|
|
return false;
|
|
}
|
|
|
|
}
|