Mostly fixed chat formatting #60
2 changed files with 17 additions and 11 deletions
|
@ -2,7 +2,6 @@ package buttondevteam.chat;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
|
@ -21,11 +20,7 @@ import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
|
||||||
import buttondevteam.chat.commands.UnlolCommand;
|
import buttondevteam.chat.commands.UnlolCommand;
|
||||||
import buttondevteam.chat.commands.ucmds.admin.DebugCommand;
|
import buttondevteam.chat.commands.ucmds.admin.DebugCommand;
|
||||||
import buttondevteam.chat.formatting.ChatFormatter;
|
import buttondevteam.chat.formatting.*;
|
||||||
import buttondevteam.chat.formatting.ChatFormatterBuilder;
|
|
||||||
import buttondevteam.chat.formatting.TellrawEvent;
|
|
||||||
import buttondevteam.chat.formatting.TellrawPart;
|
|
||||||
import buttondevteam.chat.formatting.TellrawSerializer;
|
|
||||||
import buttondevteam.lib.TBMCCoreAPI;
|
import buttondevteam.lib.TBMCCoreAPI;
|
||||||
import buttondevteam.lib.TBMCPlayer;
|
import buttondevteam.lib.TBMCPlayer;
|
||||||
import buttondevteam.lib.chat.Channel;
|
import buttondevteam.lib.chat.Channel;
|
||||||
|
@ -57,15 +52,15 @@ public class ChatProcessing {
|
||||||
|
|
||||||
static {
|
static {
|
||||||
commonFormatters.add(new ChatFormatterBuilder().setRegex(BOLD_PATTERN).setFormat(Format.Bold)
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(BOLD_PATTERN).setFormat(Format.Bold)
|
||||||
.setRemoveCharCount((short) 2).build());
|
.setRemoveCharCount((short) 2).setRange(true).build());
|
||||||
commonFormatters.add(new ChatFormatterBuilder().setRegex(ITALIC_PATTERN).setFormat(Format.Italic)
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(ITALIC_PATTERN).setFormat(Format.Italic)
|
||||||
.setRemoveCharCount((short) 1).build());
|
.setRemoveCharCount((short) 1).setRange(true).build());
|
||||||
commonFormatters.add(new ChatFormatterBuilder().setRegex(UNDERLINED_PATTERN).setFormat(Format.Underlined)
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(UNDERLINED_PATTERN).setFormat(Format.Underlined)
|
||||||
.setRemoveCharCount((short) 1).build());
|
.setRemoveCharCount((short) 1).setRange(true).build());
|
||||||
commonFormatters.add(ESCAPE_FORMATTER);
|
commonFormatters.add(ESCAPE_FORMATTER);
|
||||||
// URLs + Rainbow text
|
// URLs + Rainbow text
|
||||||
commonFormatters.add(new ChatFormatterBuilder().setRegex(URL_PATTERN).setFormat(Format.Underlined)
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(URL_PATTERN).setFormat(Format.Underlined)
|
||||||
.setOpenlink("$1").build());
|
.setOpenlink("$1").setRange(true).build());
|
||||||
commonFormatters.add(new ChatFormatterBuilder().setRegex(NULL_MENTION_PATTERN).setColor(Color.DarkRed).build()); // Properly added a bug as a feature
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(NULL_MENTION_PATTERN).setColor(Color.DarkRed).build()); // Properly added a bug as a feature
|
||||||
commonFormatters.add(new ChatFormatterBuilder().setRegex(CONSOLE_PING_PATTERN).setColor(Color.Aqua)
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(CONSOLE_PING_PATTERN).setColor(Color.Aqua)
|
||||||
.setOnmatch((String match) -> {
|
.setOnmatch((String match) -> {
|
||||||
|
|
|
@ -14,9 +14,11 @@ public class ChatFormatterBuilder {
|
||||||
private Priority priority;
|
private Priority priority;
|
||||||
private short removecharcount = 0;
|
private short removecharcount = 0;
|
||||||
private short removecharpos = -1;
|
private short removecharpos = -1;
|
||||||
|
private boolean range = false;
|
||||||
|
|
||||||
public ChatFormatter build() {
|
public ChatFormatter build() {
|
||||||
return new ChatFormatter(regex, format, color, onmatch, openlink, priority, removecharcount, removecharpos);
|
return new ChatFormatter(regex, format, color, onmatch, openlink, priority, removecharcount, removecharpos,
|
||||||
|
range);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Pattern getRegex() {
|
public Pattern getRegex() {
|
||||||
|
@ -100,4 +102,13 @@ public class ChatFormatterBuilder {
|
||||||
this.removecharpos = removecharpos;
|
this.removecharpos = removecharpos;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isRange() {
|
||||||
|
return range;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ChatFormatterBuilder setRange(boolean range) {
|
||||||
|
this.range = range;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue