mirror of
https://e.coding.net/circlecloud/MiaoChat.git
synced 2024-12-22 19:18:47 +00:00
feat: 完善物品展示 添加聊天开关
Signed-off-by: 502647092 <admin@yumc.pw>
This commit is contained in:
parent
f41da56c62
commit
335b04d01a
@ -5,6 +5,7 @@ import org.bukkit.plugin.java.JavaPlugin;
|
|||||||
|
|
||||||
import pw.yumc.MiaoChat.config.Config;
|
import pw.yumc.MiaoChat.config.Config;
|
||||||
import pw.yumc.MiaoChat.listeners.ChatListener;
|
import pw.yumc.MiaoChat.listeners.ChatListener;
|
||||||
|
import pw.yumc.YumCore.bukkit.Log;
|
||||||
import pw.yumc.YumCore.commands.CommandArgument;
|
import pw.yumc.YumCore.commands.CommandArgument;
|
||||||
import pw.yumc.YumCore.commands.CommandExecutor;
|
import pw.yumc.YumCore.commands.CommandExecutor;
|
||||||
import pw.yumc.YumCore.commands.CommandManager;
|
import pw.yumc.YumCore.commands.CommandManager;
|
||||||
@ -25,6 +26,20 @@ public class MiaoChat extends JavaPlugin implements CommandExecutor {
|
|||||||
return config;
|
return config;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Cmd(permission = "MiaoChat.toggle")
|
||||||
|
@Help("关闭聊天功能")
|
||||||
|
public void off(final CommandArgument e) {
|
||||||
|
ChatListener.offList.remove(e.getSender().getName());
|
||||||
|
Log.toSender(e.getSender(), "§c聊天功能已关闭!");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Cmd(permission = "MiaoChat.toggle")
|
||||||
|
@Help("开启聊天功能")
|
||||||
|
public void on(final CommandArgument e) {
|
||||||
|
ChatListener.offList.add(e.getSender().getName());
|
||||||
|
Log.toSender(e.getSender(), "§a聊天功能已开启!");
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onEnable() {
|
||||||
new ChatListener();
|
new ChatListener();
|
||||||
@ -34,6 +49,7 @@ public class MiaoChat extends JavaPlugin implements CommandExecutor {
|
|||||||
@Override
|
@Override
|
||||||
public void onLoad() {
|
public void onLoad() {
|
||||||
cfg = new FileConfig();
|
cfg = new FileConfig();
|
||||||
|
config = new Config();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Cmd(permission = "MiaoChat.reload")
|
@Cmd(permission = "MiaoChat.reload")
|
||||||
@ -41,6 +57,6 @@ public class MiaoChat extends JavaPlugin implements CommandExecutor {
|
|||||||
public void reload(final CommandArgument e) {
|
public void reload(final CommandArgument e) {
|
||||||
cfg.reload();
|
cfg.reload();
|
||||||
config.reload();
|
config.reload();
|
||||||
e.getSender().sendMessage("§a配置文件已重载!");
|
Log.toSender(e.getSender(), "§a配置文件已重载!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,7 @@ import pw.yumc.YumCore.config.FileConfig;
|
|||||||
|
|
||||||
public class ChatConfig {
|
public class ChatConfig {
|
||||||
private static String PrefixKey = "Format.Prefix";
|
private static String PrefixKey = "Format.Prefix";
|
||||||
|
private static String PlayerKey = "Format.Player";
|
||||||
private static String SuffixKey = "Format.Suffix";
|
private static String SuffixKey = "Format.Suffix";
|
||||||
private final FileConfig config;
|
private final FileConfig config;
|
||||||
private final List<ChatMessagePart> prefixs;
|
private final List<ChatMessagePart> prefixs;
|
||||||
@ -39,7 +40,9 @@ public class ChatConfig {
|
|||||||
prefixs.add(new ChatMessagePart(config.getConfigurationSection(PrefixKey + "." + part)));
|
prefixs.add(new ChatMessagePart(config.getConfigurationSection(PrefixKey + "." + part)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
player = new ChatMessagePart(config.getConfigurationSection("Format.Player"));
|
if (config.isSet(PlayerKey)) {
|
||||||
|
player = new ChatMessagePart(config.getConfigurationSection(PlayerKey));
|
||||||
|
}
|
||||||
suffixs.clear();
|
suffixs.clear();
|
||||||
if (config.isSet(SuffixKey)) {
|
if (config.isSet(SuffixKey)) {
|
||||||
for (final String part : config.getConfigurationSection(SuffixKey).getKeys(false)) {
|
for (final String part : config.getConfigurationSection(SuffixKey).getKeys(false)) {
|
||||||
|
@ -8,14 +8,18 @@ import org.bukkit.entity.Player;
|
|||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
import me.clip.placeholderapi.PlaceholderAPI;
|
||||||
import pw.yumc.YumCore.config.ConfigNode;
|
import pw.yumc.YumCore.config.ConfigNode;
|
||||||
import pw.yumc.YumCore.config.InjectConfigurationSection;
|
import pw.yumc.YumCore.config.InjectConfigurationSection;
|
||||||
|
import pw.yumc.YumCore.config.Nullable;
|
||||||
import pw.yumc.YumCore.tellraw.Tellraw;
|
import pw.yumc.YumCore.tellraw.Tellraw;
|
||||||
|
|
||||||
public class ChatMessagePart extends InjectConfigurationSection {
|
public class ChatMessagePart extends InjectConfigurationSection {
|
||||||
private String text;
|
private String text;
|
||||||
|
@Nullable
|
||||||
private List<String> tip;
|
private List<String> tip;
|
||||||
|
@Nullable
|
||||||
@ConfigNode("click.type")
|
@ConfigNode("click.type")
|
||||||
private String typestring;
|
private String typestring;
|
||||||
private transient CLICKTYPE type = CLICKTYPE.SUGGEST;
|
private transient CLICKTYPE type = CLICKTYPE.SUGGEST;
|
||||||
|
@Nullable
|
||||||
@ConfigNode("click.command")
|
@ConfigNode("click.command")
|
||||||
private String command;
|
private String command;
|
||||||
|
|
||||||
|
@ -1,7 +1,10 @@
|
|||||||
package pw.yumc.MiaoChat.config;
|
package pw.yumc.MiaoChat.config;
|
||||||
|
|
||||||
import org.bukkit.configuration.ConfigurationSection;
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
import pw.yumc.YumCore.config.Default;
|
||||||
|
import pw.yumc.YumCore.config.FileConfig;
|
||||||
import pw.yumc.YumCore.config.InjectConfigurationSection;
|
import pw.yumc.YumCore.config.InjectConfigurationSection;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -11,41 +14,60 @@ import pw.yumc.YumCore.config.InjectConfigurationSection;
|
|||||||
* @author 喵♂呜
|
* @author 喵♂呜
|
||||||
*/
|
*/
|
||||||
public class ChatRule extends InjectConfigurationSection {
|
public class ChatRule extends InjectConfigurationSection {
|
||||||
|
private transient String name;
|
||||||
|
@Default("50")
|
||||||
private Integer index;
|
private Integer index;
|
||||||
private String permission;
|
private String permission;
|
||||||
|
@Default("0")
|
||||||
private Integer range;
|
private Integer range;
|
||||||
private boolean item;
|
@Default("false")
|
||||||
|
private Boolean item;
|
||||||
|
@Default("&6[%s&6]&r")
|
||||||
|
private String itemformat;
|
||||||
|
private transient ChatConfig formats;
|
||||||
|
|
||||||
public ChatRule(final ConfigurationSection config) {
|
public ChatRule(final String name, final ConfigurationSection config) {
|
||||||
super(config);
|
super(config);
|
||||||
|
this.name = name;
|
||||||
|
if (permission == null) {
|
||||||
|
permission = String.format("MiaoChat.%s", name);
|
||||||
|
}
|
||||||
|
formats = new ChatConfig(new FileConfig(name + ".yml"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean check(final Player player) {
|
||||||
|
return player.hasPermission(permission);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ChatConfig getFormats() {
|
||||||
|
return formats;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return the index
|
|
||||||
*/
|
|
||||||
public Integer getIndex() {
|
public Integer getIndex() {
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public Boolean getItem() {
|
||||||
* @return the permission
|
return item;
|
||||||
*/
|
}
|
||||||
|
|
||||||
|
public String getItemformat() {
|
||||||
|
return itemformat;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
public String getPermission() {
|
public String getPermission() {
|
||||||
return permission;
|
return permission;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return the range
|
|
||||||
*/
|
|
||||||
public Integer getRange() {
|
public Integer getRange() {
|
||||||
return range;
|
return range;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return the item
|
|
||||||
*/
|
|
||||||
public boolean isItem() {
|
public boolean isItem() {
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,15 @@
|
|||||||
package pw.yumc.MiaoChat.config;
|
package pw.yumc.MiaoChat.config;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.Collections;
|
||||||
import java.util.Map;
|
import java.util.Comparator;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
import cn.citycraft.PluginHelper.config.FileConfig;
|
import pw.yumc.YumCore.bukkit.Log;
|
||||||
import pw.yumc.YumCore.bukkit.P;
|
import pw.yumc.YumCore.bukkit.P;
|
||||||
|
import pw.yumc.YumCore.config.FileConfig;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@ -14,10 +17,15 @@ import pw.yumc.YumCore.bukkit.P;
|
|||||||
* @author 喵♂呜
|
* @author 喵♂呜
|
||||||
*/
|
*/
|
||||||
public class Config {
|
public class Config {
|
||||||
FileConfig config = P.getConfig();
|
private static final String F = "Formats";
|
||||||
Map<String, ChatConfig> formats = new HashMap<>();
|
private final RuleComparator rulecomp;
|
||||||
|
private final List<ChatRule> rules;
|
||||||
|
private final FileConfig config;
|
||||||
|
|
||||||
public Config() {
|
public Config() {
|
||||||
|
config = P.getConfig();
|
||||||
|
rulecomp = new RuleComparator();
|
||||||
|
rules = new LinkedList<>();
|
||||||
reload();
|
reload();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -27,11 +35,30 @@ public class Config {
|
|||||||
* @param player
|
* @param player
|
||||||
* @return {@link ChatConfig}
|
* @return {@link ChatConfig}
|
||||||
*/
|
*/
|
||||||
public ChatConfig getChatConfig(final Player player) {
|
public ChatRule getChatRule(final Player player) {
|
||||||
|
for (final ChatRule cr : rules) {
|
||||||
|
Log.debug(cr.getName());
|
||||||
|
if (cr.check(player)) {
|
||||||
|
return cr;
|
||||||
|
}
|
||||||
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void reload() {
|
public void reload() {
|
||||||
|
rules.clear();
|
||||||
|
if (config.isSet(F)) {
|
||||||
|
for (final String rule : config.getConfigurationSection(F).getKeys(false)) {
|
||||||
|
rules.add(new ChatRule(rule, config.getConfigurationSection(F + "." + rule)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Collections.sort(rules, rulecomp);
|
||||||
|
}
|
||||||
|
|
||||||
|
private class RuleComparator implements Comparator<ChatRule> {
|
||||||
|
@Override
|
||||||
|
public int compare(final ChatRule o1, final ChatRule o2) {
|
||||||
|
return o1.getIndex().compareTo(o2.getIndex());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,21 +1,38 @@
|
|||||||
package pw.yumc.MiaoChat.listeners;
|
package pw.yumc.MiaoChat.listeners;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
import pw.yumc.MiaoChat.MiaoChat;
|
import pw.yumc.MiaoChat.MiaoChat;
|
||||||
import pw.yumc.MiaoChat.config.ChatConfig;
|
import pw.yumc.MiaoChat.config.ChatConfig;
|
||||||
import pw.yumc.MiaoChat.config.ChatMessagePart;
|
import pw.yumc.MiaoChat.config.ChatMessagePart;
|
||||||
|
import pw.yumc.MiaoChat.config.ChatRule;
|
||||||
|
import pw.yumc.YumCore.bukkit.Log;
|
||||||
import pw.yumc.YumCore.bukkit.P;
|
import pw.yumc.YumCore.bukkit.P;
|
||||||
|
import pw.yumc.YumCore.bukkit.compatible.C;
|
||||||
import pw.yumc.YumCore.statistic.Statistics;
|
import pw.yumc.YumCore.statistic.Statistics;
|
||||||
import pw.yumc.YumCore.tellraw.Tellraw;
|
import pw.yumc.YumCore.tellraw.Tellraw;
|
||||||
import pw.yumc.YumCore.update.SubscribeTask;
|
import pw.yumc.YumCore.update.SubscribeTask;
|
||||||
|
|
||||||
public class ChatListener implements Listener {
|
public class ChatListener implements Listener {
|
||||||
|
public static Set<String> offList = new HashSet<>();
|
||||||
|
static final Pattern ITEM_PATTERN = Pattern.compile("%([i1-9]?)");
|
||||||
|
|
||||||
MiaoChat plugin = P.getPlugin();
|
MiaoChat plugin = P.getPlugin();
|
||||||
|
|
||||||
public ChatListener() {
|
public ChatListener() {
|
||||||
@ -27,10 +44,11 @@ public class ChatListener implements Listener {
|
|||||||
@EventHandler
|
@EventHandler
|
||||||
public void onChat(final AsyncPlayerChatEvent e) {
|
public void onChat(final AsyncPlayerChatEvent e) {
|
||||||
final Player p = e.getPlayer();
|
final Player p = e.getPlayer();
|
||||||
final ChatConfig cc = plugin.getConfigExt().getChatConfig(e.getPlayer());
|
final ChatRule cr = plugin.getConfigExt().getChatRule(e.getPlayer());
|
||||||
if (cc == null) {
|
if (cr == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
final ChatConfig cc = cr.getFormats();
|
||||||
e.setCancelled(true);
|
e.setCancelled(true);
|
||||||
final String msg = e.getMessage();
|
final String msg = e.getMessage();
|
||||||
final Tellraw tr = Tellraw.create();
|
final Tellraw tr = Tellraw.create();
|
||||||
@ -41,7 +59,85 @@ public class ChatListener implements Listener {
|
|||||||
for (final ChatMessagePart cmp : cc.getSuffixs()) {
|
for (final ChatMessagePart cmp : cc.getSuffixs()) {
|
||||||
cmp.then(tr, p);
|
cmp.then(tr, p);
|
||||||
}
|
}
|
||||||
tr.then(ChatColor.translateAlternateColorCodes('&', msg));
|
final String message = ChatColor.translateAlternateColorCodes('&', msg);
|
||||||
tr.broadcast();
|
if (!message.isEmpty() && cr.isItem()) {
|
||||||
|
if (!handlerTellraw(p, tr, message, cr.getItemformat())) {
|
||||||
|
Log.toSender(p, "§c不允许展示相同的物品!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
final int range = cr.getRange();
|
||||||
|
Collection<? extends Entity> plist = Collections.emptyList();
|
||||||
|
if (range != 0) {
|
||||||
|
plist = p.getNearbyEntities(range, range, range);
|
||||||
|
} else {
|
||||||
|
plist = C.Player.getOnlinePlayers();
|
||||||
|
}
|
||||||
|
for (final Entity ne : plist) {
|
||||||
|
if (ne instanceof Player && !offList.contains(ne.getName())) {
|
||||||
|
tr.send(ne);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private LinkedList<String> handlerMessage(final LinkedList<String> il, String message) {
|
||||||
|
final LinkedList<String> mlist = new LinkedList<>();
|
||||||
|
if (!il.isEmpty()) {
|
||||||
|
for (final String k : il) {
|
||||||
|
final String[] args = message.split(k, 2);
|
||||||
|
mlist.add(args[0]);
|
||||||
|
mlist.add(k);
|
||||||
|
message = args[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!message.isEmpty()) {
|
||||||
|
mlist.add(message);
|
||||||
|
}
|
||||||
|
return mlist;
|
||||||
|
}
|
||||||
|
|
||||||
|
private LinkedList<String> handlerPattern(final String message) {
|
||||||
|
final Matcher m = ITEM_PATTERN.matcher(message);
|
||||||
|
final Set<String> temp = new HashSet<>();
|
||||||
|
final LinkedList<String> ilist = new LinkedList<>();
|
||||||
|
while (m.find()) {
|
||||||
|
final String key = m.group(0);
|
||||||
|
if (key.length() == 2) {
|
||||||
|
if (temp.add(key)) {
|
||||||
|
ilist.add(key);
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ilist;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean handlerTellraw(final Player player, final Tellraw tr, final String message, final String itemformat) {
|
||||||
|
final LinkedList<String> il = handlerPattern(message);
|
||||||
|
if (il == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final LinkedList<String> ml = handlerMessage(il, message);
|
||||||
|
while (!ml.isEmpty()) {
|
||||||
|
final String mm = ml.removeFirst();
|
||||||
|
if (il.contains(mm)) {
|
||||||
|
ItemStack is = null;
|
||||||
|
final char k = mm.charAt(1);
|
||||||
|
if (k == 'i') {
|
||||||
|
is = player.getItemInHand();
|
||||||
|
} else {
|
||||||
|
is = player.getInventory().getItem(k - '0' - 1);
|
||||||
|
}
|
||||||
|
if (is != null && is.getType() != Material.AIR) {
|
||||||
|
tr.then(String.format(ChatColor.translateAlternateColorCodes('&', itemformat),
|
||||||
|
is.hasItemMeta() && is.getItemMeta().hasDisplayName() ? is.getItemMeta().getDisplayName() : is.getType().name()));
|
||||||
|
tr.item(is);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
tr.then(mm);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
55
src/main/resources/admin.yml
Normal file
55
src/main/resources/admin.yml
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
#格式化配置
|
||||||
|
Format:
|
||||||
|
#前缀配置 于玩家名称前
|
||||||
|
Prefix:
|
||||||
|
0:
|
||||||
|
text: '&6[&c管理员&6]'
|
||||||
|
#顺序
|
||||||
|
1:
|
||||||
|
#文本 支持PAPI变量
|
||||||
|
text: '&6[&a%player_world%&6]'
|
||||||
|
#悬浮提示 支持PAPI
|
||||||
|
tip:
|
||||||
|
- '&6当前所在位置:'
|
||||||
|
- '&6世界: &d%player_world%'
|
||||||
|
- '&6坐标: &aX:%player_x% Y: %player_y% Z: %player_z%'
|
||||||
|
- ''
|
||||||
|
- '&c点击即可TP我!'
|
||||||
|
#点击操作
|
||||||
|
click:
|
||||||
|
#操作类型: [COMMAND,SUGGEST]
|
||||||
|
#COMMAND代表执行命令
|
||||||
|
#SUGGEST代表命令补全
|
||||||
|
type: 'COMMAND'
|
||||||
|
#命令 支持PAPI
|
||||||
|
command: '/tpa %player_name%'
|
||||||
|
# 可以添加多个
|
||||||
|
# 2:
|
||||||
|
# #文本 支持PAPI变量
|
||||||
|
# text: '&6[&a%player_world%&6]'
|
||||||
|
# #悬浮提示 支持PAPI
|
||||||
|
# tip: []
|
||||||
|
#玩家名称配置
|
||||||
|
Player:
|
||||||
|
text: '&b%player_name%'
|
||||||
|
tip:
|
||||||
|
- '&6玩家名称: &b%player_name%'
|
||||||
|
- '&6玩家等级: &a%player_level%'
|
||||||
|
- '&6玩家血量: &c%player_health%'
|
||||||
|
- '&6玩家饥饿: &d%player_food_level%'
|
||||||
|
- '&6游戏模式: &4%player_gamemode%'
|
||||||
|
- ''
|
||||||
|
- '&c点击与我聊天'
|
||||||
|
click:
|
||||||
|
type: 'SUGGEST'
|
||||||
|
command: '/tell %player_name%'
|
||||||
|
#后缀配置 于玩家名称后
|
||||||
|
Suffix:
|
||||||
|
1:
|
||||||
|
text: '&4[求助]&r '
|
||||||
|
tip:
|
||||||
|
- '点击求助OP'
|
||||||
|
click:
|
||||||
|
type: 'COMMAND'
|
||||||
|
command: '管理员@%player_name% 我需要你的帮助!'
|
||||||
|
#同样可以添加多个
|
@ -11,15 +11,19 @@ Formats:
|
|||||||
permission: 'MiaoChat.default'
|
permission: 'MiaoChat.default'
|
||||||
#范围(0为无限制)
|
#范围(0为无限制)
|
||||||
range: 0
|
range: 0
|
||||||
#解析物品(%i%=>手上物品,%0-9%快捷栏对应物品)
|
#解析物品(%i=>手上物品,%0-9快捷栏对应物品)
|
||||||
item: true
|
item: true
|
||||||
|
#物品解析规则
|
||||||
|
itemformat: '&6[&b%s&6]&r'
|
||||||
#格式名称 对应当前文件夹下的admin.yml
|
#格式名称 对应当前文件夹下的admin.yml
|
||||||
admin:
|
admin:
|
||||||
#优先级(将按照从小到大依次检测 比如 1-50 优先检测 1 符合则显示 不符合 检测 2 ...)
|
#优先级(将按照从小到大依次检测 比如 1-50 优先检测 1 符合则显示 不符合 检测 2 ...)
|
||||||
index: 49
|
index: 49
|
||||||
#权限
|
#权限
|
||||||
permission: 'MiaoChat.reload'
|
permission: 'MiaoChat.admin'
|
||||||
#范围(0为无限制)
|
#范围(0为无限制)
|
||||||
range: 0
|
range: 0
|
||||||
#解析物品(%i%=>手上物品,%0-9%快捷栏对应物品)
|
#解析物品(%i=>手上物品,%0-9快捷栏对应物品)
|
||||||
item: true
|
item: true
|
||||||
|
#物品解析规则
|
||||||
|
itemformat: '&6[&b%s&6]&r'
|
@ -19,6 +19,12 @@ permissions:
|
|||||||
${project.artifactId}.default:
|
${project.artifactId}.default:
|
||||||
description: 默认格式权限!
|
description: 默认格式权限!
|
||||||
default: true
|
default: true
|
||||||
|
${project.artifactId}.admin:
|
||||||
|
description: 管理员格式权限!
|
||||||
|
default: op
|
||||||
|
${project.artifactId}.toggle:
|
||||||
|
description: 开启关闭聊天!
|
||||||
|
default: true
|
||||||
${project.artifactId}.reload:
|
${project.artifactId}.reload:
|
||||||
description: 重新载入插件!
|
description: 重新载入插件!
|
||||||
default: op
|
default: op
|
Loading…
Reference in New Issue
Block a user