summaryrefslogtreecommitdiff
path: root/net/nemez/chatapi/click/Message.java
diff options
context:
space:
mode:
Diffstat (limited to 'net/nemez/chatapi/click/Message.java')
-rw-r--r--net/nemez/chatapi/click/Message.java131
1 files changed, 131 insertions, 0 deletions
diff --git a/net/nemez/chatapi/click/Message.java b/net/nemez/chatapi/click/Message.java
new file mode 100644
index 0000000..0abb578
--- /dev/null
+++ b/net/nemez/chatapi/click/Message.java
@@ -0,0 +1,131 @@
+package net.nemez.chatapi.click;
+
+import org.bukkit.command.CommandSender;
+import org.bukkit.entity.Player;
+
+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 permission;
+ private TextComponent message;
+ private String rawMessage;
+
+ public Message(CommandSender sender, CommandSender permission) {
+ this.sender = sender;
+ this.permission = permission;
+ message = new TextComponent("");
+ rawMessage = "";
+ }
+
+ public Message appendText(String text) {
+ text = ChatAPI.colorify(permission, text);
+ message.addExtra(text);
+ rawMessage += text;
+ return this;
+ }
+
+ public Message appendLink(String text, String url) {
+ text = ChatAPI.colorify(permission, text);
+ TextComponent component = new TextComponent(text);
+ component.setClickEvent(new ClickEvent(ClickEvent.Action.OPEN_URL, url));
+ message.addExtra(component);
+ rawMessage += text;
+ return this;
+ }
+
+ public Message appendSendChat(String text, String msg) {
+ text = ChatAPI.colorify(permission, text);
+ TextComponent component = new TextComponent(text);
+ 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);
+ TextComponent component = new TextComponent(text);
+ component.setClickEvent(new ClickEvent(ClickEvent.Action.SUGGEST_COMMAND, suggestion));
+ message.addExtra(component);
+ rawMessage += text;
+ return this;
+ }
+
+ public Message appendCallback(String text, ClickCallback callback) {
+ if (sender instanceof Player) {
+ int id = CallbackMap.register(((Player) sender).getUniqueId(), callback);
+ return appendSendChat(text, "/" + ChatAPI.getInternalCallbackCommand() + " " + id);
+ }else{
+ return appendText(text);
+ }
+ }
+
+ public Message appendTextHover(String text, String hover) {
+ text = ChatAPI.colorify(permission, text);
+ TextComponent component = new TextComponent(text);
+ addHoverText(component, hover);
+ message.addExtra(component);
+ rawMessage += text;
+ return this;
+ }
+
+ public Message appendLinkHover(String text, String url, String hover) {
+ text = ChatAPI.colorify(permission, text);
+ TextComponent component = new TextComponent(text);
+ component.setClickEvent(new ClickEvent(ClickEvent.Action.OPEN_URL, url));
+ addHoverText(component, hover);
+ message.addExtra(component);
+ rawMessage += text;
+ return this;
+ }
+
+ public Message appendSendChatHover(String text, String msg, String hover) {
+ text = ChatAPI.colorify(permission, text);
+ TextComponent component = new TextComponent(text);
+ 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) {
+ text = ChatAPI.colorify(permission, text);
+ TextComponent component = new TextComponent(text);
+ component.setClickEvent(new ClickEvent(ClickEvent.Action.SUGGEST_COMMAND, suggestion));
+ addHoverText(component, hover);
+ message.addExtra(component);
+ rawMessage += text;
+ return this;
+ }
+
+ public Message appendCallbackHover(String text, ClickCallback callback, String hover) {
+ if (sender instanceof Player) {
+ int id = CallbackMap.register(((Player) sender).getUniqueId(), callback);
+ return appendSendChatHover(text, "/" + ChatAPI.getInternalCallbackCommand() + " " + id, hover);
+ }else{
+ return appendTextHover(text, hover);
+ }
+ }
+
+ public void send() {
+ if (sender == null || !ChatAPI.canChat(this.permission)) {
+ return;
+ }
+ if (sender instanceof Player) {
+ ((Player)sender).spigot().sendMessage(message);
+ }else{
+ sender.sendMessage(rawMessage);
+ }
+ }
+
+ private void addHoverText(TextComponent comp, String text) {
+ comp.setHoverEvent(new HoverEvent(HoverEvent.Action.SHOW_TEXT, new ComponentBuilder(ChatAPI.colorify(permission, text)).create()));
+ }
+}