2011-07-18 22:06:02 +02:00
|
|
|
package com.massivecraft.factions.struct;
|
2011-02-06 13:36:11 +01:00
|
|
|
|
2014-04-04 20:55:21 +02:00
|
|
|
import com.massivecraft.factions.Conf;
|
2019-06-29 03:49:46 +02:00
|
|
|
import com.massivecraft.factions.SaberFactions;
|
2019-07-17 17:08:55 +02:00
|
|
|
import com.massivecraft.factions.util.XMaterial;
|
2018-02-03 21:33:28 +01:00
|
|
|
import com.massivecraft.factions.zcore.fperms.Permissable;
|
2014-12-08 00:12:52 +01:00
|
|
|
import com.massivecraft.factions.zcore.util.TL;
|
2011-02-06 13:36:11 +01:00
|
|
|
import org.bukkit.ChatColor;
|
2018-03-02 22:53:01 +01:00
|
|
|
import org.bukkit.Material;
|
|
|
|
import org.bukkit.configuration.ConfigurationSection;
|
|
|
|
import org.bukkit.inventory.ItemStack;
|
|
|
|
import org.bukkit.inventory.meta.ItemMeta;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.List;
|
2011-07-18 22:06:02 +02:00
|
|
|
|
2011-02-06 13:36:11 +01:00
|
|
|
|
2018-02-03 21:33:28 +01:00
|
|
|
public enum Relation implements Permissable {
|
2019-03-03 04:51:21 +01:00
|
|
|
MEMBER(4, TL.RELATION_MEMBER_SINGULAR.toString()),
|
|
|
|
ALLY(3, TL.RELATION_ALLY_SINGULAR.toString()),
|
|
|
|
TRUCE(2, TL.RELATION_TRUCE_SINGULAR.toString()),
|
|
|
|
NEUTRAL(1, TL.RELATION_NEUTRAL_SINGULAR.toString()),
|
|
|
|
ENEMY(0, TL.RELATION_ENEMY_SINGULAR.toString());
|
|
|
|
|
|
|
|
public final int value;
|
|
|
|
public final String nicename;
|
|
|
|
|
|
|
|
Relation(final int value, final String nicename) {
|
|
|
|
this.value = value;
|
|
|
|
this.nicename = nicename;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static Relation fromString(String s) {
|
|
|
|
// Because Java 6 doesn't allow String switches :(
|
|
|
|
if (s.equalsIgnoreCase(MEMBER.nicename)) {
|
|
|
|
return MEMBER;
|
|
|
|
} else if (s.equalsIgnoreCase(ALLY.nicename)) {
|
|
|
|
return ALLY;
|
|
|
|
} else if (s.equalsIgnoreCase(TRUCE.nicename)) {
|
|
|
|
return TRUCE;
|
|
|
|
} else if (s.equalsIgnoreCase(ENEMY.nicename)) {
|
|
|
|
return ENEMY;
|
|
|
|
} else {
|
|
|
|
return NEUTRAL; // If they somehow mess things up, go back to default behavior.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String toString() {
|
|
|
|
return this.nicename;
|
|
|
|
}
|
|
|
|
|
|
|
|
public String getTranslation() {
|
|
|
|
try {
|
|
|
|
return TL.valueOf("RELATION_" + name() + "_SINGULAR").toString();
|
|
|
|
} catch (IllegalArgumentException e) {
|
|
|
|
return toString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public String getPluralTranslation() {
|
|
|
|
for (TL t : TL.values()) {
|
|
|
|
if (t.name().equalsIgnoreCase("RELATION_" + name() + "_PLURAL")) {
|
|
|
|
return t.toString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return toString();
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isMember() {
|
|
|
|
return this == MEMBER;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isAlly() {
|
|
|
|
return this == ALLY;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isTruce() {
|
|
|
|
return this == TRUCE;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isNeutral() {
|
|
|
|
return this == NEUTRAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isEnemy() {
|
|
|
|
return this == ENEMY;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isAtLeast(Relation relation) {
|
|
|
|
return this.value >= relation.value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isAtMost(Relation relation) {
|
|
|
|
return this.value <= relation.value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public ChatColor getColor() {
|
|
|
|
|
|
|
|
switch (this) {
|
|
|
|
case MEMBER:
|
|
|
|
return Conf.colorMember;
|
|
|
|
case ALLY:
|
|
|
|
return Conf.colorAlly;
|
|
|
|
case NEUTRAL:
|
|
|
|
return Conf.colorNeutral;
|
|
|
|
case TRUCE:
|
|
|
|
return Conf.colorTruce;
|
|
|
|
default:
|
|
|
|
return Conf.colorEnemy;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// return appropriate Conf setting for DenyBuild based on this relation and their online status
|
|
|
|
public boolean confDenyBuild(boolean online) {
|
|
|
|
if (isMember()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (online) {
|
|
|
|
if (isEnemy()) {
|
|
|
|
return Conf.territoryEnemyDenyBuild;
|
|
|
|
} else if (isAlly()) {
|
|
|
|
return Conf.territoryAllyDenyBuild;
|
|
|
|
} else if (isTruce()) {
|
|
|
|
return Conf.territoryTruceDenyBuild;
|
|
|
|
} else {
|
|
|
|
return Conf.territoryDenyBuild;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (isEnemy()) {
|
|
|
|
return Conf.territoryEnemyDenyBuildWhenOffline;
|
|
|
|
} else if (isAlly()) {
|
|
|
|
return Conf.territoryAllyDenyBuildWhenOffline;
|
|
|
|
} else if (isTruce()) {
|
|
|
|
return Conf.territoryTruceDenyBuildWhenOffline;
|
|
|
|
} else {
|
|
|
|
return Conf.territoryDenyBuildWhenOffline;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// return appropriate Conf setting for PainBuild based on this relation and their online status
|
|
|
|
public boolean confPainBuild(boolean online) {
|
|
|
|
if (isMember()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (online) {
|
|
|
|
if (isEnemy()) {
|
|
|
|
return Conf.territoryEnemyPainBuild;
|
|
|
|
} else if (isAlly()) {
|
|
|
|
return Conf.territoryAllyPainBuild;
|
|
|
|
} else if (isTruce()) {
|
|
|
|
return Conf.territoryTrucePainBuild;
|
|
|
|
} else {
|
|
|
|
return Conf.territoryPainBuild;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (isEnemy()) {
|
|
|
|
return Conf.territoryEnemyPainBuildWhenOffline;
|
|
|
|
} else if (isAlly()) {
|
|
|
|
return Conf.territoryAllyPainBuildWhenOffline;
|
|
|
|
} else if (isTruce()) {
|
|
|
|
return Conf.territoryTrucePainBuildWhenOffline;
|
|
|
|
} else {
|
|
|
|
return Conf.territoryPainBuildWhenOffline;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// return appropriate Conf setting for DenyUseage based on this relation
|
|
|
|
public boolean confDenyUseage() {
|
|
|
|
if (isMember()) {
|
|
|
|
return false;
|
|
|
|
} else if (isEnemy()) {
|
|
|
|
return Conf.territoryEnemyDenyUseage;
|
|
|
|
} else if (isAlly()) {
|
|
|
|
return Conf.territoryAllyDenyUseage;
|
|
|
|
} else if (isTruce()) {
|
|
|
|
return Conf.territoryTruceDenyUseage;
|
|
|
|
} else {
|
|
|
|
return Conf.territoryDenyUseage;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getRelationCost() {
|
|
|
|
if (isEnemy()) {
|
|
|
|
return Conf.econCostEnemy;
|
|
|
|
} else if (isAlly()) {
|
|
|
|
return Conf.econCostAlly;
|
|
|
|
} else if (isTruce()) {
|
|
|
|
return Conf.econCostTruce;
|
|
|
|
} else {
|
|
|
|
return Conf.econCostNeutral;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Utility method to build items for F Perm GUI
|
|
|
|
@Override
|
|
|
|
public ItemStack buildItem() {
|
2019-06-29 03:49:46 +02:00
|
|
|
final ConfigurationSection RELATION_CONFIG = SaberFactions.plugin.getConfig().getConfigurationSection("fperm-gui.relation");
|
2019-03-03 04:51:21 +01:00
|
|
|
|
|
|
|
String displayName = replacePlaceholders(RELATION_CONFIG.getString("placeholder-item.name", ""));
|
|
|
|
List<String> lore = new ArrayList<>();
|
|
|
|
|
2019-07-17 17:08:55 +02:00
|
|
|
Material material = XMaterial.matchXMaterial(RELATION_CONFIG.getString("materials." + name().toLowerCase())).parseMaterial();
|
2019-03-03 04:51:21 +01:00
|
|
|
if (material == null) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
ItemStack item = new ItemStack(material);
|
|
|
|
ItemMeta itemMeta = item.getItemMeta();
|
|
|
|
|
|
|
|
for (String loreLine : RELATION_CONFIG.getStringList("placeholder-item.lore")) {
|
|
|
|
lore.add(replacePlaceholders(loreLine));
|
|
|
|
}
|
|
|
|
|
|
|
|
itemMeta.setDisplayName(displayName);
|
|
|
|
itemMeta.setLore(lore);
|
|
|
|
item.setItemMeta(itemMeta);
|
|
|
|
|
|
|
|
return item;
|
|
|
|
}
|
|
|
|
|
|
|
|
public String replacePlaceholders(String string) {
|
|
|
|
string = ChatColor.translateAlternateColorCodes('&', string);
|
|
|
|
|
|
|
|
String permissableName = nicename.substring(0, 1).toUpperCase() + nicename.substring(1);
|
|
|
|
|
|
|
|
string = string.replace("{relation-color}", getColor().toString());
|
|
|
|
string = string.replace("{relation}", permissableName);
|
|
|
|
|
|
|
|
return string;
|
|
|
|
}
|
2011-02-06 13:36:11 +01:00
|
|
|
}
|