mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2025-01-26 01:51:30 +01:00
Added icon for addons
It will be used to represent the addon in menus Default is PAPER
This commit is contained in:
parent
81cca6adc8
commit
2c371f4091
@ -1,5 +1,18 @@
|
||||
package world.bentobox.bentobox.api.addons;
|
||||
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.Material;
|
||||
import org.bukkit.configuration.ConfigurationSection;
|
||||
import org.bukkit.configuration.file.YamlConfiguration;
|
||||
import org.bukkit.permissions.PermissionDefault;
|
||||
import org.bukkit.plugin.InvalidDescriptionException;
|
||||
import org.bukkit.util.permissions.DefaultPermissions;
|
||||
import org.eclipse.jdt.annotation.NonNull;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
import world.bentobox.bentobox.api.addons.exceptions.InvalidAddonFormatException;
|
||||
import world.bentobox.bentobox.api.addons.exceptions.InvalidAddonInheritException;
|
||||
import world.bentobox.bentobox.managers.AddonsManager;
|
||||
|
||||
import java.io.File;
|
||||
import java.lang.reflect.InvocationTargetException;
|
||||
import java.net.MalformedURLException;
|
||||
@ -9,19 +22,6 @@ import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.configuration.ConfigurationSection;
|
||||
import org.bukkit.configuration.file.YamlConfiguration;
|
||||
import org.bukkit.permissions.PermissionDefault;
|
||||
import org.bukkit.plugin.InvalidDescriptionException;
|
||||
import org.bukkit.util.permissions.DefaultPermissions;
|
||||
import org.eclipse.jdt.annotation.NonNull;
|
||||
import org.eclipse.jdt.annotation.Nullable;
|
||||
|
||||
import world.bentobox.bentobox.api.addons.exceptions.InvalidAddonFormatException;
|
||||
import world.bentobox.bentobox.api.addons.exceptions.InvalidAddonInheritException;
|
||||
import world.bentobox.bentobox.managers.AddonsManager;
|
||||
|
||||
/**
|
||||
* Loads addons and sets up permissions
|
||||
* @author Tastybento, ComminQ
|
||||
@ -96,6 +96,9 @@ public class AddonClassLoader extends URLClassLoader {
|
||||
if (data.getString("softdepend") != null) {
|
||||
builder.softDependencies(Arrays.asList(data.getString("softdepend").split("\\s*,\\s*")));
|
||||
}
|
||||
if (data.getString("icon") != null) {
|
||||
builder.icon(Material.getMaterial(data.getString("icon", "PAPER")));
|
||||
}
|
||||
|
||||
return builder.build();
|
||||
}
|
||||
|
@ -1,11 +1,12 @@
|
||||
package world.bentobox.bentobox.api.addons;
|
||||
|
||||
import org.bukkit.Material;
|
||||
import org.eclipse.jdt.annotation.NonNull;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
import org.eclipse.jdt.annotation.NonNull;
|
||||
|
||||
/**
|
||||
* @author tastybento, Poslovitch
|
||||
*/
|
||||
@ -25,10 +26,15 @@ public final class AddonDescription {
|
||||
private final boolean metrics;
|
||||
/**
|
||||
* Name of the GitHub repository of the addon or an empty String.
|
||||
* It follows an {@code Owner/Name} format.
|
||||
* It follows a {@code Owner/Name} format.
|
||||
* @since 1.3.0
|
||||
*/
|
||||
private final @NonNull String repository;
|
||||
/**
|
||||
* Icon representing the addon in various menus.
|
||||
* @since 1.5.0
|
||||
*/
|
||||
private final @NonNull Material icon;
|
||||
|
||||
private AddonDescription(@NonNull Builder builder) {
|
||||
this.main = builder.main;
|
||||
@ -40,6 +46,7 @@ public final class AddonDescription {
|
||||
this.softDependencies = builder.softDependencies;
|
||||
this.metrics = builder.metrics;
|
||||
this.repository = builder.repository;
|
||||
this.icon = builder.icon;
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@ -103,6 +110,16 @@ public final class AddonDescription {
|
||||
return repository;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the material representing the addon as an icon.
|
||||
* @return the material representing the addon as an icon.
|
||||
* @since 1.5.0
|
||||
*/
|
||||
@NonNull
|
||||
public Material getIcon() {
|
||||
return icon;
|
||||
}
|
||||
|
||||
public static class Builder {
|
||||
private @NonNull String main;
|
||||
private @NonNull String name;
|
||||
@ -113,6 +130,8 @@ public final class AddonDescription {
|
||||
private @NonNull List<String> softDependencies = new ArrayList<>();
|
||||
private boolean metrics = true;
|
||||
private @NonNull String repository = "";
|
||||
private @NonNull Material icon = Material.PAPER;
|
||||
|
||||
/**
|
||||
* @since 1.1
|
||||
*/
|
||||
@ -160,11 +179,23 @@ public final class AddonDescription {
|
||||
* Must follow the {@code Owner/Name} format.
|
||||
* @since 1.3.0
|
||||
*/
|
||||
@NonNull
|
||||
public Builder repository(@NonNull String repository) {
|
||||
this.repository = repository;
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the icon representing the addon.
|
||||
* @param icon Material to set as the icon. Default is {@link Material#PAPER}.
|
||||
* @since 1.5.0
|
||||
*/
|
||||
@NonNull
|
||||
public Builder icon(@NonNull Material icon) {
|
||||
this.icon = icon;
|
||||
return this;
|
||||
}
|
||||
|
||||
@NonNull
|
||||
public AddonDescription build() {
|
||||
return new AddonDescription(this);
|
||||
|
Loading…
Reference in New Issue
Block a user