mirror of
https://github.com/EssentialsX/Essentials.git
synced 2025-01-02 14:37:46 +01:00
Move firework meta handling into MetaItemStack
Allow firework meta to be applied to item spawning and kit commands.
This commit is contained in:
parent
2b8435342d
commit
73c92bf742
@ -122,7 +122,7 @@ public class Kit
|
|||||||
{
|
{
|
||||||
for (int i = 2; i < parts.length; i++)
|
for (int i = 2; i < parts.length; i++)
|
||||||
{
|
{
|
||||||
metaStack.addStringMeta(null, allowUnsafe, parts[i], ess);
|
metaStack.parseStringMeta(user, allowUnsafe, parts, 2, ess);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,15 +2,13 @@ package com.earth2me.essentials;
|
|||||||
|
|
||||||
import static com.earth2me.essentials.I18n._;
|
import static com.earth2me.essentials.I18n._;
|
||||||
import com.earth2me.essentials.textreader.*;
|
import com.earth2me.essentials.textreader.*;
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import org.bukkit.Color;
|
import org.bukkit.Color;
|
||||||
import org.bukkit.DyeColor;
|
import org.bukkit.DyeColor;
|
||||||
import org.bukkit.FireworkEffect;
|
import org.bukkit.FireworkEffect;
|
||||||
import org.bukkit.FireworkEffect.Builder;
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.enchantments.Enchantment;
|
import org.bukkit.enchantments.Enchantment;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.meta.*;
|
import org.bukkit.inventory.meta.*;
|
||||||
@ -20,26 +18,68 @@ public class MetaItemStack
|
|||||||
{
|
{
|
||||||
private final transient Pattern splitPattern = Pattern.compile("[:+',;.]");
|
private final transient Pattern splitPattern = Pattern.compile("[:+',;.]");
|
||||||
private final ItemStack stack;
|
private final ItemStack stack;
|
||||||
|
private final static Map<String, DyeColor> colorMap = new HashMap<String, DyeColor>();
|
||||||
|
private final static Map<String, FireworkEffect.Type> fireworkShape = new HashMap<String, FireworkEffect.Type>();
|
||||||
|
private FireworkEffect.Builder builder = FireworkEffect.builder();
|
||||||
|
private boolean validFirework = false;
|
||||||
|
|
||||||
|
static
|
||||||
|
{
|
||||||
|
for (DyeColor color : DyeColor.values())
|
||||||
|
{
|
||||||
|
colorMap.put(color.name(), color);
|
||||||
|
}
|
||||||
|
for (FireworkEffect.Type type : FireworkEffect.Type.values())
|
||||||
|
{
|
||||||
|
fireworkShape.put(type.name(), type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public MetaItemStack(final ItemStack stack)
|
public MetaItemStack(final ItemStack stack)
|
||||||
{
|
{
|
||||||
this.stack = stack.clone();
|
this.stack = stack.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
public ItemStack getItemStack()
|
public ItemStack getItemStack()
|
||||||
{
|
{
|
||||||
return stack;
|
return stack;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isValidFirework()
|
||||||
|
{
|
||||||
|
return validFirework;
|
||||||
|
}
|
||||||
|
|
||||||
|
public FireworkEffect.Builder getFireworkBuilder()
|
||||||
|
{
|
||||||
|
return builder;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void parseStringMeta(final CommandSender user, final boolean allowUnsafe, String[] string, int fromArg, final IEssentials ess) throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
for (int i = fromArg; i < string.length; i++)
|
||||||
|
{
|
||||||
|
addStringMeta(user, allowUnsafe, string[i], ess);
|
||||||
|
}
|
||||||
|
if (validFirework)
|
||||||
|
{
|
||||||
|
FireworkEffect effect = builder.build();
|
||||||
|
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
|
||||||
|
fmeta.addEffect(effect);
|
||||||
|
stack.setItemMeta(fmeta);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//TODO: TL this
|
//TODO: TL this
|
||||||
public void addStringMeta(final User user, final boolean allowUnsafe, final String string, final IEssentials ess) throws Exception
|
private void addStringMeta(final CommandSender user, final boolean allowUnsafe, final String string, final IEssentials ess) throws Exception
|
||||||
{
|
{
|
||||||
final String[] split = splitPattern.split(string, 2);
|
final String[] split = splitPattern.split(string, 2);
|
||||||
if (split.length < 1)
|
if (split.length < 1)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (split.length > 1 && split[0].equalsIgnoreCase("name"))
|
if (split.length > 1 && split[0].equalsIgnoreCase("name"))
|
||||||
{
|
{
|
||||||
final String displayName = Util.replaceFormat(split[1].replace('_', ' '));
|
final String displayName = Util.replaceFormat(split[1].replace('_', ' '));
|
||||||
@ -76,11 +116,11 @@ public class MetaItemStack
|
|||||||
{
|
{
|
||||||
final BookMeta meta = (BookMeta)stack.getItemMeta();
|
final BookMeta meta = (BookMeta)stack.getItemMeta();
|
||||||
final IText input = new BookInput("book", true, ess);
|
final IText input = new BookInput("book", true, ess);
|
||||||
final BookPager pager = new BookPager(input);
|
final BookPager pager = new BookPager(input);
|
||||||
|
|
||||||
List<String> pages = pager.getPages(split[1]);
|
List<String> pages = pager.getPages(split[1]);
|
||||||
meta.setPages(pages);
|
meta.setPages(pages);
|
||||||
|
|
||||||
stack.setItemMeta(meta);
|
stack.setItemMeta(meta);
|
||||||
}
|
}
|
||||||
else if (split.length > 1 && split[0].equalsIgnoreCase("author") && stack.getType() == Material.WRITTEN_BOOK)
|
else if (split.length > 1 && split[0].equalsIgnoreCase("author") && stack.getType() == Material.WRITTEN_BOOK)
|
||||||
@ -97,36 +137,10 @@ public class MetaItemStack
|
|||||||
meta.setTitle(title);
|
meta.setTitle(title);
|
||||||
stack.setItemMeta(meta);
|
stack.setItemMeta(meta);
|
||||||
}
|
}
|
||||||
else if (split.length > 1 && split[0].equalsIgnoreCase("power") && stack.getType() == Material.FIREWORK)
|
else if (stack.getType() == Material.FIREWORK) //WARNING - Meta for fireworks will be ignored after this point.
|
||||||
{
|
{
|
||||||
final int power = Integer.parseInt(split[1]);
|
addFireworkMeta(user, false, string, ess);
|
||||||
final FireworkMeta meta = (FireworkMeta)stack.getItemMeta();
|
|
||||||
meta.setPower(power);
|
|
||||||
stack.setItemMeta(meta);
|
|
||||||
}
|
}
|
||||||
// else if (split.length > 1 && split[0].equalsIgnoreCase("effect") && stack.getType() == Material.FIREWORK)
|
|
||||||
// {
|
|
||||||
// //TODO: Add validation messages
|
|
||||||
// final FireworkMeta meta = (FireworkMeta)stack.getItemMeta();
|
|
||||||
// Builder builder = FireworkEffect.builder();
|
|
||||||
//
|
|
||||||
// String[] effectData = split[1].toUpperCase(Locale.ENGLISH).split("\\|");
|
|
||||||
//
|
|
||||||
// builder.with(FireworkEffect.Type.valueOf(effectData[0]));
|
|
||||||
//
|
|
||||||
// String[] primaryColorStrings = effectData[1].split(",");
|
|
||||||
// List<Color> primaryColors = new ArrayList<Color>();
|
|
||||||
//
|
|
||||||
// for (String primaryColorString : primaryColorStrings) {
|
|
||||||
// primaryColors.add(DyeColor.valueOf(primaryColorString).getFireworkColor());
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// builder.withColor(primaryColors);
|
|
||||||
//
|
|
||||||
// final FireworkEffect effect = builder.build();
|
|
||||||
// meta.addEffect(effect);
|
|
||||||
// stack.setItemMeta(meta);
|
|
||||||
// }
|
|
||||||
else if (split.length > 1 && (split[0].equalsIgnoreCase("color") || split[0].equalsIgnoreCase("colour"))
|
else if (split.length > 1 && (split[0].equalsIgnoreCase("color") || split[0].equalsIgnoreCase("colour"))
|
||||||
&& (stack.getType() == Material.LEATHER_BOOTS
|
&& (stack.getType() == Material.LEATHER_BOOTS
|
||||||
|| stack.getType() == Material.LEATHER_CHESTPLATE
|
|| stack.getType() == Material.LEATHER_CHESTPLATE
|
||||||
@ -153,22 +167,108 @@ public class MetaItemStack
|
|||||||
parseEnchantmentStrings(user, allowUnsafe, split);
|
parseEnchantmentStrings(user, allowUnsafe, split);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addStringEnchantment(final User user, final boolean allowUnsafe, final String string) throws Exception
|
public void addFireworkMeta(final CommandSender user, final boolean allowShortName, final String string, final IEssentials ess)
|
||||||
{
|
{
|
||||||
final String[] split = splitPattern.split(string, 2);
|
if (stack.getType() == Material.FIREWORK)
|
||||||
if (split.length < 1)
|
|
||||||
{
|
{
|
||||||
return;
|
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
|
||||||
|
final String[] split = splitPattern.split(string, 2);
|
||||||
|
|
||||||
|
if (split[0].equalsIgnoreCase("color") || split[0].equalsIgnoreCase("colour") || (allowShortName && split[0].equalsIgnoreCase("c")))
|
||||||
|
{
|
||||||
|
List<Color> primaryColors = new ArrayList<Color>();
|
||||||
|
String[] colors = split[1].split(",");
|
||||||
|
for (String color : colors)
|
||||||
|
{
|
||||||
|
if (colorMap.containsKey(color.toUpperCase()))
|
||||||
|
{
|
||||||
|
validFirework = true;
|
||||||
|
primaryColors.add(colorMap.get(color.toUpperCase()).getFireworkColor());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
builder.withColor(primaryColors);
|
||||||
|
}
|
||||||
|
else if (split[0].equalsIgnoreCase("shape") || split[0].equalsIgnoreCase("type") || (allowShortName && (split[0].equalsIgnoreCase("s") || split[0].equalsIgnoreCase("t"))))
|
||||||
|
{
|
||||||
|
FireworkEffect.Type finalEffect = null;
|
||||||
|
split[1] = (split[1].equalsIgnoreCase("large") ? "BALL_LARGE" : split[1]);
|
||||||
|
if (fireworkShape.containsKey(split[1].toUpperCase()))
|
||||||
|
{
|
||||||
|
finalEffect = fireworkShape.get(split[1].toUpperCase());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
||||||
|
}
|
||||||
|
if (finalEffect != null)
|
||||||
|
{
|
||||||
|
builder.with(finalEffect);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (split[0].equalsIgnoreCase("fade") || (allowShortName && split[0].equalsIgnoreCase("f")))
|
||||||
|
{
|
||||||
|
List<Color> fadeColors = new ArrayList<Color>();
|
||||||
|
String[] colors = split[1].split(",");
|
||||||
|
for (String color : colors)
|
||||||
|
{
|
||||||
|
if (colorMap.containsKey(color.toUpperCase()))
|
||||||
|
{
|
||||||
|
fadeColors.add(colorMap.get(color.toUpperCase()).getFireworkColor());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!fadeColors.isEmpty())
|
||||||
|
{
|
||||||
|
builder.withFade(fadeColors);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (split[0].equalsIgnoreCase("effect") || (allowShortName && split[0].equalsIgnoreCase("e")))
|
||||||
|
{
|
||||||
|
String[] effects = split[1].split(",");
|
||||||
|
for (String effect : effects)
|
||||||
|
{
|
||||||
|
if (effect.equalsIgnoreCase("twinkle"))
|
||||||
|
{
|
||||||
|
builder.flicker(true);
|
||||||
|
}
|
||||||
|
else if (effect.equalsIgnoreCase("trail"))
|
||||||
|
{
|
||||||
|
builder.trail(true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (split[0].equalsIgnoreCase("power") || (allowShortName && split[0].equalsIgnoreCase("p")))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
int power = Integer.parseInt(split[1]);
|
||||||
|
fmeta.setPower(power > 3 ? 4 : power);
|
||||||
|
}
|
||||||
|
catch (NumberFormatException e)
|
||||||
|
{
|
||||||
|
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
||||||
|
}
|
||||||
|
stack.setItemMeta(fmeta);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
parseEnchantmentStrings(user, allowUnsafe, split);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void parseEnchantmentStrings(final User user, final boolean allowUnsafe, final String[] split) throws Exception
|
private void parseEnchantmentStrings(final CommandSender user, final boolean allowUnsafe, final String[] split) throws Exception
|
||||||
{
|
{
|
||||||
Enchantment enchantment = getEnchantment(user, split[0]);
|
Enchantment enchantment = getEnchantment(null, split[0]);
|
||||||
|
|
||||||
int level = -1;
|
int level = -1;
|
||||||
if (split.length > 1)
|
if (split.length > 1)
|
||||||
{
|
{
|
||||||
@ -181,15 +281,15 @@ public class MetaItemStack
|
|||||||
level = -1;
|
level = -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (level < 0 || (!allowUnsafe && level > enchantment.getMaxLevel()))
|
if (level < 0 || (!allowUnsafe && level > enchantment.getMaxLevel()))
|
||||||
{
|
{
|
||||||
level = enchantment.getMaxLevel();
|
level = enchantment.getMaxLevel();
|
||||||
}
|
}
|
||||||
addEnchantment(user, allowUnsafe, enchantment, level);
|
addEnchantment(user, allowUnsafe, enchantment, level);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addEnchantment(final User user, final boolean allowUnsafe, final Enchantment enchantment, final int level) throws Exception
|
public void addEnchantment(final CommandSender user, final boolean allowUnsafe, final Enchantment enchantment, final int level) throws Exception
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -63,9 +63,8 @@ public class Commandenchant extends EssentialsCommand
|
|||||||
final MetaItemStack metaStack = new MetaItemStack(stack);
|
final MetaItemStack metaStack = new MetaItemStack(stack);
|
||||||
final Enchantment enchantment = metaStack.getEnchantment(user, args[0]);
|
final Enchantment enchantment = metaStack.getEnchantment(user, args[0]);
|
||||||
metaStack.addEnchantment(user, allowUnsafe, enchantment, level);
|
metaStack.addEnchantment(user, allowUnsafe, enchantment, level);
|
||||||
|
|
||||||
|
|
||||||
user.getInventory().setItemInHand(metaStack.getItemStack());
|
user.getInventory().setItemInHand(metaStack.getItemStack());
|
||||||
|
|
||||||
user.updateInventory();
|
user.updateInventory();
|
||||||
final String enchantmentName = enchantment.getName().toLowerCase(Locale.ENGLISH);
|
final String enchantmentName = enchantment.getName().toLowerCase(Locale.ENGLISH);
|
||||||
if (level == 0)
|
if (level == 0)
|
||||||
|
@ -1,13 +1,12 @@
|
|||||||
package com.earth2me.essentials.commands;
|
package com.earth2me.essentials.commands;
|
||||||
|
|
||||||
import com.earth2me.essentials.User;
|
|
||||||
import static com.earth2me.essentials.I18n._;
|
import static com.earth2me.essentials.I18n._;
|
||||||
import java.util.ArrayList;
|
import com.earth2me.essentials.MetaItemStack;
|
||||||
|
import com.earth2me.essentials.User;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import org.bukkit.Color;
|
|
||||||
import org.bukkit.DyeColor;
|
import org.bukkit.DyeColor;
|
||||||
import org.bukkit.FireworkEffect;
|
import org.bukkit.FireworkEffect;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
@ -44,116 +43,28 @@ public class Commandfirework extends EssentialsCommand
|
|||||||
@Override
|
@Override
|
||||||
protected void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception
|
protected void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception
|
||||||
{
|
{
|
||||||
|
|
||||||
if (args.length > 0)
|
if (args.length > 0)
|
||||||
{
|
{
|
||||||
ItemStack stack = user.getItemInHand();
|
final ItemStack stack = user.getItemInHand();
|
||||||
if (stack.getType() == Material.FIREWORK)
|
if (stack.getType() == Material.FIREWORK)
|
||||||
{
|
{
|
||||||
FireworkEffect.Builder builder = FireworkEffect.builder();
|
|
||||||
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
|
|
||||||
|
|
||||||
if (args.length > 0)
|
if (args.length > 0)
|
||||||
{
|
{
|
||||||
if (args[0].equalsIgnoreCase("clear"))
|
if (args[0].equalsIgnoreCase("clear"))
|
||||||
{
|
{
|
||||||
|
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
|
||||||
fmeta.clearEffects();
|
fmeta.clearEffects();
|
||||||
stack.setItemMeta(fmeta);
|
stack.setItemMeta(fmeta);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
List<Color> primaryColors = new ArrayList<Color>();
|
final MetaItemStack mStack = new MetaItemStack(stack);
|
||||||
List<Color> fadeColors = new ArrayList<Color>();
|
|
||||||
FireworkEffect.Type finalEffect = null;
|
|
||||||
|
|
||||||
boolean valid = false;
|
|
||||||
boolean fire = false;
|
boolean fire = false;
|
||||||
int amount = 1;
|
int amount = 1;
|
||||||
for (String arg : args)
|
for (String arg : args)
|
||||||
{
|
{
|
||||||
final String[] split = splitPattern.split(arg, 2);
|
final String[] split = splitPattern.split(arg, 2);
|
||||||
if (split[0].equalsIgnoreCase("color") || split[0].equalsIgnoreCase("colour") || split[0].equalsIgnoreCase("c"))
|
mStack.addFireworkMeta(user, true, arg, ess);
|
||||||
{
|
|
||||||
String[] colors = split[1].split(",");
|
|
||||||
for (String color : colors)
|
|
||||||
{
|
|
||||||
if (colorMap.containsKey(color.toUpperCase()))
|
|
||||||
{
|
|
||||||
valid = true;
|
|
||||||
primaryColors.add(colorMap.get(color.toUpperCase()).getFireworkColor());
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
builder.withColor(primaryColors);
|
|
||||||
}
|
|
||||||
if (split[0].equalsIgnoreCase("shape") || split[0].equalsIgnoreCase("s") || split[0].equalsIgnoreCase("type") || split[0].equalsIgnoreCase("t"))
|
|
||||||
{
|
|
||||||
split[1] = (split[1].equalsIgnoreCase("large") ? "BALL_LARGE" : split[1]);
|
|
||||||
if (fireworkShape.containsKey(split[1].toUpperCase()))
|
|
||||||
{
|
|
||||||
finalEffect = fireworkShape.get(split[1].toUpperCase());
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
|
||||||
}
|
|
||||||
if (finalEffect != null)
|
|
||||||
{
|
|
||||||
builder.with(finalEffect);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (split[0].equalsIgnoreCase("fade") || split[0].equalsIgnoreCase("f"))
|
|
||||||
{
|
|
||||||
String[] colors = split[1].split(",");
|
|
||||||
for (String color : colors)
|
|
||||||
{
|
|
||||||
if (colorMap.containsKey(color.toUpperCase()))
|
|
||||||
{
|
|
||||||
fadeColors.add(colorMap.get(color.toUpperCase()).getFireworkColor());
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!fadeColors.isEmpty())
|
|
||||||
{
|
|
||||||
builder.withFade(fadeColors);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (split[0].equalsIgnoreCase("effect") || split[0].equalsIgnoreCase("e"))
|
|
||||||
{
|
|
||||||
String[] effects = split[1].split(",");
|
|
||||||
for (String effect : effects)
|
|
||||||
{
|
|
||||||
if (effect.equalsIgnoreCase("twinkle"))
|
|
||||||
{
|
|
||||||
builder.flicker(true);
|
|
||||||
}
|
|
||||||
else if (effect.equalsIgnoreCase("trail"))
|
|
||||||
{
|
|
||||||
builder.trail(true);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (split[0].equalsIgnoreCase("power") || split[0].equalsIgnoreCase("p"))
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
fmeta.setPower(Integer.parseInt(split[1]));
|
|
||||||
}
|
|
||||||
catch (NumberFormatException e)
|
|
||||||
{
|
|
||||||
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (split[0].equalsIgnoreCase("fire") && user.isAuthorized("essentials.firework.fire"))
|
if (split[0].equalsIgnoreCase("fire") && user.isAuthorized("essentials.firework.fire"))
|
||||||
{
|
{
|
||||||
fire = true;
|
fire = true;
|
||||||
@ -161,7 +72,7 @@ public class Commandfirework extends EssentialsCommand
|
|||||||
{
|
{
|
||||||
amount = Integer.parseInt(split[1]);
|
amount = Integer.parseInt(split[1]);
|
||||||
int serverLimit = ess.getSettings().getSpawnMobLimit();
|
int serverLimit = ess.getSettings().getSpawnMobLimit();
|
||||||
if(amount > serverLimit)
|
if (amount > serverLimit)
|
||||||
{
|
{
|
||||||
amount = serverLimit;
|
amount = serverLimit;
|
||||||
user.sendMessage(_("mobSpawnLimit"));
|
user.sendMessage(_("mobSpawnLimit"));
|
||||||
@ -173,31 +84,32 @@ public class Commandfirework extends EssentialsCommand
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (valid)
|
|
||||||
|
if (fire)
|
||||||
{
|
{
|
||||||
if (fire)
|
for (int i = 0; i < amount; i++)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < amount; i++ )
|
Firework firework = (Firework)user.getWorld().spawnEntity(user.getLocation(), EntityType.FIREWORK);
|
||||||
|
FireworkMeta fmeta = (FireworkMeta)mStack.getItemStack().getItemMeta();
|
||||||
|
if (mStack.isValidFirework())
|
||||||
{
|
{
|
||||||
Firework firework = (Firework)user.getWorld().spawnEntity(user.getLocation(), EntityType.FIREWORK);
|
FireworkEffect effect = mStack.getFireworkBuilder().build();
|
||||||
FireworkMeta ffmeta = firework.getFireworkMeta();
|
fmeta.addEffect(effect);
|
||||||
ffmeta.addEffect(builder.build());
|
|
||||||
ffmeta.setPower(fmeta.getPower());
|
|
||||||
firework.setFireworkMeta(ffmeta);
|
|
||||||
}
|
}
|
||||||
}
|
firework.setFireworkMeta(fmeta);
|
||||||
else
|
|
||||||
{
|
|
||||||
final FireworkEffect effect = builder.build();
|
|
||||||
fmeta.addEffect(effect);
|
|
||||||
stack.setItemMeta(fmeta);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else if (!mStack.isValidFirework())
|
||||||
{
|
{
|
||||||
user.sendMessage(_("fireworkColor"));
|
user.sendMessage(_("fireworkColor"));
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FireworkMeta fmeta = (FireworkMeta)mStack.getItemStack().getItemMeta();
|
||||||
|
FireworkEffect effect = mStack.getFireworkBuilder().build();
|
||||||
|
fmeta.addEffect(effect);
|
||||||
|
stack.setItemMeta(fmeta);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -208,7 +120,26 @@ public class Commandfirework extends EssentialsCommand
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
throw new NotEnoughArgumentsException();
|
final ItemStack stack = user.getItemInHand();
|
||||||
|
if (stack.getType() == Material.FIREWORK)
|
||||||
|
{
|
||||||
|
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
|
||||||
|
List<FireworkEffect> effects = fmeta.getEffects();
|
||||||
|
user.sendMessage("The firework you are holding has the following effects:");
|
||||||
|
|
||||||
|
for (FireworkEffect effect : effects)
|
||||||
|
{
|
||||||
|
StringBuilder effectDesc = new StringBuilder();
|
||||||
|
effectDesc.append("Effect: ");
|
||||||
|
Map<String, Object> desc = effect.serialize();
|
||||||
|
|
||||||
|
for (String info : desc.keySet())
|
||||||
|
{
|
||||||
|
effectDesc.append(info).append(": ").append(desc.get(info)).append(" ");
|
||||||
|
}
|
||||||
|
user.sendMessage(effectDesc.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -77,11 +77,9 @@ public class Commandgive extends EssentialsCommand
|
|||||||
{
|
{
|
||||||
allowUnsafe = false;
|
allowUnsafe = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = Util.isInt(args[3]) ? 4 : 3; i < args.length; i++)
|
metaStack.parseStringMeta(sender, allowUnsafe, args, Util.isInt(args[3]) ? 4 : 3, ess);
|
||||||
{
|
|
||||||
metaStack.addStringMeta(null, allowUnsafe, args[i], ess);
|
|
||||||
}
|
|
||||||
stack = metaStack.getItemStack();
|
stack = metaStack.getItemStack();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@ package com.earth2me.essentials.commands;
|
|||||||
import static com.earth2me.essentials.I18n._;
|
import static com.earth2me.essentials.I18n._;
|
||||||
import com.earth2me.essentials.MetaItemStack;
|
import com.earth2me.essentials.MetaItemStack;
|
||||||
import com.earth2me.essentials.User;
|
import com.earth2me.essentials.User;
|
||||||
|
import com.earth2me.essentials.Util;
|
||||||
import com.earth2me.essentials.craftbukkit.InventoryWorkaround;
|
import com.earth2me.essentials.craftbukkit.InventoryWorkaround;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
@ -59,11 +60,9 @@ public class Commanditem extends EssentialsCommand
|
|||||||
{
|
{
|
||||||
MetaItemStack metaStack = new MetaItemStack(stack);
|
MetaItemStack metaStack = new MetaItemStack(stack);
|
||||||
final boolean allowUnsafe = ess.getSettings().allowUnsafeEnchantments() && user.isAuthorized("essentials.enchant.allowunsafe");
|
final boolean allowUnsafe = ess.getSettings().allowUnsafeEnchantments() && user.isAuthorized("essentials.enchant.allowunsafe");
|
||||||
|
|
||||||
for (int i = 2; i < args.length; i++)
|
metaStack.parseStringMeta(user, allowUnsafe, args, 2, ess);
|
||||||
{
|
|
||||||
metaStack.addStringMeta(null, allowUnsafe, args[i], ess);
|
|
||||||
}
|
|
||||||
stack = metaStack.getItemStack();
|
stack = metaStack.getItemStack();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user