mirror of
https://github.com/EssentialsX/Essentials.git
synced 2024-12-23 09:37:50 +01:00
Add methods to set/remove custom aliases
This commit is contained in:
parent
8e1f3617fd
commit
6e5d378324
@ -13,7 +13,7 @@ import org.bukkit.inventory.ItemStack;
|
|||||||
public class CustomItemResolver implements IItemDb.ItemResolver, IConf {
|
public class CustomItemResolver implements IItemDb.ItemResolver, IConf {
|
||||||
private final EssentialsConf config;
|
private final EssentialsConf config;
|
||||||
private final Essentials ess;
|
private final Essentials ess;
|
||||||
private final HashMap<String, String> customItems = new HashMap<>();
|
private final HashMap<String, String> map = new HashMap<>();
|
||||||
|
|
||||||
public CustomItemResolver(Essentials ess) {
|
public CustomItemResolver(Essentials ess) {
|
||||||
config = new EssentialsConf(new File(ess.getDataFolder(), "custom_items.yml"));
|
config = new EssentialsConf(new File(ess.getDataFolder(), "custom_items.yml"));
|
||||||
@ -23,7 +23,7 @@ public class CustomItemResolver implements IItemDb.ItemResolver, IConf {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ItemStack apply(String item) {
|
public ItemStack apply(String item) {
|
||||||
if (customItems.containsKey(item)) {
|
if (map.containsKey(item)) {
|
||||||
try {
|
try {
|
||||||
return ess.getItemDb().get(item);
|
return ess.getItemDb().get(item);
|
||||||
} catch (Exception ignored) {}
|
} catch (Exception ignored) {}
|
||||||
@ -34,12 +34,12 @@ public class CustomItemResolver implements IItemDb.ItemResolver, IConf {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Collection<String> getNames() {
|
public Collection<String> getNames() {
|
||||||
return customItems.keySet();
|
return map.keySet();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void reloadConfig() {
|
public void reloadConfig() {
|
||||||
customItems.clear();
|
map.clear();
|
||||||
config.load();
|
config.load();
|
||||||
|
|
||||||
ConfigurationSection section = config.getConfigurationSection("aliases");
|
ConfigurationSection section = config.getConfigurationSection("aliases");
|
||||||
@ -53,11 +53,31 @@ public class CustomItemResolver implements IItemDb.ItemResolver, IConf {
|
|||||||
String target = section.getString(alias);
|
String target = section.getString(alias);
|
||||||
|
|
||||||
if (target != null && !section.contains(target) && existsInItemDb(target)) {
|
if (target != null && !section.contains(target) && existsInItemDb(target)) {
|
||||||
customItems.put(alias, target);
|
map.put(alias, target);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setAlias(String alias, String target) {
|
||||||
|
if (map.containsKey(alias) && map.get(alias).equalsIgnoreCase(target)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
map.put(alias, target);
|
||||||
|
save();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeAlias(String alias) {
|
||||||
|
if (map.remove(alias) != null) {
|
||||||
|
save();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void save() {
|
||||||
|
config.setProperty("aliases", map);
|
||||||
|
config.save();
|
||||||
|
}
|
||||||
|
|
||||||
private boolean existsInItemDb(String item) {
|
private boolean existsInItemDb(String item) {
|
||||||
try {
|
try {
|
||||||
ess.getItemDb().get(item);
|
ess.getItemDb().get(item);
|
||||||
|
Loading…
Reference in New Issue
Block a user