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

Updating payment limit handling

This commit is contained in:
Zrips 2020-10-30 14:29:36 +02:00
parent 07e97f50ae
commit 3d48656311
5 changed files with 97 additions and 40 deletions

View File

@ -1276,11 +1276,17 @@ public class Jobs extends JavaPlugin {
if (jobsExpGainEvent.isCancelled())
return;
boolean limited = true;
for (CurrencyType one : CurrencyType.values()) {
if (!jPlayer.isUnderLimit(one, payment.get(one)))
return;
if (jPlayer.isUnderLimit(one, payment.get(one))) {
limited = false;
break;
}
}
if (limited)
return;
economy.pay(jPlayer, payment.getPayment());
JobProgression prog = jPlayer.getJobProgression(job);

View File

@ -52,14 +52,10 @@ public class limit implements Cmd {
if (!Jobs.getGCManager().getLimit(type).isEnabled())
continue;
PaymentData limit = JPlayer.getPaymentLimit();
if (limit == null) {
int lefttime1 = Jobs.getGCManager().getLimit(type).getTimeLimit() * 1000;
sender.sendMessage(Jobs.getLanguage().getMessage("command.limit.output." + type.getName().toLowerCase() + "time", "%time%", TimeManage.to24hourShort((long) lefttime1)));
sender.sendMessage(Jobs.getLanguage().getMessage("command.limit.output." + type.getName().toLowerCase() + "Limit",
"%current%", "0.0",
"%total%", JPlayer.getLimit(type)));
continue;
}
if (limit.getLeftTime(type) <= 0)
limit.resetLimits(type);
if (limit.getLeftTime(type) > 0) {
sender.sendMessage(Jobs.getLanguage().getMessage("command.limit.output." + type.getName().toLowerCase() + "time", "%time%", TimeManage.to24hourShort(limit.getLeftTime(type))));
sender.sendMessage(Jobs.getLanguage().getMessage("command.limit.output." + type.getName().toLowerCase() + "Limit",

View File

@ -166,7 +166,7 @@ public class JobsPlayer {
if (data.isReachedLimit(type, value == null ? 0 : value)) {
String name = type.getName().toLowerCase();
if (player.isOnline() && !data.isInformed() && !data.isReseted()) {
if (player.isOnline() && !data.isInformed() && !data.isReseted(type)) {
if (Jobs.getGCManager().useMaxPaymentCurve) {
player.sendMessage(Jobs.getLanguage().getMessage("command.limit.output.reached" + name + "limit"));
player.sendMessage(Jobs.getLanguage().getMessage("command.limit.output.reached" + name + "limit2"));
@ -179,8 +179,8 @@ public class JobsPlayer {
}
if (data.isAnnounceTime(limit.getAnnouncementDelay()) && player.isOnline())
ActionBarManager.send(player, Jobs.getLanguage().getMessage("command.limit.output." + name + "time", "%time%", TimeManage.to24hourShort(data.getLeftTime(type))));
if (data.isReseted())
data.setReseted(false);
if (data.isReseted(type))
data.setReseted(type, false);
return false;
}
data.addAmount(type, amount);

View File

@ -0,0 +1,57 @@
package com.gamingmesh.jobs.economy;
import com.gamingmesh.jobs.container.CurrencyType;
public class LimitsData {
private CurrencyType type = null;
private double amount = 0D;
private long paymentsTime = 0L;
private boolean reseted = false;
public LimitsData(CurrencyType type, long paymentsTime) {
this(type, paymentsTime, 0D);
}
public LimitsData(CurrencyType type, long paymentsTime, double payment) {
this.type = type;
this.paymentsTime = paymentsTime;
this.amount = payment;
}
public boolean isReseted() {
return reseted;
}
public void setReseted(boolean reseted) {
this.reseted = reseted;
}
public CurrencyType getType() {
return type;
}
public void setType(CurrencyType type) {
this.type = type;
}
public double getAmount() {
return this.amount;
}
public double addAmount(double amount) {
return this.amount += amount;
}
public void setAmount(double payment) {
this.amount = payment;
}
public long getPaymentsTime() {
return paymentsTime;
}
public void setPaymentsTime(long paymentsTime) {
this.paymentsTime = paymentsTime;
}
}

View File

@ -9,30 +9,24 @@ public class PaymentData {
private Long lastAnnouced = 0L;
private final HashMap<CurrencyType, Double> payments = new HashMap<>();
private final HashMap<CurrencyType, Long> paymentsTimes = new HashMap<>();
private final HashMap<CurrencyType, LimitsData> payments = new HashMap<>();
private boolean informed = false;
private boolean reseted = false;
public PaymentData(Long time, Double Payment, Double Points, Double Exp, Long lastAnnouced, boolean Informed) {
paymentsTimes.put(CurrencyType.EXP, time);
paymentsTimes.put(CurrencyType.MONEY, time);
paymentsTimes.put(CurrencyType.POINTS, time);
payments.put(CurrencyType.EXP, Exp);
payments.put(CurrencyType.MONEY, Payment);
payments.put(CurrencyType.POINTS, Points);
payments.put(CurrencyType.EXP, new LimitsData(CurrencyType.EXP, time, Exp));
payments.put(CurrencyType.MONEY, new LimitsData(CurrencyType.MONEY, time, Payment));
payments.put(CurrencyType.POINTS, new LimitsData(CurrencyType.POINTS, time, Points));
this.lastAnnouced = lastAnnouced;
this.informed = Informed;
}
public PaymentData(CurrencyType type, Double amount) {
paymentsTimes.put(type, System.currentTimeMillis());
payments.put(type, amount);
this.lastAnnouced = 0L;
this.informed = false;
for (CurrencyType one : CurrencyType.values()) {
if (one != type)
payments.put(one, new LimitsData(one, System.currentTimeMillis(), 0D));
}
payments.put(type, new LimitsData(type, System.currentTimeMillis(), amount));
}
public PaymentData() {
@ -40,19 +34,19 @@ public class PaymentData {
}
public Long getTime(CurrencyType type) {
return paymentsTimes.get(type);
return payments.get(type).getPaymentsTime();
}
public void setReseted(boolean reseted) {
this.reseted = reseted;
public void setReseted(CurrencyType type, boolean reseted) {
payments.get(type).setReseted(reseted);
}
public boolean isReseted() {
return reseted;
public boolean isReseted(CurrencyType type) {
return payments.get(type).isReseted();
}
public Double getAmount(CurrencyType type) {
return !payments.containsKey(type) ? 0D : (int) (payments.get(type) * 100) / 100D;
return !payments.containsKey(type) ? 0D : (int) (payments.get(type).getAmount() * 100) / 100D;
}
public Double getAmountBylimit(CurrencyType type, int limit) {
@ -80,12 +74,11 @@ public class PaymentData {
}
public void addNewAmount(CurrencyType type, Double Payment, Long time) {
paymentsTimes.put(type, time == null ? System.currentTimeMillis() : time);
payments.put(type, Payment);
payments.put(type, new LimitsData(type, time == null ? System.currentTimeMillis() : time, Payment));
}
public void addAmount(CurrencyType type, Double Payment) {
payments.put(type, payments.get(type) + Payment);
payments.get(type).addAmount(Payment);
}
public long getLeftTime(CurrencyType type) {
@ -96,13 +89,13 @@ public class PaymentData {
}
public boolean isOverLimit(CurrencyType type, int limit) {
if (payments.get(type) < limit)
if (payments.get(type).getAmount() < limit)
return false;
return true;
}
public double percentOverLimit(CurrencyType type, int limit) {
return ((payments.get(type) / limit) - 1) * 100;
return ((payments.get(type).getAmount() / limit) - 1) * 100;
}
public boolean isOverTimeLimit(CurrencyType type) {
@ -117,8 +110,13 @@ public class PaymentData {
public void resetLimits() {
for (CurrencyType type : CurrencyType.values()) {
addNewAmount(type, 0D);
setReseted(type, true);
}
reseted = true;
}
public void resetLimits(CurrencyType type) {
addNewAmount(type, 0D);
setReseted(type, true);
}
public boolean isReachedLimit(CurrencyType type, int money) {