Reformatted code.
This commit is contained in:
4
.idea/modules/ChatAPI.main.iml
generated
4
.idea/modules/ChatAPI.main.iml
generated
@@ -13,9 +13,9 @@
|
|||||||
<orderEntry type="library" scope="PROVIDED" name="Gradle: com.google.guava:guava:21.0" level="project" />
|
<orderEntry type="library" scope="PROVIDED" name="Gradle: com.google.guava:guava:21.0" level="project" />
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Gradle: com.google.code.gson:gson:2.8.0" level="project" />
|
<orderEntry type="library" scope="PROVIDED" name="Gradle: com.google.code.gson:gson:2.8.0" level="project" />
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Gradle: org.yaml:snakeyaml:1.23" level="project" />
|
<orderEntry type="library" scope="PROVIDED" name="Gradle: org.yaml:snakeyaml:1.23" level="project" />
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Gradle: org.spigotmc:spigot-api:1.13.2-R0.1-SNAPSHOT" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Gradle: net.md-5:bungeecord-chat:1.13-SNAPSHOT" level="project" />
|
<orderEntry type="library" scope="PROVIDED" name="Gradle: net.md-5:bungeecord-chat:1.13-SNAPSHOT" level="project" />
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Gradle: junit:junit:4.10" level="project" />
|
<orderEntry type="library" scope="PROVIDED" name="Gradle: org.spigotmc:spigot-api:1.13.2-R0.1-SNAPSHOT" level="project" />
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Gradle: org.hamcrest:hamcrest-core:1.1" level="project" />
|
<orderEntry type="library" scope="PROVIDED" name="Gradle: org.hamcrest:hamcrest-core:1.1" level="project" />
|
||||||
|
<orderEntry type="library" scope="PROVIDED" name="Gradle: junit:junit:4.10" level="project" />
|
||||||
</component>
|
</component>
|
||||||
</module>
|
</module>
|
||||||
@@ -1,56 +1,49 @@
|
|||||||
package net.nemez.chatapi;
|
package net.nemez.chatapi;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import net.md_5.bungee.api.ChatMessageType;
|
||||||
import java.util.Random;
|
import net.md_5.bungee.api.chat.TextComponent;
|
||||||
|
import net.nemez.chatapi.click.CallbackCommand;
|
||||||
|
import net.nemez.chatapi.click.Message;
|
||||||
|
import net.nemez.chatapi.click.PlayerQuitListener;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandMap;
|
import org.bukkit.command.CommandMap;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
import net.md_5.bungee.api.chat.TextComponent;
|
import java.lang.reflect.Field;
|
||||||
import net.md_5.bungee.api.ChatMessageType;
|
import java.util.Random;
|
||||||
import net.nemez.chatapi.click.CallbackCommand;
|
|
||||||
import net.nemez.chatapi.click.Message;
|
public class ChatAPI {
|
||||||
import net.nemez.chatapi.click.PlayerQuitListener;
|
|
||||||
|
|
||||||
public class ChatAPI
|
|
||||||
{
|
|
||||||
|
|
||||||
/* message coloring permission */
|
/* message coloring permission */
|
||||||
public static final String PERMISSION_CHAT_COLOR = "chat.color";
|
public static final String PERMISSION_CHAT_COLOR = "chat.color";
|
||||||
/* message formatting permission */
|
/* message formatting permission */
|
||||||
public static final String PERMISSION_CHAT_FORMAT = "chat.format";
|
public static final String PERMISSION_CHAT_FORMAT = "chat.format";
|
||||||
/* message magic formatting permission */
|
/* message magic formatting permission */
|
||||||
public static final String PERMISSION_CHAT_MAGIC = "chat.magic";
|
public static final String PERMISSION_CHAT_MAGIC = "chat.magic";
|
||||||
/* permission to send messages in chat */
|
/* permission to send messages in chat */
|
||||||
public static final String PERMISSION_CHAT_USE = "chat.use";
|
public static final String PERMISSION_CHAT_USE = "chat.use";
|
||||||
/* message to send when the internal command is not ran correctly (ran by user) */
|
/* message to send when the internal command is not ran correctly (ran by user) */
|
||||||
public static final String MESSAGE_HELP_CLICK_CALLBACK = "&cThis is an internal command for ChatAPI and should not be ran by players manually.";
|
public static final String MESSAGE_HELP_CLICK_CALLBACK = "&cThis is an internal command for ChatAPI and should not be ran by players manually.";
|
||||||
/* message to send when the internal command is not ran by a player */
|
/* message to send when the internal command is not ran by a player */
|
||||||
public static final String MESSAGE_PLAYER_CLICK_CALLBACK = "&cThis command can only be run by a player";
|
public static final String MESSAGE_PLAYER_CLICK_CALLBACK = "&cThis command can only be run by a player";
|
||||||
/* the actual command name for use in click callbacks */
|
/* the actual command name for use in click callbacks */
|
||||||
private static String internalCommandName;
|
private static String internalCommandName;
|
||||||
|
|
||||||
/** Initializes ChatAPI and registers the required commands for clickable chat to function. */
|
/** Initializes ChatAPI and registers the required commands for clickable chat to function. */
|
||||||
public static void initialize(JavaPlugin plugin)
|
public static void initialize(JavaPlugin plugin) {
|
||||||
{
|
if (internalCommandName != null) {
|
||||||
if (internalCommandName != null)
|
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Random rand = new Random(System.currentTimeMillis());
|
Random rand = new Random(System.currentTimeMillis());
|
||||||
internalCommandName = "chatapi-exec-" + Integer.toHexString(rand.nextInt(0xEFFF) + 0x1000);
|
internalCommandName = "chatapi-exec-" + Integer.toHexString(rand.nextInt(0xEFFF) + 0x1000);
|
||||||
try
|
try {
|
||||||
{
|
|
||||||
final Field cmdMap = Bukkit.getServer().getClass().getDeclaredField("commandMap");
|
final Field cmdMap = Bukkit.getServer().getClass().getDeclaredField("commandMap");
|
||||||
cmdMap.setAccessible(true);
|
cmdMap.setAccessible(true);
|
||||||
CommandMap map = (CommandMap) cmdMap.get(Bukkit.getServer());
|
CommandMap map = (CommandMap) cmdMap.get(Bukkit.getServer());
|
||||||
map.register("net/nemez/chatapi", new CallbackCommand(internalCommandName));
|
map.register("net/nemez/chatapi", new CallbackCommand(internalCommandName));
|
||||||
}
|
} catch (Exception e) {
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
plugin.getLogger().severe("Failed to register internal command '" + internalCommandName + "'");
|
plugin.getLogger().severe("Failed to register internal command '" + internalCommandName + "'");
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
@@ -59,97 +52,100 @@ public class ChatAPI
|
|||||||
plugin.getServer().getPluginManager().registerEvents(new PlayerQuitListener(), plugin);
|
plugin.getServer().getPluginManager().registerEvents(new PlayerQuitListener(), plugin);
|
||||||
plugin.getLogger().info("ChatAPI initialized");
|
plugin.getLogger().info("ChatAPI initialized");
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Colorifies a message using &format codes. Respects permissions.
|
/**
|
||||||
*
|
* Sends a colorified message to the command sender.
|
||||||
* @param sender the command sender whose permissions to use. null if permissions are to be ignored.
|
*
|
||||||
|
* @param sender the command sender to whom to send the message.
|
||||||
|
* @param message the message to send.
|
||||||
|
*/
|
||||||
|
public static void send(CommandSender sender, String message) {
|
||||||
|
if (sender == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
sender.sendMessage(colorify(null, message));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Colorifies a message using &format codes. Respects permissions.
|
||||||
|
*
|
||||||
|
* @param sender the command sender whose permissions to use. null if permissions are to be ignored.
|
||||||
* @param message the message to color
|
* @param message the message to color
|
||||||
* @return colored message */
|
*
|
||||||
public static String colorify(CommandSender sender, String message)
|
* @return colored message
|
||||||
{
|
*/
|
||||||
if (sender == null || sender.hasPermission(PERMISSION_CHAT_COLOR))
|
public static String colorify(CommandSender sender, String message) {
|
||||||
{
|
if (sender == null || sender.hasPermission(PERMISSION_CHAT_COLOR)) {
|
||||||
message = message.replaceAll("&([0-9a-fA-FrR])", "§$1");
|
message = message.replaceAll("&([0-9a-fA-FrR])", "§$1");
|
||||||
}
|
}
|
||||||
if (sender == null || sender.hasPermission(PERMISSION_CHAT_FORMAT))
|
if (sender == null || sender.hasPermission(PERMISSION_CHAT_FORMAT)) {
|
||||||
{
|
|
||||||
message = message.replaceAll("&([l-oL-OrR])", "§$1");
|
message = message.replaceAll("&([l-oL-OrR])", "§$1");
|
||||||
}
|
}
|
||||||
if (sender == null || sender.hasPermission(PERMISSION_CHAT_MAGIC))
|
if (sender == null || sender.hasPermission(PERMISSION_CHAT_MAGIC)) {
|
||||||
{
|
|
||||||
message = message.replaceAll("&([kKrR])", "§$1");
|
message = message.replaceAll("&([kKrR])", "§$1");
|
||||||
}
|
}
|
||||||
message = message.replace("&§", "&");
|
message = message.replace("&§", "&");
|
||||||
return message;
|
return message;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Sends a colorified message to the command sender.
|
/**
|
||||||
*
|
* Sends a colorified action bar message to the command sender.
|
||||||
* @param sender the command sender to whom to send the message.
|
*
|
||||||
* @param message the message to send. */
|
* @param sender the command sender to whom to send the action bar message.
|
||||||
public static void send(CommandSender sender, String message)
|
* @param message the message to send.
|
||||||
{
|
*/
|
||||||
if (sender == null)
|
public static void sendActionBar(CommandSender sender, String message) {
|
||||||
{
|
if (sender instanceof Player) {
|
||||||
return;
|
|
||||||
}
|
|
||||||
sender.sendMessage(colorify(null, message));
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Sends a colorified action bar message to the command sender.
|
|
||||||
*
|
|
||||||
* @param sender the command sender to whom to send the action bar message.
|
|
||||||
* @param message the message to send. */
|
|
||||||
public static void sendActionBar(CommandSender sender, String message)
|
|
||||||
{
|
|
||||||
if (sender instanceof Player)
|
|
||||||
{
|
|
||||||
((Player) sender).spigot().sendMessage(ChatMessageType.ACTION_BAR, new TextComponent(colorify(null, message)));
|
((Player) sender).spigot().sendMessage(ChatMessageType.ACTION_BAR, new TextComponent(colorify(null, message)));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Checks if a command sender has the permission node required to send chat messages.
|
/**
|
||||||
*
|
* Checks if a command sender has the permission node required to send chat messages.
|
||||||
|
*
|
||||||
* @param sender the command sender to check.
|
* @param sender the command sender to check.
|
||||||
* @return true/false if sender can chat or is null. */
|
*
|
||||||
public static boolean canChat(CommandSender sender)
|
* @return true/false if sender can chat or is null.
|
||||||
{
|
*/
|
||||||
if (sender == null)
|
public static boolean canChat(CommandSender sender) {
|
||||||
{
|
if (sender == null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
return sender.hasPermission(PERMISSION_CHAT_USE);
|
return sender.hasPermission(PERMISSION_CHAT_USE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Creates a new message object that will be sent to the given command sender with regards to the second command sender's permissions.
|
/**
|
||||||
*
|
* Creates a new message object that will be sent to the given command sender.
|
||||||
|
*
|
||||||
* @param sender the command sender to whom to send the message.
|
* @param sender the command sender to whom to send the message.
|
||||||
* @param permissionSender the command sender whose permissions to use.
|
*
|
||||||
* @return message object */
|
* @return message object.
|
||||||
public static Message createMessage(CommandSender sender, CommandSender permissionSender)
|
*/
|
||||||
{
|
public static Message createMessage(CommandSender sender) {
|
||||||
return new Message(sender, permissionSender);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Creates a new message object that will be sent to the given command sender.
|
|
||||||
*
|
|
||||||
* @param sender the command sender to whom to send the message.
|
|
||||||
* @return message object. */
|
|
||||||
public static Message createMessage(CommandSender sender)
|
|
||||||
{
|
|
||||||
return createMessage(sender, null);
|
return createMessage(sender, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Gets the name of the internal ChatAPI command used for click callbacks.
|
/**
|
||||||
|
* Creates a new message object that will be sent to the given command sender with regards to the second command sender's permissions.
|
||||||
|
*
|
||||||
|
* @param sender the command sender to whom to send the message.
|
||||||
|
* @param permissionSender the command sender whose permissions to use.
|
||||||
|
*
|
||||||
|
* @return message object
|
||||||
|
*/
|
||||||
|
public static Message createMessage(CommandSender sender, CommandSender permissionSender) {
|
||||||
|
return new Message(sender, permissionSender);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the name of the internal ChatAPI command used for click callbacks.
|
||||||
* This function is used internally and you don't need to worry about it.
|
* This function is used internally and you don't need to worry about it.
|
||||||
*
|
*
|
||||||
* @return callback command name */
|
* @return callback command name
|
||||||
public static String getInternalCallbackCommand()
|
*/
|
||||||
{
|
public static String getInternalCallbackCommand() {
|
||||||
return internalCommandName;
|
return internalCommandName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,11 @@
|
|||||||
package net.nemez.chatapi.click;
|
package net.nemez.chatapi.click;
|
||||||
|
|
||||||
import java.util.UUID;
|
import net.nemez.chatapi.ChatAPI;
|
||||||
|
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
import net.nemez.chatapi.ChatAPI;
|
import java.util.UUID;
|
||||||
|
|
||||||
public class CallbackCommand extends Command {
|
public class CallbackCommand extends Command {
|
||||||
|
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
package net.nemez.chatapi.click;
|
package net.nemez.chatapi.click;
|
||||||
|
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.bukkit.command.CommandSender;
|
|
||||||
|
|
||||||
public class CallbackMap {
|
public class CallbackMap {
|
||||||
|
|
||||||
private static HashMap<String, HashMap<Integer, ClickCallback>> map = new HashMap<String, HashMap<Integer, ClickCallback>>();
|
private static HashMap<String, HashMap<Integer, ClickCallback>> map = new HashMap<String, HashMap<Integer, ClickCallback>>();
|
||||||
@@ -25,7 +25,7 @@ public class CallbackMap {
|
|||||||
playerMap.put(id, callback);
|
playerMap.put(id, callback);
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static void execute(CommandSender sender, UUID uuid, int id) {
|
protected static void execute(CommandSender sender, UUID uuid, int id) {
|
||||||
HashMap<Integer, ClickCallback> playerMap = map.get(uuid.toString());
|
HashMap<Integer, ClickCallback> playerMap = map.get(uuid.toString());
|
||||||
if (playerMap == null) {
|
if (playerMap == null) {
|
||||||
@@ -42,11 +42,11 @@ public class CallbackMap {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
t.start();
|
t.start();
|
||||||
}else{
|
} else {
|
||||||
cb.execute(sender);
|
cb.execute(sender);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static void discard(UUID uuid) {
|
protected static void discard(UUID uuid) {
|
||||||
map.remove(uuid.toString());
|
map.remove(uuid.toString());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,28 +1,25 @@
|
|||||||
package net.nemez.chatapi.click;
|
package net.nemez.chatapi.click;
|
||||||
|
|
||||||
import org.bukkit.command.CommandSender;
|
|
||||||
|
|
||||||
import net.nemez.chatapi.ChatAPI;
|
import net.nemez.chatapi.ChatAPI;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
|
||||||
public abstract class ClickCallback {
|
public abstract class ClickCallback {
|
||||||
|
|
||||||
private boolean repeatable, async;
|
private boolean repeatable, async;
|
||||||
private String expiredMessage;
|
private String expiredMessage;
|
||||||
private boolean expired;
|
private boolean expired;
|
||||||
|
|
||||||
public ClickCallback(boolean repeatable, boolean async, String expiredMessage) {
|
public ClickCallback(boolean repeatable, boolean async, String expiredMessage) {
|
||||||
this.repeatable = repeatable;
|
this.repeatable = repeatable;
|
||||||
this.async = async;
|
this.async = async;
|
||||||
this.expiredMessage = expiredMessage;
|
this.expiredMessage = expiredMessage;
|
||||||
this.expired = false;
|
this.expired = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract void run(CommandSender sender);
|
|
||||||
|
|
||||||
public final void execute(CommandSender sender) {
|
public final void execute(CommandSender sender) {
|
||||||
if (!expired) {
|
if (!expired) {
|
||||||
run(sender);
|
run(sender);
|
||||||
}else{
|
} else {
|
||||||
if (sender != null) {
|
if (sender != null) {
|
||||||
sender.sendMessage(ChatAPI.colorify(null, expiredMessage));
|
sender.sendMessage(ChatAPI.colorify(null, expiredMessage));
|
||||||
}
|
}
|
||||||
@@ -31,15 +28,17 @@ public abstract class ClickCallback {
|
|||||||
expired = true;
|
expired = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public abstract void run(CommandSender sender);
|
||||||
|
|
||||||
public boolean isRepeatable() {
|
public boolean isRepeatable() {
|
||||||
return repeatable;
|
return repeatable;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isAsynchronous() {
|
public boolean isAsynchronous() {
|
||||||
return async;
|
return async;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getExpiredMessage() {
|
public String getExpiredMessage() {
|
||||||
return expiredMessage;
|
return expiredMessage;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,115 +1,81 @@
|
|||||||
package net.nemez.chatapi.click;
|
package net.nemez.chatapi.click;
|
||||||
|
|
||||||
|
import net.md_5.bungee.api.ChatMessageType;
|
||||||
|
import net.md_5.bungee.api.chat.*;
|
||||||
|
import net.nemez.chatapi.ChatAPI;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
import net.md_5.bungee.api.ChatMessageType;
|
public class Message {
|
||||||
import net.md_5.bungee.api.chat.BaseComponent;
|
|
||||||
import net.md_5.bungee.api.chat.ClickEvent;
|
|
||||||
import net.md_5.bungee.api.chat.ComponentBuilder;
|
|
||||||
import net.md_5.bungee.api.chat.HoverEvent;
|
|
||||||
import net.md_5.bungee.api.chat.TextComponent;
|
|
||||||
import net.nemez.chatapi.ChatAPI;
|
|
||||||
|
|
||||||
public class Message
|
|
||||||
{
|
|
||||||
|
|
||||||
private CommandSender sender;
|
private CommandSender sender;
|
||||||
private CommandSender permission;
|
private CommandSender permission;
|
||||||
private TextComponent message;
|
private TextComponent message;
|
||||||
private String rawMessage;
|
private String rawMessage;
|
||||||
|
|
||||||
public Message(CommandSender sender, CommandSender permission)
|
public Message(CommandSender sender, CommandSender permission) {
|
||||||
{
|
|
||||||
this.sender = sender;
|
this.sender = sender;
|
||||||
this.permission = permission;
|
this.permission = permission;
|
||||||
message = new TextComponent("");
|
message = new TextComponent("");
|
||||||
rawMessage = "";
|
rawMessage = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
public Message appendText(String text)
|
public Message appendLink(String text, String url) {
|
||||||
{
|
|
||||||
text = ChatAPI.colorify(permission, text);
|
text = ChatAPI.colorify(permission, text);
|
||||||
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
||||||
for (BaseComponent component : components)
|
for (BaseComponent component : components) {
|
||||||
{
|
|
||||||
message.addExtra(component);
|
|
||||||
}
|
|
||||||
rawMessage += text;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Message appendLink(String text, String url)
|
|
||||||
{
|
|
||||||
text = ChatAPI.colorify(permission, text);
|
|
||||||
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
|
||||||
for (BaseComponent component : components)
|
|
||||||
{
|
|
||||||
component.setClickEvent(new ClickEvent(ClickEvent.Action.OPEN_URL, url));
|
component.setClickEvent(new ClickEvent(ClickEvent.Action.OPEN_URL, url));
|
||||||
message.addExtra(component);
|
message.addExtra(component);
|
||||||
}
|
}
|
||||||
rawMessage += text;
|
rawMessage += text;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Message appendSendChat(String text, String msg)
|
public Message appendSuggest(String text, String suggestion) {
|
||||||
{
|
|
||||||
text = ChatAPI.colorify(permission, text);
|
text = ChatAPI.colorify(permission, text);
|
||||||
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
||||||
for (BaseComponent component : components)
|
for (BaseComponent component : components) {
|
||||||
{
|
|
||||||
component.setClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, msg));
|
|
||||||
message.addExtra(component);
|
|
||||||
}
|
|
||||||
rawMessage += text;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Message appendSuggest(String text, String suggestion)
|
|
||||||
{
|
|
||||||
text = ChatAPI.colorify(permission, text);
|
|
||||||
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
|
||||||
for (BaseComponent component : components)
|
|
||||||
{
|
|
||||||
component.setClickEvent(new ClickEvent(ClickEvent.Action.SUGGEST_COMMAND, suggestion));
|
component.setClickEvent(new ClickEvent(ClickEvent.Action.SUGGEST_COMMAND, suggestion));
|
||||||
message.addExtra(component);
|
message.addExtra(component);
|
||||||
}
|
}
|
||||||
rawMessage += text;
|
rawMessage += text;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Message appendCallback(String text, ClickCallback callback)
|
public Message appendCallback(String text, ClickCallback callback) {
|
||||||
{
|
if (sender instanceof Player) {
|
||||||
if (sender instanceof Player)
|
|
||||||
{
|
|
||||||
int id = CallbackMap.register(((Player) sender).getUniqueId(), callback);
|
int id = CallbackMap.register(((Player) sender).getUniqueId(), callback);
|
||||||
return appendSendChat(text, "/" + ChatAPI.getInternalCallbackCommand() + " " + id);
|
return appendSendChat(text, "/" + ChatAPI.getInternalCallbackCommand() + " " + id);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
return appendText(text);
|
return appendText(text);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Message appendTextHover(String text, String hover)
|
public Message appendSendChat(String text, String msg) {
|
||||||
{
|
|
||||||
text = ChatAPI.colorify(permission, text);
|
text = ChatAPI.colorify(permission, text);
|
||||||
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
||||||
for (BaseComponent component : components)
|
for (BaseComponent component : components) {
|
||||||
{
|
component.setClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, msg));
|
||||||
addHoverText(component, hover);
|
|
||||||
message.addExtra(component);
|
message.addExtra(component);
|
||||||
}
|
}
|
||||||
rawMessage += text;
|
rawMessage += text;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Message appendLinkHover(String text, String url, String hover)
|
public Message appendText(String text) {
|
||||||
{
|
|
||||||
text = ChatAPI.colorify(permission, text);
|
text = ChatAPI.colorify(permission, text);
|
||||||
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
||||||
for (BaseComponent component : components)
|
for (BaseComponent component : components) {
|
||||||
{
|
message.addExtra(component);
|
||||||
|
}
|
||||||
|
rawMessage += text;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Message appendLinkHover(String text, String url, String hover) {
|
||||||
|
text = ChatAPI.colorify(permission, text);
|
||||||
|
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
||||||
|
for (BaseComponent component : components) {
|
||||||
component.setClickEvent(new ClickEvent(ClickEvent.Action.OPEN_URL, url));
|
component.setClickEvent(new ClickEvent(ClickEvent.Action.OPEN_URL, url));
|
||||||
addHoverText(component, hover);
|
addHoverText(component, hover);
|
||||||
message.addExtra(component);
|
message.addExtra(component);
|
||||||
@@ -117,27 +83,18 @@ public class Message
|
|||||||
rawMessage += text;
|
rawMessage += text;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Message appendSendChatHover(String text, String msg, String hover)
|
private void addHoverText(BaseComponent comp, String text) {
|
||||||
{
|
comp.setHoverEvent(new HoverEvent(
|
||||||
text = ChatAPI.colorify(permission, text);
|
HoverEvent.Action.SHOW_TEXT,
|
||||||
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
new ComponentBuilder(ChatAPI.colorify(permission, text)).create()
|
||||||
for (BaseComponent component : components)
|
));
|
||||||
{
|
|
||||||
component.setClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, msg));
|
|
||||||
addHoverText(component, hover);
|
|
||||||
message.addExtra(component);
|
|
||||||
}
|
|
||||||
rawMessage += text;
|
|
||||||
return this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Message appendSuggestHover(String text, String suggestion, String hover)
|
public Message appendSuggestHover(String text, String suggestion, String hover) {
|
||||||
{
|
|
||||||
text = ChatAPI.colorify(permission, text);
|
text = ChatAPI.colorify(permission, text);
|
||||||
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
||||||
for (BaseComponent component : components)
|
for (BaseComponent component : components) {
|
||||||
{
|
|
||||||
component.setClickEvent(new ClickEvent(ClickEvent.Action.SUGGEST_COMMAND, suggestion));
|
component.setClickEvent(new ClickEvent(ClickEvent.Action.SUGGEST_COMMAND, suggestion));
|
||||||
addHoverText(component, hover);
|
addHoverText(component, hover);
|
||||||
message.addExtra(component);
|
message.addExtra(component);
|
||||||
@@ -145,65 +102,68 @@ public class Message
|
|||||||
rawMessage += text;
|
rawMessage += text;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Message appendCallbackHover(String text, ClickCallback callback, String hover)
|
public Message appendCallbackHover(String text, ClickCallback callback, String hover) {
|
||||||
{
|
if (sender instanceof Player) {
|
||||||
if (sender instanceof Player)
|
|
||||||
{
|
|
||||||
int id = CallbackMap.register(((Player) sender).getUniqueId(), callback);
|
int id = CallbackMap.register(((Player) sender).getUniqueId(), callback);
|
||||||
return appendSendChatHover(text, "/" + ChatAPI.getInternalCallbackCommand() + " " + id, hover);
|
return appendSendChatHover(text, "/" + ChatAPI.getInternalCallbackCommand() + " " + id, hover);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
return appendTextHover(text, hover);
|
return appendTextHover(text, hover);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Message appendSendChatHover(String text, String msg, String hover) {
|
||||||
|
text = ChatAPI.colorify(permission, text);
|
||||||
|
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
||||||
|
for (BaseComponent component : components) {
|
||||||
|
component.setClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, msg));
|
||||||
|
addHoverText(component, hover);
|
||||||
|
message.addExtra(component);
|
||||||
|
}
|
||||||
|
rawMessage += text;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Message appendTextHover(String text, String hover) {
|
||||||
|
text = ChatAPI.colorify(permission, text);
|
||||||
|
BaseComponent[] components = TextComponent.fromLegacyText(text);
|
||||||
|
for (BaseComponent component : components) {
|
||||||
|
addHoverText(component, hover);
|
||||||
|
message.addExtra(component);
|
||||||
|
}
|
||||||
|
rawMessage += text;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public Message appendMessage(Message msg) {
|
public Message appendMessage(Message msg) {
|
||||||
message.addExtra(msg.message);
|
message.addExtra(msg.message);
|
||||||
rawMessage += msg.rawMessage;
|
rawMessage += msg.rawMessage;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void send()
|
public void send() {
|
||||||
{
|
if (sender == null || !ChatAPI.canChat(this.permission)) {
|
||||||
if (sender == null || !ChatAPI.canChat(this.permission))
|
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (sender instanceof Player)
|
if (sender instanceof Player) {
|
||||||
{
|
|
||||||
((Player) sender).spigot().sendMessage(message);
|
((Player) sender).spigot().sendMessage(message);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
sender.sendMessage(rawMessage);
|
sender.sendMessage(rawMessage);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void sendAsActionBar()
|
public void sendAsActionBar() {
|
||||||
{
|
if (sender == null) {
|
||||||
if (sender == null)
|
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (sender instanceof Player)
|
if (sender instanceof Player) {
|
||||||
{
|
|
||||||
((Player) sender).spigot().sendMessage(ChatMessageType.ACTION_BAR, message);
|
((Player) sender).spigot().sendMessage(ChatMessageType.ACTION_BAR, message);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
sender.sendMessage(rawMessage);
|
sender.sendMessage(rawMessage);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getRawMessage() {
|
public String getRawMessage() {
|
||||||
return rawMessage;
|
return rawMessage;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addHoverText(BaseComponent comp, String text)
|
|
||||||
{
|
|
||||||
comp.setHoverEvent(new HoverEvent(HoverEvent.Action.SHOW_TEXT,
|
|
||||||
new ComponentBuilder(ChatAPI.colorify(permission, text)).create()));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import org.bukkit.command.CommandSender;
|
|||||||
public class RunnableCallback extends ClickCallback {
|
public class RunnableCallback extends ClickCallback {
|
||||||
|
|
||||||
private Runnable runnable;
|
private Runnable runnable;
|
||||||
|
|
||||||
public RunnableCallback(Runnable runnable, boolean repeatable, boolean async, String expiredMessage) {
|
public RunnableCallback(Runnable runnable, boolean repeatable, boolean async, String expiredMessage) {
|
||||||
super(repeatable, async, expiredMessage);
|
super(repeatable, async, expiredMessage);
|
||||||
this.runnable = runnable;
|
this.runnable = runnable;
|
||||||
|
|||||||
Reference in New Issue
Block a user