1
0
mirror of https://github.com/Zrips/Jobs.git synced 2025-01-16 05:01:34 +01:00

PyroFishing fix

This commit is contained in:
Zrips 2024-06-10 12:18:35 +03:00
parent eed592e5bd
commit 1708d3b0a2
4 changed files with 45 additions and 45 deletions

View File

@ -1306,7 +1306,7 @@ public final class Jobs extends JavaPlugin {
}
//need to update bp
if (block != null) {
if (block != null && !Jobs.getGCManager().useBlockProtectionBlockTracker) {
BlockProtection bp = getBpManager().getBp(block.getLocation());
if (bp != null)
bp.setPaid(true);

View File

@ -384,6 +384,8 @@ public class LanguageManager {
c.get("command.info.output.mmkill.none", "%jobname% does not get money for killing Mythic monsters.");
c.get("command.info.output.fish.info", "&eFish");
c.get("command.info.output.fish.none", "%jobname% does not get money from fishing.");
c.get("command.info.output.pyrofishingpro.info", "&eFish");
c.get("command.info.output.pyrofishingpro.none", "%jobname% does not get money from fishing.");
c.get("command.info.output.craft.info", "&eCraft");
c.get("command.info.output.craft.none", "%jobname% does not get money from crafting.");
c.get("command.info.output.smelt.info", "&eSmelt");

View File

@ -1,13 +1,16 @@
package com.gamingmesh.jobs.hooks.pyroFishingPro;
import com.gamingmesh.jobs.Jobs;
import me.arsmagica.API.PyroFishCatchEvent;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import com.gamingmesh.jobs.Jobs;
import me.arsmagica.API.PyroFishCatchEvent;
public class PyroFishingProManager implements Listener {
public static String lastFish;
private static String lastFish;
private static long time = 0;
private final Jobs jobs;
public PyroFishingProManager() {
@ -18,5 +21,12 @@ public class PyroFishingProManager implements Listener {
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
public void onPyroFishCatch(PyroFishCatchEvent event) {
lastFish = event.getTier();
time = System.currentTimeMillis();
}
public static String getFish() {
if (time + 60 < System.currentTimeMillis())
return null;
return lastFish;
}
}

View File

@ -124,6 +124,7 @@ import net.Zrips.CMILib.Items.CMIItemStack;
import net.Zrips.CMILib.Items.CMIMC;
import net.Zrips.CMILib.Items.CMIMaterial;
import net.Zrips.CMILib.Locale.LC;
import net.Zrips.CMILib.Logs.CMIDebug;
import net.Zrips.CMILib.Messages.CMIMessages;
import net.Zrips.CMILib.Version.Version;
import net.Zrips.CMILib.Version.Schedulers.CMIScheduler;
@ -518,6 +519,7 @@ public final class JobsPaymentListener implements Listener {
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
public void onPlayerFish(PlayerFishEvent event) {
Player player = event.getPlayer();
if (!Jobs.getGCManager().canPerformActionInWorld(player.getWorld()))
@ -549,10 +551,8 @@ public final class JobsPaymentListener implements Listener {
}
}
if (JobsHook.PyroFishingPro.isEnabled()) {
if (PyroFishingProManager.lastFish != null) {
Jobs.action(Jobs.getPlayerManager().getJobsPlayer(player), new PyroFishingProInfo(PyroFishingProManager.lastFish, ActionType.PYROFISHINGPRO));
}
if (JobsHook.PyroFishingPro.isEnabled() && PyroFishingProManager.getFish() != null) {
Jobs.action(Jobs.getPlayerManager().getJobsPlayer(player), new PyroFishingProInfo(PyroFishingProManager.getFish(), ActionType.PYROFISHINGPRO), event.getCaught());
return;
}
@ -1111,26 +1111,7 @@ public final class JobsPaymentListener implements Listener {
if (block == null || !Jobs.getGCManager().canPerformActionInWorld(block.getWorld()))
return;
final Block finalBlock = block;
plugin.getBlockOwnerShip(CMIMaterial.get(finalBlock)).ifPresent(os -> {
if (os.disable(finalBlock) && Jobs.getGCManager().informOnPaymentDisable) {
UUID uuid = plugin.getBlockOwnerShip(CMIMaterial.get(finalBlock)).get().getOwnerByLocation(finalBlock.getLocation());
Player player = Bukkit.getPlayer(uuid);
if (player == null || !player.isOnline())
return;
JobsPlayer jPlayer = Jobs.getPlayerManager().getJobsPlayer(player);
String lc = CMILocation.toString(finalBlock.getLocation());
if (!jPlayer.hasBlockOwnerShipInform(lc)) {
CMIMessages.sendMessage(player, Jobs.getLanguage().getMessage("general.error.blockDisabled",
"[type]", CMIMaterial.get(finalBlock).getName(),
"[location]", LC.Location_Full.getLocale(finalBlock.getLocation())));
jPlayer.addBlockOwnerShipInform(lc);
}
}
});
processItemMove(block);
}
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
@ -1143,25 +1124,32 @@ public final class JobsPaymentListener implements Listener {
final BrewingStand stand = (BrewingStand) event.getDestination().getHolder();
if (Jobs.getGCManager().canPerformActionInWorld(stand.getWorld()))
plugin.getBlockOwnerShip(CMIMaterial.get(stand.getBlock())).ifPresent(os -> {
if (os.disable(stand.getBlock()) && Jobs.getGCManager().informOnPaymentDisable) {
if (!Jobs.getGCManager().canPerformActionInWorld(stand.getWorld()))
return;
UUID uuid = plugin.getBlockOwnerShip(CMIMaterial.get(stand.getBlock())).get().getOwnerByLocation(stand.getLocation());
processItemMove(stand.getBlock());
}
private void processItemMove(Block block) {
plugin.getBlockOwnerShip(CMIMaterial.get(block)).ifPresent(os -> {
if (!os.disable(block) || !Jobs.getGCManager().informOnPaymentDisable)
return;
UUID uuid = plugin.getBlockOwnerShip(CMIMaterial.get(block)).get().getOwnerByLocation(block.getLocation());
Player player = Bukkit.getPlayer(uuid);
if (player == null || !player.isOnline())
return;
JobsPlayer jPlayer = Jobs.getPlayerManager().getJobsPlayer(player);
String lc = CMILocation.toString(stand.getLocation());
String lc = CMILocation.toString(block.getLocation());
if (jPlayer.hasBlockOwnerShipInform(lc))
return;
if (!jPlayer.hasBlockOwnerShipInform(lc)) {
CMIMessages.sendMessage(player, Jobs.getLanguage().getMessage("general.error.blockDisabled",
"[type]", CMIMaterial.get(stand.getBlock()).getName(),
"[location]", LC.Location_Full.getLocale(stand.getLocation())));
"[type]", CMIMaterial.get(block).getName(),
"[location]", LC.Location_Full.getLocale(block.getLocation())));
jPlayer.addBlockOwnerShipInform(lc);
}
}
});
}