1
0
mirror of https://github.com/Zrips/Jobs.git synced 2025-01-20 07:01:22 +01:00

Inform about blockprotection only if payment is possible for it.

This commit is contained in:
Zrips 2017-09-01 13:49:27 +03:00
parent 02a3c4cd65
commit 05e9184b9c
4 changed files with 78 additions and 48 deletions

View File

@ -95,7 +95,6 @@ import com.gamingmesh.jobs.stuff.RawMessage;
import com.gamingmesh.jobs.stuff.TabComplete; import com.gamingmesh.jobs.stuff.TabComplete;
import com.gamingmesh.jobs.stuff.VersionChecker; import com.gamingmesh.jobs.stuff.VersionChecker;
import com.gamingmesh.jobs.stuff.CMIScoreboardManager; import com.gamingmesh.jobs.stuff.CMIScoreboardManager;
import com.gamingmesh.jobs.stuff.Debug;
import com.gamingmesh.jobs.tasks.BufferedPaymentThread; import com.gamingmesh.jobs.tasks.BufferedPaymentThread;
import com.gamingmesh.jobs.tasks.DatabaseSaveThread; import com.gamingmesh.jobs.tasks.DatabaseSaveThread;
@ -879,7 +878,7 @@ public class Jobs extends JavaPlugin {
int numjobs = progression.size(); int numjobs = progression.size();
// no job // no job
if (!isBpOk(jPlayer.getPlayer(), info, block, true)) if (!isBpOk(jPlayer, info, block, true))
return; return;
if (numjobs == 0) { if (numjobs == 0) {
@ -894,62 +893,62 @@ public class Jobs extends JavaPlugin {
Double income = jobinfo.getIncome(1, numjobs); Double income = jobinfo.getIncome(1, numjobs);
Double pointAmount = jobinfo.getPoints(1, numjobs); Double pointAmount = jobinfo.getPoints(1, numjobs);
if (income != 0D || pointAmount != 0D) { if (income == 0D && pointAmount == 0D)
return;
Boost boost = pManager.getFinalBonus(jPlayer, Jobs.getNoneJob()); Boost boost = pManager.getFinalBonus(jPlayer, Jobs.getNoneJob());
// Calculate income // Calculate income
if (income != 0D) { if (income != 0D) {
income = income + (income * boost.getFinal(CurrencyType.MONEY)); income = income + (income * boost.getFinal(CurrencyType.MONEY));
if (GconfigManager.useMinimumOveralPayment && income > 0) { if (GconfigManager.useMinimumOveralPayment && income > 0) {
double maxLimit = income * GconfigManager.MinimumOveralPaymentLimit; double maxLimit = income * GconfigManager.MinimumOveralPaymentLimit;
if (income < maxLimit) { if (income < maxLimit) {
income = maxLimit; income = maxLimit;
}
} }
} }
}
// Calculate points // Calculate points
if (pointAmount != 0D) { if (pointAmount != 0D) {
pointAmount = pointAmount + (pointAmount * boost.getFinal(CurrencyType.POINTS)); pointAmount = pointAmount + (pointAmount * boost.getFinal(CurrencyType.POINTS));
if (GconfigManager.useMinimumOveralPoints && pointAmount > 0) { if (GconfigManager.useMinimumOveralPoints && pointAmount > 0) {
double maxLimit = pointAmount * GconfigManager.MinimumOveralPaymentLimit; double maxLimit = pointAmount * GconfigManager.MinimumOveralPaymentLimit;
if (pointAmount < maxLimit) { if (pointAmount < maxLimit) {
pointAmount = maxLimit; pointAmount = maxLimit;
}
} }
} }
}
if (!jPlayer.isUnderLimit(CurrencyType.MONEY, income)) { if (!jPlayer.isUnderLimit(CurrencyType.MONEY, income)) {
income = 0D; income = 0D;
if (GconfigManager.getLimit(CurrencyType.MONEY).getStopWith().contains(CurrencyType.POINTS)) if (GconfigManager.getLimit(CurrencyType.MONEY).getStopWith().contains(CurrencyType.POINTS))
pointAmount = 0D;
}
if (!jPlayer.isUnderLimit(CurrencyType.POINTS, pointAmount)) {
pointAmount = 0D; pointAmount = 0D;
if (GconfigManager.getLimit(CurrencyType.POINTS).getStopWith().contains(CurrencyType.MONEY)) }
income = 0D;
}
if (income == 0D && pointAmount == 0D) if (!jPlayer.isUnderLimit(CurrencyType.POINTS, pointAmount)) {
return; pointAmount = 0D;
if (GconfigManager.getLimit(CurrencyType.POINTS).getStopWith().contains(CurrencyType.MONEY))
income = 0D;
}
if (info.getType() == ActionType.BREAK && block != null) if (income == 0D && pointAmount == 0D)
Jobs.getBpManager().remove(block); return;
if (pointAmount != 0D) if (info.getType() == ActionType.BREAK && block != null)
jPlayer.setSaved(false); Jobs.getBpManager().remove(block);
Jobs.getEconomy().pay(jPlayer, income, pointAmount, 0.0); if (pointAmount != 0D)
jPlayer.setSaved(false);
if (GconfigManager.LoggingUse) { Jobs.getEconomy().pay(jPlayer, income, pointAmount, 0.0);
HashMap<CurrencyType, Double> amounts = new HashMap<CurrencyType, Double>();
amounts.put(CurrencyType.MONEY, income); if (GconfigManager.LoggingUse) {
loging.recordToLog(jPlayer, info, amounts); HashMap<CurrencyType, Double> amounts = new HashMap<CurrencyType, Double>();
} amounts.put(CurrencyType.MONEY, income);
loging.recordToLog(jPlayer, info, amounts);
} }
} else { } else {
@ -1101,7 +1100,7 @@ public class Jobs extends JavaPlugin {
} }
} }
private static boolean isBpOk(Player player, ActionInfo info, Block block, boolean inform) { private static boolean isBpOk(JobsPlayer player, ActionInfo info, Block block, boolean inform) {
if (block == null || !getGCManager().useBlockProtection) if (block == null || !getGCManager().useBlockProtection)
return true; return true;
@ -1126,7 +1125,8 @@ public class Jobs extends JavaPlugin {
if (time > System.currentTimeMillis() || bp.isPaid() && bp.getAction() != DBAction.DELETE) { if (time > System.currentTimeMillis() || bp.isPaid() && bp.getAction() != DBAction.DELETE) {
int sec = Math.round((time - System.currentTimeMillis()) / 1000L); int sec = Math.round((time - System.currentTimeMillis()) / 1000L);
if (inform) { if (inform) {
getActionBar().send(player, getLanguage().getMessage("message.blocktimer", "[time]", sec)); if (player.canGetPaid(info))
getActionBar().send(player.getPlayer(), getLanguage().getMessage("message.blocktimer", "[time]", sec));
} }
return false; return false;
} }
@ -1151,7 +1151,8 @@ public class Jobs extends JavaPlugin {
if (time > System.currentTimeMillis() || bp.isPaid() && bp.getAction() != DBAction.DELETE) { if (time > System.currentTimeMillis() || bp.isPaid() && bp.getAction() != DBAction.DELETE) {
int sec = Math.round((time - System.currentTimeMillis()) / 1000L); int sec = Math.round((time - System.currentTimeMillis()) / 1000L);
if (inform) { if (inform) {
getActionBar().send(player, getLanguage().getMessage("message.blocktimer", "[time]", sec)); if (player.canGetPaid(info))
getActionBar().send(player.getPlayer(), getLanguage().getMessage("message.blocktimer", "[time]", sec));
} }
getBpManager().add(block, cd); getBpManager().add(block, cd);
return false; return false;

View File

@ -12,7 +12,6 @@ import com.gamingmesh.jobs.commands.JobCommand;
import com.gamingmesh.jobs.container.JobProgression; import com.gamingmesh.jobs.container.JobProgression;
import com.gamingmesh.jobs.container.JobsPlayer; import com.gamingmesh.jobs.container.JobsPlayer;
import com.gamingmesh.jobs.stuff.RawMessage; import com.gamingmesh.jobs.stuff.RawMessage;
import com.gamingmesh.jobs.stuff.TimeManage;
public class archive implements Cmd { public class archive implements Cmd {

View File

@ -766,4 +766,36 @@ public class JobsPlayer {
public void setLastPermissionUpdate(Long lastPermissionUpdate) { public void setLastPermissionUpdate(Long lastPermissionUpdate) {
this.lastPermissionUpdate = lastPermissionUpdate; this.lastPermissionUpdate = lastPermissionUpdate;
} }
public boolean canGetPaid(ActionInfo info) {
List<JobProgression> progression = getJobProgression();
int numjobs = progression.size();
if (numjobs == 0) {
if (Jobs.getNoneJob() == null)
return false;
JobInfo jobinfo = Jobs.getNoneJob().getJobInfo(info, 1);
if (jobinfo == null)
return false;
Double income = jobinfo.getIncome(1, numjobs);
Double points = jobinfo.getPoints(1, numjobs);
if (income == 0D && points == 0D)
return false;
}
for (JobProgression prog : progression) {
int level = prog.getLevel();
JobInfo jobinfo = prog.getJob().getJobInfo(info, level);
if (jobinfo == null)
continue;
Double income = jobinfo.getIncome(level, numjobs);
Double pointAmount = jobinfo.getPoints(level, numjobs);
Double expAmount = jobinfo.getExperience(level, numjobs);
if (income != 0D || pointAmount != 0D || expAmount != 0D)
return true;
}
return false;
}
} }

View File

@ -514,8 +514,6 @@ public class JobsPaymentListener implements Listener {
} }
} }
Debug.D("Crafted item " + resultStack.getType().name() + " " + resultStack.getAmount());
// If we need to pay only by each craft action we will skip calculation how much was crafted // If we need to pay only by each craft action we will skip calculation how much was crafted
if (!Jobs.getGCManager().PayForEachCraft) { if (!Jobs.getGCManager().PayForEachCraft) {
if (resultStack.hasItemMeta() && resultStack.getItemMeta().hasDisplayName()) if (resultStack.hasItemMeta() && resultStack.getItemMeta().hasDisplayName())