From a6af091e8906eb960b9dcc4991aacdd9e8ba07ba Mon Sep 17 00:00:00 2001
From: Risto Lahtela <24460436+Rsl1122@users.noreply.github.com>
Date: Thu, 13 Aug 2020 14:14:56 +0300
Subject: [PATCH] Implemented Sponge MessageBuilder
---
.../plan/commands/use/BukkitPartBuilder.java | 6 +-
.../plan/command/use/BungeePartBuilder.java | 6 +-
.../plan/commands/use/SpongeCMDSender.java | 2 +-
.../commands/use/SpongeMessageBuilder.java | 100 ++++++++++++++++++
4 files changed, 111 insertions(+), 3 deletions(-)
create mode 100644 Plan/sponge/src/main/java/com/djrapitops/plan/commands/use/SpongeMessageBuilder.java
diff --git a/Plan/bukkit/src/main/java/com/djrapitops/plan/commands/use/BukkitPartBuilder.java b/Plan/bukkit/src/main/java/com/djrapitops/plan/commands/use/BukkitPartBuilder.java
index 59f27018e..783c6dd92 100644
--- a/Plan/bukkit/src/main/java/com/djrapitops/plan/commands/use/BukkitPartBuilder.java
+++ b/Plan/bukkit/src/main/java/com/djrapitops/plan/commands/use/BukkitPartBuilder.java
@@ -86,12 +86,16 @@ class BukkitPartBuilder implements MessageBuilder {
}
@Override
- public MessageBuilder indent(int i) {
+ public MessageBuilder indent(int amount) {
+ for (int i = 0; i < amount; i++) {
+ part.append(" ");
+ }
return this;
}
@Override
public MessageBuilder tabular(CharSequence charSequence) {
+ sender.getFormatter().table(charSequence.toString(), ":");
return this;
}
diff --git a/Plan/bungeecord/src/main/java/com/djrapitops/plan/command/use/BungeePartBuilder.java b/Plan/bungeecord/src/main/java/com/djrapitops/plan/command/use/BungeePartBuilder.java
index 674a32e76..05994ed49 100644
--- a/Plan/bungeecord/src/main/java/com/djrapitops/plan/command/use/BungeePartBuilder.java
+++ b/Plan/bungeecord/src/main/java/com/djrapitops/plan/command/use/BungeePartBuilder.java
@@ -87,12 +87,16 @@ class BungeePartBuilder implements MessageBuilder {
}
@Override
- public MessageBuilder indent(int i) {
+ public MessageBuilder indent(int amount) {
+ for (int i = 0; i < amount; i++) {
+ part.append(" ");
+ }
return this;
}
@Override
public MessageBuilder tabular(CharSequence charSequence) {
+ sender.getFormatter().table(charSequence.toString(), ":");
return this;
}
diff --git a/Plan/sponge/src/main/java/com/djrapitops/plan/commands/use/SpongeCMDSender.java b/Plan/sponge/src/main/java/com/djrapitops/plan/commands/use/SpongeCMDSender.java
index df9dd338e..8c030fac6 100644
--- a/Plan/sponge/src/main/java/com/djrapitops/plan/commands/use/SpongeCMDSender.java
+++ b/Plan/sponge/src/main/java/com/djrapitops/plan/commands/use/SpongeCMDSender.java
@@ -32,7 +32,7 @@ public class SpongeCMDSender implements CMDSender {
@Override
public MessageBuilder buildMessage() {
- return null;/*TODO*/
+ return new SpongeMessageBuilder(this);
}
@Override
diff --git a/Plan/sponge/src/main/java/com/djrapitops/plan/commands/use/SpongeMessageBuilder.java b/Plan/sponge/src/main/java/com/djrapitops/plan/commands/use/SpongeMessageBuilder.java
new file mode 100644
index 000000000..497e84273
--- /dev/null
+++ b/Plan/sponge/src/main/java/com/djrapitops/plan/commands/use/SpongeMessageBuilder.java
@@ -0,0 +1,100 @@
+/*
+ * This file is part of Player Analytics (Plan).
+ *
+ * Plan is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License v3 as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Plan is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with Plan. If not, see .
+ */
+package com.djrapitops.plan.commands.use;
+
+import org.spongepowered.api.text.Text;
+import org.spongepowered.api.text.action.TextActions;
+
+import java.net.MalformedURLException;
+import java.net.URL;
+import java.util.Collection;
+
+public class SpongeMessageBuilder implements MessageBuilder {
+
+ private final SpongeCMDSender sender;
+ private final Text.Builder builder;
+
+ public SpongeMessageBuilder(SpongeCMDSender sender) {
+ this.sender = sender;
+ builder = Text.builder();
+ }
+
+ @Override
+ public MessageBuilder addPart(String s) {
+ builder.append(Text.of(s));
+ return this;
+ }
+
+ @Override
+ public MessageBuilder newLine() {
+ builder.append(Text.of('\n'));
+ return this;
+ }
+
+ @Override
+ public MessageBuilder link(String url) {
+ try {
+ builder.onClick(TextActions.openUrl(new URL(url)));
+ } catch (MalformedURLException e) {
+ throw new IllegalArgumentException("'" + url + "' is not a valid URL");
+ }
+ return this;
+ }
+
+ @Override
+ public MessageBuilder command(String command) {
+ builder.onClick(TextActions.runCommand(command.charAt(0) == '/' ? command.substring(1) : command));
+ return this;
+ }
+
+ @Override
+ public MessageBuilder hover(String message) {
+ builder.onHover(TextActions.showText(Text.of(message)));
+ return this;
+ }
+
+ @Override
+ public MessageBuilder hover(String... strings) {
+ builder.onHover(TextActions.showText(Text.of((Object[]) strings)));
+ return this;
+ }
+
+ @Override
+ public MessageBuilder hover(Collection collection) {
+ builder.onHover(TextActions.showText(Text.of(collection.toArray())));
+ return this;
+ }
+
+ @Override
+ public MessageBuilder indent(int amount) {
+ for (int i = 0; i < amount; i++) {
+ builder.append(Text.of(' '));
+ }
+ return this;
+ }
+
+ @Override
+ public MessageBuilder tabular(CharSequence charSequence) {
+ sender.getFormatter().table(charSequence.toString(), ":");
+ return this;
+ }
+
+ @Override
+ public void send() {
+ sender.source.sendMessage(builder.build());
+ }
+}