2023-11-12 19:02:11 +01:00
|
|
|
package net.knarcraft.blacksmith.config.scrapper;
|
|
|
|
|
2023-11-14 16:04:48 +01:00
|
|
|
import net.citizensnpcs.api.util.DataKey;
|
|
|
|
import net.knarcraft.blacksmith.config.SettingValueType;
|
2023-11-16 01:17:27 +01:00
|
|
|
import net.knarcraft.blacksmith.config.Settings;
|
2023-11-14 16:04:48 +01:00
|
|
|
import net.knarcraft.blacksmith.config.TraitSettings;
|
|
|
|
import net.knarcraft.blacksmith.util.ConfigHelper;
|
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.Map;
|
|
|
|
|
2023-11-16 01:17:27 +01:00
|
|
|
public class ScrapperNPCSettings implements TraitSettings, Settings<ScrapperSetting> {
|
|
|
|
private final Map<ScrapperSetting, Object> currentValues = new HashMap<>();
|
2023-11-14 16:04:48 +01:00
|
|
|
private final GlobalScrapperSettings globalScrapperSettings;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Instantiates a new scrapper NPC settings object
|
|
|
|
*
|
|
|
|
* @param globalScrapperSettings <p>The global settings object to get default values from</p>
|
|
|
|
*/
|
|
|
|
public ScrapperNPCSettings(GlobalScrapperSettings globalScrapperSettings) {
|
|
|
|
this.globalScrapperSettings = globalScrapperSettings;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads variables from the given data key
|
|
|
|
*
|
|
|
|
* @param key <p>The data key to load variables from</p>
|
|
|
|
*/
|
|
|
|
public void loadVariables(DataKey key) {
|
2023-11-16 01:17:27 +01:00
|
|
|
for (ScrapperSetting setting : ScrapperSetting.values()) {
|
2023-11-14 16:04:48 +01:00
|
|
|
if (key.keyExists(setting.getChildPath())) {
|
|
|
|
currentValues.put(setting, key.getRaw(setting.getChildPath()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves variables to the given data key
|
|
|
|
*
|
|
|
|
* @param key <p>The data key to save variables to</p>
|
|
|
|
*/
|
|
|
|
public void saveVariables(DataKey key) {
|
2023-11-16 01:17:27 +01:00
|
|
|
for (ScrapperSetting setting : ScrapperSetting.values()) {
|
2023-11-14 16:04:48 +01:00
|
|
|
key.setRaw(setting.getChildPath(), currentValues.get(setting));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Changes one setting to the given value
|
|
|
|
*
|
|
|
|
* @param setting <p>The setting to change</p>
|
|
|
|
* @param newValue <p>The new value of the setting</p>
|
|
|
|
*/
|
2023-11-16 01:17:27 +01:00
|
|
|
public void changeValue(ScrapperSetting setting, Object newValue) {
|
2023-11-14 16:04:48 +01:00
|
|
|
if (setting.getValueType() == SettingValueType.STRING_LIST ||
|
|
|
|
setting.getValueType() == SettingValueType.REFORGE_ABLE_ITEMS) {
|
|
|
|
//Workaround to make sure it's treated as the correct type
|
|
|
|
currentValues.put(setting, newValue == null ? null : ConfigHelper.asStringList(newValue));
|
|
|
|
} else {
|
|
|
|
currentValues.put(setting, newValue);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the raw current value of a setting
|
|
|
|
*
|
|
|
|
* @param setting <p>The setting to get the value of</p>
|
|
|
|
* @return <p>The current value of the setting</p>
|
|
|
|
*/
|
2023-11-16 01:17:27 +01:00
|
|
|
public Object getRawValue(ScrapperSetting setting) {
|
2023-11-14 16:04:48 +01:00
|
|
|
return currentValues.get(setting);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getBusyWithPlayerMessage() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asString(ScrapperSetting.BUSY_WITH_PLAYER_MESSAGE);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getBusyWorkingMessage() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asString(ScrapperSetting.BUSY_WITH_SALVAGE_MESSAGE);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getStartWorkingMessage() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asString(ScrapperSetting.START_SALVAGE_MESSAGE);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the message to display when a blacksmith has successfully repaired an item
|
|
|
|
*
|
|
|
|
* @return <p>The reforge success message</p>
|
|
|
|
*/
|
|
|
|
public String getSuccessMessage() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asString(ScrapperSetting.SUCCESS_SALVAGE_MESSAGE);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getCoolDownUnexpiredMessage() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asString(ScrapperSetting.COOL_DOWN_UNEXPIRED_MESSAGE);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The message displayed if a player presents a different item after seeing the price to salvage an item
|
|
|
|
*/
|
|
|
|
public String getItemChangedMessage() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asString(ScrapperSetting.ITEM_UNEXPECTEDLY_CHANGED_MESSAGE);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the minimum delay used to wait for a salvaging to finish.
|
|
|
|
*
|
|
|
|
* @return <p>The minimum salvage delay</p>
|
|
|
|
*/
|
|
|
|
public int getMinSalvageDelay() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asInt(ScrapperSetting.MIN_SALVAGE_DELAY);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the maximum delay used to wait for a salvaging to finish
|
|
|
|
*
|
|
|
|
* @return <p>The maximum salvage delay</p>
|
|
|
|
*/
|
|
|
|
public int getMaxSalvageDelay() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asInt(ScrapperSetting.MAX_SALVAGE_DELAY);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the cool-down between each salvaging
|
|
|
|
*
|
|
|
|
* @return <p>The salvage cool-down</p>
|
|
|
|
*/
|
|
|
|
public int getSalvageCoolDown() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asInt(ScrapperSetting.SALVAGE_COOL_DOWN);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets whether an item should be dropped on the ground instead of being given to the player
|
|
|
|
*
|
|
|
|
* @return <p>Whether to drop reforged items on the ground</p>
|
|
|
|
*/
|
|
|
|
public boolean getDropItem() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asBoolean(ScrapperSetting.DROP_ITEM);
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean getDisableCoolDown() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asInt(ScrapperSetting.SALVAGE_COOL_DOWN) <= 0;
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets whether to disable the delay between starting reforging and the reforging finishing
|
|
|
|
*
|
|
|
|
* @return <p>Whether to disable the reforge delay</p>
|
|
|
|
*/
|
|
|
|
public boolean getDisableDelay() {
|
2023-11-16 01:17:27 +01:00
|
|
|
return asInt(ScrapperSetting.MAX_SALVAGE_DELAY) <= 0;
|
2023-11-14 16:04:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the given value as an integer
|
|
|
|
*
|
|
|
|
* <p>This will throw an exception if used for a non-integer setting</p>
|
|
|
|
*
|
|
|
|
* @param setting <p>The setting to get the value of</p>
|
|
|
|
* @return <p>The value of the given setting as an integer</p>
|
|
|
|
*/
|
2023-11-16 01:17:27 +01:00
|
|
|
private int asInt(ScrapperSetting setting) {
|
2023-11-14 16:04:48 +01:00
|
|
|
return ConfigHelper.asInt(getValue(setting));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the string value of the given setting
|
|
|
|
*
|
|
|
|
* @param setting <p>The setting to get the value of</p>
|
|
|
|
* @return <p>The value of the given setting as a string</p>
|
|
|
|
*/
|
2023-11-16 01:17:27 +01:00
|
|
|
private String asString(ScrapperSetting setting) {
|
2023-11-14 16:04:48 +01:00
|
|
|
return getValue(setting).toString();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the boolean value of the given setting
|
|
|
|
*
|
|
|
|
* @param setting <p>The setting to get the value of</p>
|
|
|
|
* @return <p>The value of the given setting as a boolean</p>
|
|
|
|
*/
|
2023-11-16 01:17:27 +01:00
|
|
|
private boolean asBoolean(ScrapperSetting setting) {
|
2023-11-14 16:04:48 +01:00
|
|
|
return ConfigHelper.asBoolean(getValue(setting));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the value of a setting, using the default if not set
|
|
|
|
*
|
|
|
|
* @param setting <p>The setting to get the value of</p>
|
|
|
|
* @return <p>The current value</p>
|
|
|
|
*/
|
2023-11-16 01:17:27 +01:00
|
|
|
private Object getValue(ScrapperSetting setting) {
|
2023-11-14 16:04:48 +01:00
|
|
|
Object value = currentValues.get(setting);
|
|
|
|
//If not set, use the default value from the config.yml file
|
|
|
|
if (value == null) {
|
2023-11-16 01:17:27 +01:00
|
|
|
Map<ScrapperSetting, Object> defaultNPCSettings = globalScrapperSettings.getDefaultNPCSettings();
|
2023-11-14 16:04:48 +01:00
|
|
|
if (defaultNPCSettings.containsKey(setting)) {
|
|
|
|
value = defaultNPCSettings.get(setting);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//If not set in config.yml, use the default value from the enum
|
|
|
|
if (value == null) {
|
|
|
|
value = setting.getDefaultValue();
|
|
|
|
}
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
|
2023-11-12 19:02:11 +01:00
|
|
|
}
|