版本更新至:3.76
调整:开发框架改为 Gradle 新增:Language2 工具新增 [book] 类型
This commit is contained in:
431
src/main/java/me/skymc/taboolib/jsonformatter/JSONFormatter.java
Normal file
431
src/main/java/me/skymc/taboolib/jsonformatter/JSONFormatter.java
Normal file
@@ -0,0 +1,431 @@
|
||||
package me.skymc.taboolib.jsonformatter;
|
||||
|
||||
import java.lang.reflect.Constructor;
|
||||
import java.lang.reflect.Field;
|
||||
import java.lang.reflect.Method;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.ChatColor;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import me.skymc.taboolib.json.JSONArray;
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
import me.skymc.taboolib.jsonformatter.click.ClickEvent;
|
||||
import me.skymc.taboolib.jsonformatter.hover.HoverEvent;
|
||||
import me.skymc.taboolib.nms.NMSUtils;
|
||||
|
||||
public class JSONFormatter {
|
||||
|
||||
private JSONArray ja = new JSONArray();
|
||||
private Builder builder = new Builder();
|
||||
private String color = "";
|
||||
private List<JSONArray> all = new ArrayList<JSONArray>();
|
||||
private boolean newline = true;
|
||||
|
||||
public JSONFormatter(){
|
||||
}
|
||||
|
||||
public JSONFormatter(boolean newline){
|
||||
this.newline = newline;
|
||||
}
|
||||
|
||||
public JSONFormatter append(JSONFormatter json){
|
||||
if(json.ja.length() == 0)
|
||||
return this;
|
||||
try{
|
||||
if(newline && json.newline){
|
||||
all.addAll(json.all);
|
||||
}
|
||||
for(int i = 0; i < json.ja.length(); i++){
|
||||
add(json.ja.get(i));
|
||||
}
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
public int getSize(){
|
||||
if(newline){ return 1; }
|
||||
return all.size() + 1;
|
||||
}
|
||||
|
||||
public JSONFormatter newLine(){
|
||||
if(newline){
|
||||
append("\n");
|
||||
}else{
|
||||
all.add(ja);
|
||||
ja = new JSONArray();
|
||||
}
|
||||
resetAll();
|
||||
return this;
|
||||
}
|
||||
|
||||
public JSONFormatter newLine(int amount){
|
||||
for(int i = 0; i < amount; i++)
|
||||
newLine();
|
||||
return this;
|
||||
}
|
||||
|
||||
public void clear(){
|
||||
ja = new JSONArray();
|
||||
builder = new Builder();
|
||||
color = "";
|
||||
}
|
||||
|
||||
public JSONFormatter resetAll(){
|
||||
return resetColors().resetModifiers();
|
||||
}
|
||||
|
||||
public JSONFormatter resetColors(){
|
||||
color = "";
|
||||
return this;
|
||||
}
|
||||
|
||||
public JSONFormatter resetModifiers(){
|
||||
builder = new Builder();
|
||||
return this;
|
||||
}
|
||||
|
||||
public String toJSON(){
|
||||
JSONObject jo = new JSONObject();
|
||||
try{
|
||||
if(ja.length() > 0)
|
||||
jo.put("extra", ja);
|
||||
jo.put("text", "");
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
return jo.toString();
|
||||
}
|
||||
|
||||
public List<String> toJSONList(){
|
||||
List<String> list = new ArrayList<String>();
|
||||
try{
|
||||
for(JSONArray ja : all){
|
||||
JSONObject jo = new JSONObject();
|
||||
if(ja.length() > 0)
|
||||
jo.put("extra", ja);
|
||||
jo.put("text", "");
|
||||
list.add(jo.toString());
|
||||
}
|
||||
JSONObject jo = new JSONObject();
|
||||
if(ja.length() > 0)
|
||||
jo.put("extra", ja);
|
||||
jo.put("text", "");
|
||||
list.add(jo.toString());
|
||||
return list;
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public Object toSerialized(){
|
||||
try{
|
||||
return a.invoke(null, toJSON());
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public List<Object> toSerializedList(){
|
||||
List<Object> list = new ArrayList<Object>();
|
||||
try{
|
||||
for(String s : toJSONList()){
|
||||
list.add(a.invoke(null, s));
|
||||
}
|
||||
return list;
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public JSONFormatter send(Player player){
|
||||
JSONFormatter.send(player, this);
|
||||
return this;
|
||||
}
|
||||
|
||||
private void add(Object jo){
|
||||
if(ja == null)
|
||||
ja = new JSONArray();
|
||||
if(jo != null)
|
||||
ja.put(jo);
|
||||
}
|
||||
|
||||
private JSONFormatter append(String text, BuilderMaker bm){
|
||||
builder = new Builder(builder);
|
||||
for(int i = 0; i < text.length(); i++){
|
||||
char c = text.charAt(i);
|
||||
switch(c){
|
||||
case '§':{
|
||||
if((i + 1) == text.length()){
|
||||
builder.append(c);
|
||||
continue;
|
||||
}
|
||||
ChatColor cc = ChatColor.getByChar(text.charAt(i + 1));
|
||||
if(cc == null){
|
||||
builder.append(c);
|
||||
break;
|
||||
}
|
||||
add(bm.make());
|
||||
switch(cc){
|
||||
case BOLD:
|
||||
builder = new Builder(builder);
|
||||
builder.bold = true;
|
||||
break;
|
||||
case ITALIC:
|
||||
builder = new Builder(builder);
|
||||
builder.italic = true;
|
||||
break;
|
||||
case MAGIC:
|
||||
builder = new Builder(builder);
|
||||
builder.magic = true;
|
||||
break;
|
||||
case RESET:
|
||||
builder = new Builder();
|
||||
color = "";
|
||||
break;
|
||||
case STRIKETHROUGH:
|
||||
builder = new Builder(builder);
|
||||
builder.strikethrough = true;
|
||||
break;
|
||||
case UNDERLINE:
|
||||
builder = new Builder(builder);
|
||||
builder.underline = true;
|
||||
break;
|
||||
default:{
|
||||
builder = new Builder();
|
||||
color = cc.name().toLowerCase();
|
||||
break;
|
||||
}
|
||||
}
|
||||
i++;
|
||||
break;
|
||||
}
|
||||
default:{
|
||||
builder.append(c);
|
||||
}
|
||||
}
|
||||
}
|
||||
add(bm.make());
|
||||
return this;
|
||||
}
|
||||
|
||||
public JSONFormatter append(String text){
|
||||
return append(text, new BuilderMaker(){
|
||||
@Override
|
||||
public JSONObject make(){
|
||||
return builder.toString(color);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public JSONFormatter appendHover(String text, final HoverEvent hevent){
|
||||
return append(text, new BuilderMaker(){
|
||||
@Override
|
||||
public JSONObject make(){
|
||||
return builder.toStringHover(color, hevent);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public JSONFormatter appendClick(String text, final ClickEvent cevent){
|
||||
return append(text, new BuilderMaker(){
|
||||
@Override
|
||||
public JSONObject make(){
|
||||
return builder.toStringClick(color, cevent);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public JSONFormatter appendHoverClick(String text, final HoverEvent hevent, final ClickEvent cevent){
|
||||
return append(text, new BuilderMaker(){
|
||||
@Override
|
||||
public JSONObject make(){
|
||||
return builder.toStringHoverClick(color, hevent, cevent);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public Object getPacket(){
|
||||
try{
|
||||
return ppocc.newInstance(toSerialized());
|
||||
}catch(Exception e){
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public List<Object> getPacketList(){
|
||||
List<Object> list = new ArrayList<Object>();
|
||||
try{
|
||||
for(Object o : toSerializedList()){
|
||||
list.add(ppocc.newInstance(o));
|
||||
}
|
||||
return list;
|
||||
}catch(Exception e){
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
private static Class<?> cs = NMSUtils.getNMSClassSilent("ChatSerializer", "IChatBaseComponent"), icbc = NMSUtils.getNMSClassSilent("IChatBaseComponent"), ppoc = NMSUtils.getNMSClassSilent("PacketPlayOutChat"), pc = NMSUtils.getNMSClassSilent("PlayerConnection"),
|
||||
p = NMSUtils.getNMSClassSilent("Packet"), ep = NMSUtils.getNMSClassSilent("EntityPlayer");
|
||||
private static Method a = NMSUtils.getMethodSilent(cs, "a", String.class), sp = NMSUtils.getMethodSilent(pc, "sendPacket", p);
|
||||
private static Field ppc = NMSUtils.getFieldSilent(ep, "playerConnection");
|
||||
private static Constructor<?> ppocc = NMSUtils.getConstructorSilent(ppoc, icbc);
|
||||
private static boolean b = check(cs, icbc, ppoc, pc, p, ep, a, sp, ppc, ppocc);
|
||||
|
||||
private static boolean check(Object... o){
|
||||
for(Object a : o){
|
||||
if(a == null)
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
private static void send(Player player, JSONFormatter jf){
|
||||
if(!jf.newline){
|
||||
send1(player, jf);
|
||||
}else if(b){
|
||||
try{
|
||||
Object entityplayer = NMSUtils.getHandle(player);
|
||||
Object ppco = ppc.get(entityplayer);
|
||||
sp.invoke(ppco, jf.getPacket());
|
||||
} catch(Exception e){
|
||||
Bukkit.getServer().dispatchCommand(Bukkit.getConsoleSender(), "tellraw " + player.getName() + " " + jf.toJSON());
|
||||
}
|
||||
}else{
|
||||
Bukkit.getServer().dispatchCommand(Bukkit.getConsoleSender(), "tellraw " + player.getName() + " " + jf.toJSON());
|
||||
}
|
||||
}
|
||||
|
||||
private static void send1(Player player, JSONFormatter jf){
|
||||
if(b){
|
||||
try{
|
||||
Object entityplayer = NMSUtils.getHandle(player);
|
||||
Object ppco = ppc.get(entityplayer);
|
||||
List<Object> packets = jf.getPacketList();
|
||||
List<String> jsons = null;
|
||||
for(int i = 0; i < packets.size(); i++){
|
||||
try{
|
||||
sp.invoke(ppco, packets.get(i));
|
||||
}catch(Exception e){
|
||||
if(jsons == null){
|
||||
jsons = jf.toJSONList();
|
||||
}
|
||||
Bukkit.getServer().dispatchCommand(Bukkit.getConsoleSender(), "tellraw " + player.getName() + " " + jsons.get(i));
|
||||
}
|
||||
}
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
}else{
|
||||
for(String json : jf.toJSONList()){
|
||||
Bukkit.getServer().dispatchCommand(Bukkit.getConsoleSender(), "tellraw " + player.getName() + " " + json);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private class Builder{
|
||||
|
||||
private StringBuilder sb = new StringBuilder("");
|
||||
private boolean bold = false, italic = false, magic = false, strikethrough = false, underline = false, changed = false;
|
||||
|
||||
public Builder(){
|
||||
}
|
||||
|
||||
public Builder(Builder b){
|
||||
bold = b.bold;
|
||||
italic = b.italic;
|
||||
magic = b.magic;
|
||||
strikethrough = b.strikethrough;
|
||||
underline = b.underline;
|
||||
}
|
||||
|
||||
public void append(char c){
|
||||
sb.append(c);
|
||||
changed = true;
|
||||
}
|
||||
|
||||
private JSONObject toString(String color, BuilderHelper bh){
|
||||
String string = sb.toString();
|
||||
if(!changed)
|
||||
return null;
|
||||
if(string.length() == 0)
|
||||
return null;
|
||||
JSONObject jo = new JSONObject();
|
||||
try{
|
||||
if(!color.equals(""))
|
||||
jo.put("color", color);
|
||||
if(bold)
|
||||
jo.put("bold", true);
|
||||
if(italic)
|
||||
jo.put("italic", true);
|
||||
if(magic)
|
||||
jo.put("obfuscated", true);
|
||||
if(strikethrough)
|
||||
jo.put("strikethrough", true);
|
||||
if(underline)
|
||||
jo.put("underlined", true);
|
||||
bh.add(jo);
|
||||
jo.put("text", string);
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
return jo;
|
||||
}
|
||||
|
||||
public JSONObject toString(String color){
|
||||
return toString(color, new BuilderHelper(){
|
||||
@Override
|
||||
public void add(JSONObject jo) throws Exception{
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public JSONObject toStringHover(String color, final HoverEvent event){
|
||||
return toString(color, new BuilderHelper(){
|
||||
@Override
|
||||
public void add(JSONObject jo) throws Exception{
|
||||
if(event.getEvent().length() > 1)
|
||||
jo.put("hoverEvent", event.getEvent());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public JSONObject toStringClick(String color, final ClickEvent event){
|
||||
return toString(color, new BuilderHelper(){
|
||||
@Override
|
||||
public void add(JSONObject jo) throws Exception{
|
||||
if(event.getEvent().length() > 1)
|
||||
jo.put("clickEvent", event.getEvent());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public JSONObject toStringHoverClick(String color, final HoverEvent hevent, final ClickEvent cevent){
|
||||
return toString(color, new BuilderHelper(){
|
||||
@Override
|
||||
public void add(JSONObject jo) throws Exception{
|
||||
if(hevent.getEvent().length() > 1)
|
||||
jo.put("hoverEvent", hevent.getEvent());
|
||||
if(cevent.getEvent().length() > 1)
|
||||
jo.put("clickEvent", cevent.getEvent());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private abstract class BuilderMaker{
|
||||
public abstract JSONObject make();
|
||||
}
|
||||
|
||||
private abstract class BuilderHelper{
|
||||
public abstract void add(JSONObject jo) throws Exception;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,9 @@
|
||||
package me.skymc.taboolib.jsonformatter.click;
|
||||
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
|
||||
public abstract class ClickEvent{
|
||||
|
||||
public abstract JSONObject getEvent();
|
||||
|
||||
}
|
||||
@@ -0,0 +1,23 @@
|
||||
package me.skymc.taboolib.jsonformatter.click;
|
||||
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
|
||||
public class OpenUrlEvent extends ClickEvent{
|
||||
|
||||
private JSONObject object = new JSONObject();
|
||||
|
||||
public OpenUrlEvent(String suggest){
|
||||
try{
|
||||
object.put("action", "open_url");
|
||||
object.put("value", suggest);
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public JSONObject getEvent(){
|
||||
return object;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,23 @@
|
||||
package me.skymc.taboolib.jsonformatter.click;
|
||||
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
|
||||
public class RunCommandEvent extends ClickEvent{
|
||||
|
||||
private JSONObject object = new JSONObject();
|
||||
|
||||
public RunCommandEvent(String command){
|
||||
try{
|
||||
object.put("action", "run_command");
|
||||
object.put("value", command);
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public JSONObject getEvent(){
|
||||
return object;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,23 @@
|
||||
package me.skymc.taboolib.jsonformatter.click;
|
||||
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
|
||||
public class SuggestCommandEvent extends ClickEvent{
|
||||
|
||||
private JSONObject object = new JSONObject();
|
||||
|
||||
public SuggestCommandEvent(String suggest){
|
||||
try{
|
||||
object.put("action", "suggest_command");
|
||||
object.put("value", suggest);
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public JSONObject getEvent(){
|
||||
return object;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,9 @@
|
||||
package me.skymc.taboolib.jsonformatter.hover;
|
||||
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
|
||||
public abstract class HoverEvent{
|
||||
|
||||
public abstract JSONObject getEvent();
|
||||
|
||||
}
|
||||
@@ -0,0 +1,23 @@
|
||||
package me.skymc.taboolib.jsonformatter.hover;
|
||||
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
|
||||
public class ShowAchievementEvent extends HoverEvent{
|
||||
|
||||
private JSONObject object = new JSONObject();
|
||||
|
||||
public ShowAchievementEvent(String achievement){
|
||||
try{
|
||||
object.put("action", "show_achievement");
|
||||
object.put("value", achievement);
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public JSONObject getEvent(){
|
||||
return object;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,79 @@
|
||||
package me.skymc.taboolib.jsonformatter.hover;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.enchantments.Enchantment;
|
||||
import org.bukkit.inventory.ItemStack;
|
||||
import org.bukkit.inventory.meta.ItemMeta;
|
||||
|
||||
import me.skymc.taboolib.TabooLib;
|
||||
import me.skymc.taboolib.inventory.ItemUtils;
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
import me.skymc.taboolib.nms.item.DabItemUtils;
|
||||
import me.skymc.taboolib.nms.item.IDabItemUtils;
|
||||
|
||||
public class ShowItemEvent extends HoverEvent{
|
||||
|
||||
private JSONObject object = new JSONObject();
|
||||
|
||||
public Object getItemTag(ItemStack item) {
|
||||
try {
|
||||
return DabItemUtils.getInstance().getTag(DabItemUtils.getInstance().getNMSCopy(item));
|
||||
} catch (Exception e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
@SuppressWarnings("deprecation")
|
||||
public ShowItemEvent(ItemStack is){
|
||||
try{
|
||||
object.put("action", "show_item");
|
||||
StringBuilder tag = new StringBuilder();
|
||||
Object itemTag = getItemTag(is);
|
||||
if (itemTag != null) {
|
||||
tag.append(",tag:" + itemTag);
|
||||
}
|
||||
else {
|
||||
ItemMeta im = is.getItemMeta();
|
||||
List<String> lore = im.hasLore() ? im.getLore() : new ArrayList<>();
|
||||
Map<Enchantment, Integer> enchants = is.getItemMeta().getEnchants();
|
||||
tag.append(",tag:{display:{Name:" + (enchants.size() > 0 ? "§b§o" : "§f") + ItemUtils.getCustomName(is));
|
||||
if (lore.size() > 0) {
|
||||
tag.append(",Lore:[");
|
||||
for (String s : lore){
|
||||
tag.append("\"" + s + "\",");
|
||||
}
|
||||
tag.delete(tag.length() - 1, tag.length());
|
||||
tag.append("]");
|
||||
}
|
||||
tag.append("}");
|
||||
if (enchants.size() > 0) {
|
||||
if(tag.length() > 6) {
|
||||
tag.append(",");
|
||||
}
|
||||
tag.append("ench:[");
|
||||
for (Entry<Enchantment, Integer> e : enchants.entrySet()) {
|
||||
tag.append("{id:" + e.getKey().getId() + ",lvl:" + e.getValue() + "},");
|
||||
}
|
||||
tag.delete(tag.length() - 1, tag.length());
|
||||
tag.append("]");
|
||||
}
|
||||
tag.append("}");
|
||||
}
|
||||
|
||||
object.put("value", "{id:" + (TabooLib.getVerint() > 10700 ? DabItemUtils.getMinecraftName(is) : is.getTypeId()) + ",Count:" + is.getAmount() + tag.toString() + "}");
|
||||
} catch(Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public JSONObject getEvent(){
|
||||
return object;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,23 @@
|
||||
package me.skymc.taboolib.jsonformatter.hover;
|
||||
|
||||
import me.skymc.taboolib.json.JSONObject;
|
||||
|
||||
public class ShowTextEvent extends HoverEvent{
|
||||
|
||||
private JSONObject object = new JSONObject();
|
||||
|
||||
public ShowTextEvent(String text){
|
||||
try{
|
||||
object.put("action", "show_text");
|
||||
object.put("value", text);
|
||||
}catch(Exception e){
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public JSONObject getEvent(){
|
||||
return object;
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user