mirror of
https://github.com/CarmJos/EasyPlugin.git
synced 2026-06-04 16:48:16 +08:00
[v1.3.5] 消息配置文件相关更新
- [U] 优化消息发送逻辑,不再向玩家发送空消息。
This commit is contained in:
@@ -5,7 +5,7 @@
|
||||
<parent>
|
||||
<artifactId>easyplugin-parent</artifactId>
|
||||
<groupId>cc.carm.lib</groupId>
|
||||
<version>1.3.4</version>
|
||||
<version>1.3.5</version>
|
||||
</parent>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
|
||||
+27
-13
@@ -4,13 +4,14 @@ import cc.carm.lib.easyplugin.configuration.file.FileConfig;
|
||||
import cc.carm.lib.easyplugin.configuration.values.ConfigValue;
|
||||
import cc.carm.lib.easyplugin.utils.ColorParser;
|
||||
import cc.carm.lib.easyplugin.utils.MessageUtils;
|
||||
import net.md_5.bungee.api.ChatMessageType;
|
||||
import net.md_5.bungee.api.chat.TextComponent;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
import java.util.Collections;
|
||||
|
||||
public class EasyMessage {
|
||||
|
||||
@Nullable ConfigValue<String> configValue;
|
||||
@@ -65,12 +66,11 @@ public class EasyMessage {
|
||||
}
|
||||
|
||||
public @NotNull String get(@Nullable CommandSender sender, @Nullable String[] params, @Nullable Object[] values) {
|
||||
if (sender == null) return getMessages();
|
||||
if (params == null || values == null) {
|
||||
return ColorParser.parse(MessageUtils.setPlaceholders(sender, getMessages()));
|
||||
} else {
|
||||
return ColorParser.parse(MessageUtils.setPlaceholders(sender, getMessages(), params, values));
|
||||
}
|
||||
String messages = getMessages();
|
||||
if (sender == null || messages.length() < 1) return messages;
|
||||
params = params == null ? new String[0] : params;
|
||||
values = values == null ? new Object[0] : values;
|
||||
return ColorParser.parse(MessageUtils.setPlaceholders(sender, messages, params, values));
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender) {
|
||||
@@ -82,11 +82,25 @@ public class EasyMessage {
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender, @Nullable String[] params, @Nullable Object[] values) {
|
||||
if (params == null || values == null) {
|
||||
MessageUtils.sendWithPlaceholders(sender, getMessages());
|
||||
} else {
|
||||
MessageUtils.sendWithPlaceholders(sender, Collections.singletonList(getMessages()), params, values);
|
||||
}
|
||||
String message = get(sender, params, values);
|
||||
if (message.length() < 1) return;
|
||||
MessageUtils.send(sender, message);
|
||||
}
|
||||
|
||||
public void sendBar(@Nullable Player player) {
|
||||
sendBar(player, null);
|
||||
}
|
||||
|
||||
public void sendBar(@Nullable Player player, @Nullable Object[] values) {
|
||||
sendBar(player, getMessageParams(), values);
|
||||
}
|
||||
|
||||
public void sendBar(@Nullable Player player, @Nullable String[] params, @Nullable Object[] values) {
|
||||
if (player == null) return;
|
||||
String message = get(player, params, values);
|
||||
|
||||
if (message.length() < 1) return;
|
||||
player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(get(player, params, values)));
|
||||
}
|
||||
|
||||
public void sendToAll() {
|
||||
|
||||
+9
-11
@@ -2,6 +2,7 @@ package cc.carm.lib.easyplugin.configuration.language;
|
||||
|
||||
import cc.carm.lib.easyplugin.configuration.file.FileConfig;
|
||||
import cc.carm.lib.easyplugin.configuration.values.ConfigValueList;
|
||||
import cc.carm.lib.easyplugin.utils.ColorParser;
|
||||
import cc.carm.lib.easyplugin.utils.MessageUtils;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.command.CommandSender;
|
||||
@@ -48,7 +49,6 @@ public class EasyMessageList {
|
||||
else return Arrays.asList(getDefaultValue());
|
||||
}
|
||||
|
||||
|
||||
private @Nullable String[] getMessageParams() {
|
||||
return messageParams;
|
||||
}
|
||||
@@ -71,11 +71,10 @@ public class EasyMessageList {
|
||||
|
||||
public @NotNull List<String> get(@Nullable CommandSender sender, @Nullable String[] params, @Nullable Object[] values) {
|
||||
if (sender == null) return getMessages();
|
||||
if (params == null || values == null) {
|
||||
return MessageUtils.setPlaceholders(sender, getMessages());
|
||||
} else {
|
||||
return MessageUtils.setPlaceholders(sender, getMessages(), params, values);
|
||||
}
|
||||
params = params == null ? new String[0] : params;
|
||||
values = values == null ? new Object[0] : values;
|
||||
|
||||
return ColorParser.parse(MessageUtils.setPlaceholders(sender, getMessages(), params, values));
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender) {
|
||||
@@ -87,11 +86,10 @@ public class EasyMessageList {
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender, @Nullable String[] params, @Nullable Object[] values) {
|
||||
if (params == null || values == null) {
|
||||
MessageUtils.sendWithPlaceholders(sender, getMessages());
|
||||
} else {
|
||||
MessageUtils.sendWithPlaceholders(sender, getMessages(), params, values);
|
||||
}
|
||||
List<String> messages = get(sender, params, values);
|
||||
if (messages.isEmpty()) return;
|
||||
if (messages.size() == 1 && messages.get(0).length() == 0) return; //空消息不再发送
|
||||
MessageUtils.send(sender, messages);
|
||||
}
|
||||
|
||||
public void sendToAll() {
|
||||
|
||||
+48
-31
@@ -3,13 +3,16 @@ package cc.carm.lib.easyplugin.configuration.message;
|
||||
|
||||
import cc.carm.lib.easyplugin.configuration.file.FileConfig;
|
||||
import cc.carm.lib.easyplugin.configuration.values.ConfigValue;
|
||||
import cc.carm.lib.easyplugin.utils.ColorParser;
|
||||
import cc.carm.lib.easyplugin.utils.MessageUtils;
|
||||
import net.md_5.bungee.api.ChatMessageType;
|
||||
import net.md_5.bungee.api.chat.TextComponent;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
import java.util.Collections;
|
||||
import java.util.function.Supplier;
|
||||
|
||||
public class ConfigMessage extends ConfigValue<String> {
|
||||
@@ -41,53 +44,67 @@ public class ConfigMessage extends ConfigValue<String> {
|
||||
this.messageParams = messageParams;
|
||||
}
|
||||
|
||||
public @NotNull String get(CommandSender sender) {
|
||||
return MessageUtils.setPlaceholders(sender, get());
|
||||
public String[] getMessageParams() {
|
||||
return messageParams;
|
||||
}
|
||||
|
||||
public @NotNull String get(CommandSender sender, Object[] values) {
|
||||
if (messageParams != null) {
|
||||
return get(sender, messageParams, values);
|
||||
} else {
|
||||
return get(sender);
|
||||
}
|
||||
public @NotNull String get(@Nullable CommandSender sender) {
|
||||
return get(sender, null);
|
||||
}
|
||||
|
||||
public @NotNull String get(CommandSender sender, String[] params, Object[] values) {
|
||||
return MessageUtils.setPlaceholders(sender, get(), params, values);
|
||||
public @NotNull String get(@Nullable CommandSender sender, @Nullable Object[] values) {
|
||||
return get(sender, getMessageParams(), values);
|
||||
}
|
||||
|
||||
public void send(CommandSender sender) {
|
||||
MessageUtils.sendWithPlaceholders(sender, get());
|
||||
public @NotNull String get(@Nullable CommandSender sender, @Nullable String[] params, @Nullable Object[] values) {
|
||||
String messages = get();
|
||||
if (sender == null || messages.length() < 1) return messages;
|
||||
params = params == null ? new String[0] : params;
|
||||
values = values == null ? new Object[0] : values;
|
||||
return ColorParser.parse(MessageUtils.setPlaceholders(sender, messages, params, values));
|
||||
}
|
||||
|
||||
public void send(CommandSender sender, Object[] values) {
|
||||
if (messageParams != null) {
|
||||
send(sender, messageParams, values);
|
||||
} else {
|
||||
send(sender, new String[0], new Object[0]);
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender) {
|
||||
send(sender, null);
|
||||
}
|
||||
|
||||
public void send(CommandSender sender, String[] params, Object[] values) {
|
||||
MessageUtils.sendWithPlaceholders(sender, Collections.singletonList(get()), params, values);
|
||||
public void send(@Nullable CommandSender sender, @Nullable Object[] values) {
|
||||
send(sender, getMessageParams(), values);
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender, @Nullable String[] params, @Nullable Object[] values) {
|
||||
String message = get(sender, params, values);
|
||||
if (message.length() < 1) return;
|
||||
|
||||
MessageUtils.send(sender, message);
|
||||
}
|
||||
|
||||
public void sendBar(@Nullable Player player) {
|
||||
sendBar(player, null);
|
||||
}
|
||||
|
||||
public void sendBar(@Nullable Player player, @Nullable Object[] values) {
|
||||
sendBar(player, getMessageParams(), values);
|
||||
}
|
||||
|
||||
public void sendBar(@Nullable Player player, @Nullable String[] params, @Nullable Object[] values) {
|
||||
if (player == null) return;
|
||||
String message = get(player, params, values);
|
||||
if (message.length() < 1) return;
|
||||
|
||||
player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(get(player, params, values)));
|
||||
}
|
||||
|
||||
public void sendToAll() {
|
||||
Bukkit.getOnlinePlayers().forEach(player -> MessageUtils.sendWithPlaceholders(player, Collections.singletonList(get())));
|
||||
sendToAll(null);
|
||||
}
|
||||
|
||||
public void sendToAll(Object[] values) {
|
||||
if (messageParams != null) {
|
||||
sendToAll(messageParams, values);
|
||||
} else {
|
||||
sendToAll();
|
||||
}
|
||||
public void sendToAll(@Nullable Object[] values) {
|
||||
sendToAll(messageParams, values);
|
||||
}
|
||||
|
||||
public void sendToAll(String[] params, Object[] values) {
|
||||
Bukkit.getOnlinePlayers().forEach(pl -> MessageUtils.sendWithPlaceholders(pl, Collections.singletonList(get()), params, values));
|
||||
public void sendToAll(@Nullable String[] params, @Nullable Object[] values) {
|
||||
Bukkit.getOnlinePlayers().forEach(pl -> send(pl, params, values));
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
+30
-29
@@ -3,6 +3,7 @@ package cc.carm.lib.easyplugin.configuration.message;
|
||||
|
||||
import cc.carm.lib.easyplugin.configuration.file.FileConfig;
|
||||
import cc.carm.lib.easyplugin.configuration.values.ConfigValueList;
|
||||
import cc.carm.lib.easyplugin.utils.ColorParser;
|
||||
import cc.carm.lib.easyplugin.utils.MessageUtils;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.command.CommandSender;
|
||||
@@ -41,52 +42,52 @@ public class ConfigMessageList extends ConfigValueList<String> {
|
||||
this.messageParams = messageParams;
|
||||
}
|
||||
|
||||
public String[] getMessageParams() {
|
||||
return messageParams;
|
||||
}
|
||||
|
||||
public @NotNull List<String> get(@Nullable CommandSender sender) {
|
||||
return MessageUtils.setPlaceholders(sender, get());
|
||||
return get(sender, null);
|
||||
}
|
||||
|
||||
public @NotNull List<String> get(@Nullable CommandSender sender, Object[] values) {
|
||||
if (messageParams != null) {
|
||||
return get(sender, messageParams, values);
|
||||
} else {
|
||||
return get(sender);
|
||||
}
|
||||
|
||||
public @NotNull List<String> get(@Nullable CommandSender sender, @Nullable Object[] values) {
|
||||
return get(sender, getMessageParams(), values);
|
||||
}
|
||||
|
||||
public @NotNull List<String> get(@Nullable CommandSender sender, String[] params, Object[] values) {
|
||||
return MessageUtils.setPlaceholders(sender, get(), params, values);
|
||||
public @NotNull List<String> get(@Nullable CommandSender sender, @Nullable String[] params, @Nullable Object[] values) {
|
||||
if (sender == null) return get();
|
||||
params = params == null ? new String[0] : params;
|
||||
values = values == null ? new Object[0] : values;
|
||||
|
||||
return ColorParser.parse(MessageUtils.setPlaceholders(sender, get(), params, values));
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender) {
|
||||
MessageUtils.sendWithPlaceholders(sender, get());
|
||||
send(sender, null);
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender, Object[] values) {
|
||||
if (messageParams != null) {
|
||||
send(sender, messageParams, values);
|
||||
} else {
|
||||
send(sender);
|
||||
}
|
||||
public void send(@Nullable CommandSender sender, @Nullable Object[] values) {
|
||||
send(sender, getMessageParams(), values);
|
||||
}
|
||||
|
||||
public void send(@Nullable CommandSender sender, String[] params, Object[] values) {
|
||||
MessageUtils.sendWithPlaceholders(sender, get(), params, values);
|
||||
}
|
||||
|
||||
public void sendToAll(String[] params, Object[] values) {
|
||||
Bukkit.getOnlinePlayers().forEach(pl -> MessageUtils.sendWithPlaceholders(pl, get(), params, values));
|
||||
public void send(@Nullable CommandSender sender, @Nullable String[] params, @Nullable Object[] values) {
|
||||
List<String> messages = get(sender, params, values);
|
||||
if (messages.isEmpty()) return;
|
||||
if (messages.size() == 1 && messages.get(0).length() == 0) return; //空消息不再发送
|
||||
MessageUtils.send(sender, messages);
|
||||
}
|
||||
|
||||
public void sendToAll() {
|
||||
Bukkit.getOnlinePlayers().forEach(player -> MessageUtils.sendWithPlaceholders(player, get()));
|
||||
sendToAll(null);
|
||||
}
|
||||
|
||||
public void sendToAll(Object[] values) {
|
||||
if (messageParams != null) {
|
||||
sendToAll(messageParams, values);
|
||||
} else {
|
||||
sendToAll();
|
||||
}
|
||||
public void sendToAll(@Nullable Object[] values) {
|
||||
sendToAll(messageParams, values);
|
||||
}
|
||||
|
||||
public void sendToAll(@Nullable String[] params, @Nullable Object[] values) {
|
||||
Bukkit.getOnlinePlayers().forEach(pl -> send(pl, params, values));
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
Reference in New Issue
Block a user