mirror of
https://github.com/TotalFreedomMC/TF-ProjectKorra.git
synced 2025-01-05 14:38:24 +00:00
Fixes (#551)
-Fixed EarthTunnel dropping blocks -Fixed EarthTunnel not breaking blocks from certain moves -Fixed EarthTunnel on RaiseEarth leaving blocks behind -Metal Clips throw option is now enabled by default -Trying to bend a subelement says "You are not a {subelement}" instead of "you don't have access to {subelement}" -WaterSpout can now be activated above water -Added check to see if player can bend Packed Ice when they move onto it from another block -IceArms can form under water -Aliases now works for /bending choose {element} {player}
This commit is contained in:
parent
cec9df3ca7
commit
1ede291efd
5 changed files with 25 additions and 8 deletions
|
@ -78,7 +78,7 @@ public class BindCommand extends PKCommand {
|
||||||
} else if (coreAbil == null || !bPlayer.canBind(coreAbil)) {
|
} else if (coreAbil == null || !bPlayer.canBind(coreAbil)) {
|
||||||
if (coreAbil != null && coreAbil.getElement() != Element.AVATAR && !bPlayer.hasElement(coreAbil.getElement())) {
|
if (coreAbil != null && coreAbil.getElement() != Element.AVATAR && !bPlayer.hasElement(coreAbil.getElement())) {
|
||||||
if (coreAbil.getElement() instanceof SubElement) {
|
if (coreAbil.getElement() instanceof SubElement) {
|
||||||
sender.sendMessage(ChatColor.RED + this.noSubElement.replace("{subelement}", coreAbil.getElement().getName() + coreAbil.getElement().getType().getBending()));
|
sender.sendMessage(ChatColor.RED + this.noSubElement.replace("{subelement}", coreAbil.getElement().getName() + coreAbil.getElement().getType().getBender()));
|
||||||
} else {
|
} else {
|
||||||
sender.sendMessage(ChatColor.RED + this.noElement.replace("{element}", coreAbil.getElement().getName() + coreAbil.getElement().getType().getBender()));
|
sender.sendMessage(ChatColor.RED + this.noElement.replace("{element}", coreAbil.getElement().getName() + coreAbil.getElement().getType().getBender()));
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,12 +71,12 @@ public class ChooseCommand extends PKCommand {
|
||||||
else if (element.equalsIgnoreCase("f")) element = "fire";
|
else if (element.equalsIgnoreCase("f")) element = "fire";
|
||||||
else if (element.equalsIgnoreCase("w")) element = "water";
|
else if (element.equalsIgnoreCase("w")) element = "water";
|
||||||
else if (element.equalsIgnoreCase("c")) element = "chi";
|
else if (element.equalsIgnoreCase("c")) element = "chi";
|
||||||
Element target = Element.getElement(element);
|
Element targetElement = Element.getElement(element);
|
||||||
if (Arrays.asList(Element.getAllElements()).contains(target)) {
|
if (Arrays.asList(Element.getAllElements()).contains(targetElement)) {
|
||||||
if (!hasPermission(sender, element)) {
|
if (!hasPermission(sender, element)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
add(sender, (Player) sender, target);
|
add(sender, (Player) sender, targetElement);
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
sender.sendMessage(ChatColor.RED + invalidElement);
|
sender.sendMessage(ChatColor.RED + invalidElement);
|
||||||
|
@ -93,6 +93,11 @@ public class ChooseCommand extends PKCommand {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
String element = args.get(0).toLowerCase();
|
String element = args.get(0).toLowerCase();
|
||||||
|
if (element.equalsIgnoreCase("a")) element = "air";
|
||||||
|
else if (element.equalsIgnoreCase("e")) element = "earth";
|
||||||
|
else if (element.equalsIgnoreCase("f")) element = "fire";
|
||||||
|
else if (element.equalsIgnoreCase("w")) element = "water";
|
||||||
|
else if (element.equalsIgnoreCase("c")) element = "chi";
|
||||||
Element targetElement = Element.getElement(element);
|
Element targetElement = Element.getElement(element);
|
||||||
if (Arrays.asList(Element.getAllElements()).contains(targetElement)) {
|
if (Arrays.asList(Element.getAllElements()).contains(targetElement)) {
|
||||||
add(sender, target, targetElement);
|
add(sender, target, targetElement);
|
||||||
|
|
|
@ -199,7 +199,7 @@ public class ConfigManager {
|
||||||
config.addDefault("Commands.Bind.ElementToggledOff", "You have that ability's element toggled off currently.");
|
config.addDefault("Commands.Bind.ElementToggledOff", "You have that ability's element toggled off currently.");
|
||||||
config.addDefault("Commands.Bind.SuccessfullyBound", "Succesfully bound {ability} to slot {slot}.");
|
config.addDefault("Commands.Bind.SuccessfullyBound", "Succesfully bound {ability} to slot {slot}.");
|
||||||
config.addDefault("Commands.Bind.NoElement", "You are not a {element}!");
|
config.addDefault("Commands.Bind.NoElement", "You are not a {element}!");
|
||||||
config.addDefault("Commands.Bind.NoSubElement", "You don't have access to {subelement}!");
|
config.addDefault("Commands.Bind.NoSubElement", "You are not a {subelement}!");
|
||||||
|
|
||||||
config.addDefault("Commands.Add.Description", "This command will allow the user to add an element to the targeted <Player>, or themselves if the target is not specified. This command is typically reserved for server administrators.");
|
config.addDefault("Commands.Add.Description", "This command will allow the user to add an element to the targeted <Player>, or themselves if the target is not specified. This command is typically reserved for server administrators.");
|
||||||
config.addDefault("Commands.Add.SuccessfullyAddedCFW", "You are now also a {element}.");
|
config.addDefault("Commands.Add.SuccessfullyAddedCFW", "You are now also a {element}.");
|
||||||
|
@ -914,7 +914,7 @@ public class ConfigManager {
|
||||||
config.addDefault("Abilities.Earth.MetalClips.CrushCooldown", 2000);
|
config.addDefault("Abilities.Earth.MetalClips.CrushCooldown", 2000);
|
||||||
config.addDefault("Abilities.Earth.MetalClips.ShootCooldown", 1500);
|
config.addDefault("Abilities.Earth.MetalClips.ShootCooldown", 1500);
|
||||||
config.addDefault("Abilities.Earth.MetalClips.Duration", 10000);
|
config.addDefault("Abilities.Earth.MetalClips.Duration", 10000);
|
||||||
config.addDefault("Abilities.Earth.MetalClips.ThrowEnabled", false);
|
config.addDefault("Abilities.Earth.MetalClips.ThrowEnabled", true);
|
||||||
|
|
||||||
config.addDefault("Abilities.Earth.RaiseEarth.Enabled", true);
|
config.addDefault("Abilities.Earth.RaiseEarth.Enabled", true);
|
||||||
config.addDefault("Abilities.Earth.RaiseEarth.Speed", 10);
|
config.addDefault("Abilities.Earth.RaiseEarth.Speed", 10);
|
||||||
|
|
|
@ -209,7 +209,9 @@ public class WaterArmsSpear extends WaterAbility {
|
||||||
getIceBlocks().remove(block);
|
getIceBlocks().remove(block);
|
||||||
}
|
}
|
||||||
|
|
||||||
new TempBlock(block, Material.ICE, (byte) 0);
|
TempBlock tempBlock = new TempBlock(block, Material.AIR, (byte) 0);
|
||||||
|
tempBlock.setType(Material.ICE);
|
||||||
|
|
||||||
getIceBlocks().put(block, System.currentTimeMillis() + spearDuration + (long) (Math.random() * 500));
|
getIceBlocks().put(block, System.currentTimeMillis() + spearDuration + (long) (Math.random() * 500));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,14 +51,16 @@ public class WaterSpout extends WaterAbility {
|
||||||
this.useBlockSpiral = getConfig().getBoolean("Abilities.Water.WaterSpout.BlockSpiral");
|
this.useBlockSpiral = getConfig().getBoolean("Abilities.Water.WaterSpout.BlockSpiral");
|
||||||
this.height = getConfig().getDouble("Abilities.Water.WaterSpout.Height");
|
this.height = getConfig().getDouble("Abilities.Water.WaterSpout.Height");
|
||||||
this.interval = getConfig().getLong("Abilities.Water.WaterSpout.Interval");
|
this.interval = getConfig().getLong("Abilities.Water.WaterSpout.Interval");
|
||||||
|
|
||||||
hadFly = player.isFlying();
|
hadFly = player.isFlying();
|
||||||
canFly = player.getAllowFlight();
|
canFly = player.getAllowFlight();
|
||||||
|
maxHeight = getNightFactor(height);
|
||||||
WaterSpoutWave spoutWave = new WaterSpoutWave(player, WaterSpoutWave.AbilityType.CLICK);
|
WaterSpoutWave spoutWave = new WaterSpoutWave(player, WaterSpoutWave.AbilityType.CLICK);
|
||||||
if (spoutWave.isStarted() && !spoutWave.isRemoved()) {
|
if (spoutWave.isStarted() && !spoutWave.isRemoved()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Block topBlock = GeneralMethods.getTopBlock(player.getLocation(), 0, -50);
|
Block topBlock = GeneralMethods.getTopBlock(player.getLocation(), (int)-getNightFactor(height), (int)-getNightFactor(height));
|
||||||
if (topBlock == null) {
|
if (topBlock == null) {
|
||||||
topBlock = player.getLocation().getBlock();
|
topBlock = player.getLocation().getBlock();
|
||||||
}
|
}
|
||||||
|
@ -255,6 +257,13 @@ public class WaterSpout extends WaterAbility {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isIcebendable(blocki) || isSnow(blocki)) {
|
if (isIcebendable(blocki) || isSnow(blocki)) {
|
||||||
|
if (isIcebendable(blocki)) {
|
||||||
|
if (blocki.getType() == Material.PACKED_ICE && !canBendOnPackedIce) {
|
||||||
|
remove();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!TempBlock.isTempBlock(blocki)) {
|
if (!TempBlock.isTempBlock(blocki)) {
|
||||||
revertBaseBlock();
|
revertBaseBlock();
|
||||||
baseBlock = new TempBlock(blocki, Material.STATIONARY_WATER, (byte) 8);
|
baseBlock = new TempBlock(blocki, Material.STATIONARY_WATER, (byte) 8);
|
||||||
|
@ -266,6 +275,7 @@ public class WaterSpout extends WaterAbility {
|
||||||
}
|
}
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((blocki.getType() != Material.AIR && (!isPlant(blocki) || !bPlayer.canPlantbend()))) {
|
if ((blocki.getType() != Material.AIR && (!isPlant(blocki) || !bPlayer.canPlantbend()))) {
|
||||||
revertBaseBlock();
|
revertBaseBlock();
|
||||||
return -1;
|
return -1;
|
||||||
|
|
Loading…
Reference in a new issue