1
mirror of https://github.com/carm-outsource/TimeReward.git synced 2026-06-04 15:28:16 +08:00

7 Commits

Author SHA1 Message Date
Yurinann 7e598d1912 fix(message): 修正语言文件。 (#7) 2023-02-23 02:37:27 +08:00
carm 7e1b9e2542 chore(author): 添加作者名单 [ci skip] 2023-02-23 02:25:16 +08:00
carm cc0155b108 feat(claim): 添加自动领取签到奖励的开关与手动领取指令。(#4) 2023-02-23 01:41:58 +08:00
carm ab922f0eaa feat(claim): 添加自动领取签到奖励的开关与手动领取指令。(#4) 2023-02-23 01:41:28 +08:00
carm 77182148c5 Merge remote-tracking branch 'origin/master' 2023-02-23 00:56:32 +08:00
carm cd12f9383a feat(update): 适配最新依赖版本。 2023-02-23 00:56:13 +08:00
Yurinann 681a65230b fix(version): 适配 1.10- 版本的消息文本发送 (#6)
feat(command): 添加了指令权限判断与重载时的奖励数量反馈
2023-02-23 00:50:58 +08:00
16 changed files with 398 additions and 191 deletions
+9 -3
View File
@@ -43,6 +43,11 @@
- 必须参数 `<参数>` - 必须参数 `<参数>`
```text ```text
# claim [奖励ID]
@ 玩家指令
- 为自己手动领取对应奖励。
- 若不填写奖励ID,则自动领取全部可领取的奖励。
# reload # reload
@ 管理指令 (TimeReward.admin) @ 管理指令 (TimeReward.admin)
- 重载插件配置文件。 - 重载插件配置文件。
@@ -51,7 +56,7 @@
@ 管理指令 (TimeReward.admin) @ 管理指令 (TimeReward.admin)
- 查看用户的在线时长信息与奖励领取情况。 - 查看用户的在线时长信息与奖励领取情况。
# list # list
@ 管理指令 (TimeReward.admin) @ 管理指令 (TimeReward.admin)
- 列出所有奖励与条件。 - 列出所有奖励与条件。
@@ -75,8 +80,9 @@
# %TimeReward_claimed_<奖励ID>% # %TimeReward_claimed_<奖励ID>%
- 得到玩家是否已经领取了某个奖励。 - 得到玩家是否已经领取了某个奖励。
- * 也可以代表玩家是否可以领取某个奖励
- * 因为一旦可以领取就会自动领取,变为已领取状态 # %TimeReward_claimable_<奖励ID>%
- 得到玩家是否可以领取某个奖励
``` ```
## 配置文件 ## 配置文件
+1 -1
View File
@@ -18,7 +18,7 @@
<groupId>cc.carm.plugin</groupId> <groupId>cc.carm.plugin</groupId>
<artifactId>timereward</artifactId> <artifactId>timereward</artifactId>
<version>2.0.0</version> <version>2.1.0</version>
<name>TimeReward</name> <name>TimeReward</name>
<description>在线时长自动领奖插件,通过指令发放奖励,基于EasyPlugin实现。</description> <description>在线时长自动领奖插件,通过指令发放奖励,基于EasyPlugin实现。</description>
@@ -5,7 +5,7 @@ import cc.carm.lib.easyplugin.EasyPlugin;
import cc.carm.lib.easyplugin.updatechecker.GHUpdateChecker; import cc.carm.lib.easyplugin.updatechecker.GHUpdateChecker;
import cc.carm.lib.easyplugin.utils.MessageUtils; import cc.carm.lib.easyplugin.utils.MessageUtils;
import cc.carm.lib.mineconfiguration.bukkit.MineConfiguration; import cc.carm.lib.mineconfiguration.bukkit.MineConfiguration;
import cc.carm.plugin.timereward.command.TimeRewardCommand; import cc.carm.plugin.timereward.command.MainCommand;
import cc.carm.plugin.timereward.conf.PluginConfig; import cc.carm.plugin.timereward.conf.PluginConfig;
import cc.carm.plugin.timereward.conf.PluginMessages; import cc.carm.plugin.timereward.conf.PluginMessages;
import cc.carm.plugin.timereward.hooker.PAPIExpansion; import cc.carm.plugin.timereward.hooker.PAPIExpansion;
@@ -61,13 +61,13 @@ public class Main extends EasyPlugin {
log("加载奖励管理器..."); log("加载奖励管理器...");
this.rewardManager = new RewardManager(this); this.rewardManager = new RewardManager(this);
debug("加载了 " + this.rewardManager.listRewards().size() + " 个奖励配置。"); log("成功加载了 " + this.rewardManager.listRewards().size() + " 个奖励配置。");
log("注册监听器..."); log("注册监听器...");
registerListener(new UserListener()); registerListener(new UserListener());
log("注册指令..."); log("注册指令...");
registerCommand("TimeReward", new TimeRewardCommand()); registerCommand("TimeReward", new MainCommand(this));
if (MessageUtils.hasPlaceholderAPI()) { if (MessageUtils.hasPlaceholderAPI()) {
log("注册变量..."); log("注册变量...");
@@ -0,0 +1,37 @@
package cc.carm.plugin.timereward.command;
import cc.carm.lib.easyplugin.command.CommandHandler;
import cc.carm.plugin.timereward.command.sub.*;
import cc.carm.plugin.timereward.conf.PluginMessages;
import org.bukkit.command.CommandSender;
import org.bukkit.plugin.java.JavaPlugin;
import org.jetbrains.annotations.NotNull;
public class MainCommand extends CommandHandler {
public MainCommand(@NotNull JavaPlugin plugin) {
super(plugin);
registerSubCommand(new ClaimCommand(this, "claim"));
registerSubCommand(new ListCommand(this, "list"));
registerSubCommand(new UserCommand(this, "user"));
registerSubCommand(new TestCommand(this, "test"));
registerSubCommand(new ReloadCommand(this, "reload"));
}
@Override
public Void noArgs(CommandSender sender) {
if (sender.hasPermission("TimeReward.admin")) {
PluginMessages.USAGE.ADMIN.send(sender);
} else {
PluginMessages.USAGE.USER.send(sender);
}
return null;
}
@Override
public Void noPermission(CommandSender sender) {
PluginMessages.NO_PERMISSION.send(sender);
return null;
}
}
@@ -1,141 +0,0 @@
package cc.carm.plugin.timereward.command;
import cc.carm.plugin.timereward.Main;
import cc.carm.plugin.timereward.TimeRewardAPI;
import cc.carm.plugin.timereward.conf.PluginMessages;
import cc.carm.plugin.timereward.storage.RewardContents;
import cc.carm.plugin.timereward.storage.UserData;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.command.TabCompleter;
import org.bukkit.entity.HumanEntity;
import org.bukkit.entity.Player;
import org.bukkit.util.StringUtil;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.stream.Collectors;
public class TimeRewardCommand implements CommandExecutor, TabCompleter {
private boolean help(CommandSender sender) {
PluginMessages.COMMAND_USAGE.send(sender);
return true;
}
@Override
public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String alias, String[] args) {
if (args.length < 1) return help(sender);
String aim = args[0];
if (aim.equalsIgnoreCase("reload")) {
long s1 = System.currentTimeMillis();
PluginMessages.RELOAD.START.send(sender);
try {
Main.getInstance().getConfigProvider().reload();
Main.getInstance().getMessageProvider().reload();
PluginMessages.RELOAD.COMPLETE.send(sender, System.currentTimeMillis() - s1);
} catch (Exception e) {
PluginMessages.RELOAD.ERROR.send(sender);
e.printStackTrace();
}
return true;
} else if (aim.equalsIgnoreCase("list")) {
Collection<RewardContents> awards = TimeRewardAPI.getRewardManager().listRewards().values();
PluginMessages.LIST.HEADER.send(sender, awards.size());
for (RewardContents reward : awards) {
if (reward.getPermission() != null) {
PluginMessages.LIST.OBJECT_PERM.send(sender,
reward.getRewardID(), reward.getDisplayName(),
reward.getTime(), reward.getPermission()
);
} else {
PluginMessages.LIST.OBJECT.send(sender,
reward.getRewardID(), reward.getDisplayName(), reward.getTime()
);
}
}
return true;
} else if (aim.equalsIgnoreCase("test")) {
if (args.length < 2) return help(sender);
if (!(sender instanceof Player)) {
PluginMessages.NOT_PLAYER.send(sender);
return true;
}
RewardContents contents = TimeRewardAPI.getRewardManager().getReward(args[1]);
if (contents == null) {
PluginMessages.NOT_EXISTS.send(sender, args[1]);
return true;
}
PluginMessages.COMMAND_LIST.send(sender, contents.getRewardID());
TimeRewardAPI.getRewardManager().executeCommand((Player) sender, contents);
return true;
} else if (aim.equalsIgnoreCase("user")) {
if (args.length < 2) return help(sender);
Player player = Bukkit.getPlayer(args[1]);
if (player == null) {
PluginMessages.NOT_ONLINE.send(sender, args[1]);
return true;
}
UserData user = TimeRewardAPI.getUserManager().getData(player);
PluginMessages.USER_INFO.send(sender,
player.getName(), user.getAllSeconds(),
user.getClaimedRewards().size(), String.join("&8, &f", user.getClaimedRewards())
);
return true;
}
return help(sender);
}
@Override
public @Nullable List<String> onTabComplete(@NotNull CommandSender sender, @NotNull Command command, @NotNull String alias, @NotNull String[] args) {
List<String> allCompletes = new ArrayList<>();
// 玩家指令部分
if (sender.hasPermission("TimeReward.admin")) {
switch (args.length) {
case 1: {
allCompletes.add("reload");
allCompletes.add("user");
allCompletes.add("list");
if (sender instanceof Player) allCompletes.add("test");
break;
}
case 2: {
String aim = args[0];
if (aim.equalsIgnoreCase("test") && sender instanceof Player) {
allCompletes = new ArrayList<>(TimeRewardAPI.getRewardManager().listRewards().keySet());
} else if (aim.equalsIgnoreCase("user")) {
allCompletes = Bukkit.getOnlinePlayers().stream().map(HumanEntity::getName).collect(Collectors.toList());
}
break;
}
default: {
break;
}
}
}
return allCompletes.stream()
.filter(s -> StringUtil.startsWithIgnoreCase(s, args[args.length - 1]))
.limit(10).collect(Collectors.toList());
}
}
@@ -0,0 +1,64 @@
package cc.carm.plugin.timereward.command.sub;
import cc.carm.lib.easyplugin.command.SubCommand;
import cc.carm.plugin.timereward.Main;
import cc.carm.plugin.timereward.TimeRewardAPI;
import cc.carm.plugin.timereward.command.MainCommand;
import cc.carm.plugin.timereward.conf.PluginMessages;
import cc.carm.plugin.timereward.manager.RewardManager;
import cc.carm.plugin.timereward.storage.RewardContents;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.plugin.java.JavaPlugin;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.List;
public class ClaimCommand extends SubCommand<MainCommand> {
public ClaimCommand(@NotNull MainCommand parent, String identifier, String... aliases) {
super(parent, identifier, aliases);
}
@Override
public Void execute(JavaPlugin plugin, CommandSender sender, String[] args) {
if (!(sender instanceof Player)) {
PluginMessages.NOT_PLAYER.send(sender);
return null;
}
Player player = (Player) sender;
RewardManager manager = TimeRewardAPI.getRewardManager();
@Nullable String rewardID = args.length > 0 ? args[0] : null;
if (rewardID == null) {
List<RewardContents> unclaimedRewards = manager.getUnclaimedRewards(player);
if (unclaimedRewards.isEmpty()) {
PluginMessages.NO_UNCLAIMED_REWARD.send(sender);
return null;
}
Main.getInstance().getScheduler().run(() -> unclaimedRewards.forEach(
// 在同步进程中为玩家发放奖励
unclaimedReward -> manager.claimReward(player, unclaimedReward, false)
));
} else {
RewardContents reward = manager.getReward(rewardID);
if (reward == null) {
PluginMessages.NOT_EXISTS.send(sender, rewardID);
return null;
}
if (!manager.isClaimable(player, reward)) {
PluginMessages.NOT_CLAIMABLE.send(sender, reward.getDisplayName());
return null;
}
Main.getInstance().getScheduler().run(() -> manager.claimReward(player, reward, false));
}
return null;
}
}
@@ -0,0 +1,45 @@
package cc.carm.plugin.timereward.command.sub;
import cc.carm.lib.easyplugin.command.SubCommand;
import cc.carm.plugin.timereward.TimeRewardAPI;
import cc.carm.plugin.timereward.command.MainCommand;
import cc.carm.plugin.timereward.conf.PluginMessages;
import cc.carm.plugin.timereward.storage.RewardContents;
import org.bukkit.command.CommandSender;
import org.bukkit.plugin.java.JavaPlugin;
import org.jetbrains.annotations.NotNull;
import java.util.Collection;
public class ListCommand extends SubCommand<MainCommand> {
public ListCommand(@NotNull MainCommand parent, String identifier, String... aliases) {
super(parent, identifier, aliases);
}
@Override
public Void execute(JavaPlugin plugin, CommandSender sender, String[] args) {
Collection<RewardContents> awards = TimeRewardAPI.getRewardManager().listRewards().values();
PluginMessages.LIST.HEADER.send(sender, awards.size());
for (RewardContents reward : awards) {
if (reward.getPermission() != null) {
PluginMessages.LIST.OBJECT_PERM.send(sender,
reward.getRewardID(), reward.getDisplayName(),
reward.getTime(), reward.getPermission()
);
} else {
PluginMessages.LIST.OBJECT.send(sender,
reward.getRewardID(), reward.getDisplayName(), reward.getTime()
);
}
}
return null;
}
@Override
public boolean hasPermission(@NotNull CommandSender sender) {
return sender.hasPermission("TimeReward.admin");
}
}
@@ -0,0 +1,41 @@
package cc.carm.plugin.timereward.command.sub;
import cc.carm.lib.easyplugin.command.SubCommand;
import cc.carm.plugin.timereward.Main;
import cc.carm.plugin.timereward.TimeRewardAPI;
import cc.carm.plugin.timereward.command.MainCommand;
import cc.carm.plugin.timereward.conf.PluginMessages;
import org.bukkit.command.CommandSender;
import org.bukkit.plugin.java.JavaPlugin;
import org.jetbrains.annotations.NotNull;
public class ReloadCommand extends SubCommand<MainCommand> {
public ReloadCommand(@NotNull MainCommand parent, String identifier, String... aliases) {
super(parent, identifier, aliases);
}
@Override
public Void execute(JavaPlugin plugin, CommandSender sender, String[] args) throws Exception {
long s1 = System.currentTimeMillis();
PluginMessages.RELOAD.START.send(sender);
try {
Main.getInstance().getConfigProvider().reload();
Main.getInstance().getMessageProvider().reload();
PluginMessages.RELOAD.COMPLETE.send(sender, System.currentTimeMillis() - s1, TimeRewardAPI.getRewardManager().listRewards().size());
} catch (Exception e) {
PluginMessages.RELOAD.ERROR.send(sender);
e.printStackTrace();
}
return null;
}
@Override
public boolean hasPermission(@NotNull CommandSender sender) {
return sender.hasPermission("TimeReward.admin");
}
}
@@ -0,0 +1,55 @@
package cc.carm.plugin.timereward.command.sub;
import cc.carm.lib.easyplugin.command.SimpleCompleter;
import cc.carm.lib.easyplugin.command.SubCommand;
import cc.carm.plugin.timereward.TimeRewardAPI;
import cc.carm.plugin.timereward.command.MainCommand;
import cc.carm.plugin.timereward.conf.PluginMessages;
import cc.carm.plugin.timereward.storage.RewardContents;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.plugin.java.JavaPlugin;
import org.jetbrains.annotations.NotNull;
import java.util.List;
public class TestCommand extends SubCommand<MainCommand> {
public TestCommand(@NotNull MainCommand parent, String identifier, String... aliases) {
super(parent, identifier, aliases);
}
@Override
public Void execute(JavaPlugin plugin, CommandSender sender, String[] args) throws Exception {
if (args.length < 1) return getParent().noArgs(sender);
if (!(sender instanceof Player)) {
PluginMessages.NOT_PLAYER.send(sender);
return null;
}
RewardContents contents = TimeRewardAPI.getRewardManager().getReward(args[0]);
if (contents == null) {
PluginMessages.NOT_EXISTS.send(sender, args[0]);
return null;
}
PluginMessages.COMMAND_LIST.send(sender, contents.getRewardID());
TimeRewardAPI.getRewardManager().executeCommand((Player) sender, contents);
return null;
}
@Override
public List<String> tabComplete(JavaPlugin plugin, CommandSender sender, String[] args) {
if (args.length == 1) {
return SimpleCompleter.text(args[args.length - 1], TimeRewardAPI.getRewardManager().listRewards().keySet());
} else return null;
}
@Override
public boolean hasPermission(@NotNull CommandSender sender) {
return sender.hasPermission("TimeReward.admin");
}
}
@@ -0,0 +1,52 @@
package cc.carm.plugin.timereward.command.sub;
import cc.carm.lib.easyplugin.command.SimpleCompleter;
import cc.carm.lib.easyplugin.command.SubCommand;
import cc.carm.plugin.timereward.TimeRewardAPI;
import cc.carm.plugin.timereward.command.MainCommand;
import cc.carm.plugin.timereward.conf.PluginMessages;
import cc.carm.plugin.timereward.storage.UserData;
import org.bukkit.Bukkit;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.plugin.java.JavaPlugin;
import org.jetbrains.annotations.NotNull;
import java.util.List;
public class UserCommand extends SubCommand<MainCommand> {
public UserCommand(@NotNull MainCommand parent, String identifier, String... aliases) {
super(parent, identifier, aliases);
}
@Override
public Void execute(JavaPlugin plugin, CommandSender sender, String[] args) throws Exception {
if (args.length < 1) return getParent().noArgs(sender);
Player player = Bukkit.getPlayer(args[0]);
if (player == null) {
PluginMessages.NOT_ONLINE.send(sender, args[0]);
return null;
}
UserData user = TimeRewardAPI.getUserManager().getData(player);
PluginMessages.USER_INFO.send(sender,
player.getName(), user.getAllSeconds(),
user.getClaimedRewards().size(), String.join("&8, &f", user.getClaimedRewards())
);
return null;
}
@Override
public List<String> tabComplete(JavaPlugin plugin, CommandSender sender, String[] args) {
if (args.length == 1) return SimpleCompleter.onlinePlayers(args[0]);
else return null;
}
@Override
public boolean hasPermission(@NotNull CommandSender sender) {
return sender.hasPermission("TimeReward.admin");
}
}
@@ -0,0 +1,17 @@
package cc.carm.plugin.timereward.conf;
import cc.carm.lib.configuration.core.ConfigurationRoot;
import cc.carm.lib.configuration.core.annotation.HeaderComment;
import cc.carm.lib.configuration.core.value.ConfigValue;
import cc.carm.lib.configuration.core.value.type.ConfiguredValue;
public class FunctionConfig extends ConfigurationRoot {
@HeaderComment({
"是否启用自动领取",
"启用后,玩家将会在满足奖励领取条件时自动领取奖励。",
"若关闭,则玩家需要手动输入指令领取奖励。"
})
public static final ConfigValue<Boolean> AUTO_CLAIM = ConfiguredValue.of(Boolean.class, true);
}
@@ -24,9 +24,7 @@ public class PluginConfig extends ConfigurationRoot {
}) })
public static final ConfigValue<Boolean> CHECK_UPDATE = ConfiguredValue.of(Boolean.class, true); public static final ConfigValue<Boolean> CHECK_UPDATE = ConfiguredValue.of(Boolean.class, true);
@HeaderComment("数据存储相关设定") public static final Class<?> FUNCTIONS = FunctionConfig.class;
public static final class STORAGE extends ConfigurationRoot {
}
@HeaderComment({"奖励相关设定,包含以下设定:", @HeaderComment({"奖励相关设定,包含以下设定:",
" [id] 配置键名即奖励ID,支持英文、数字与下划线。", " [id] 配置键名即奖励ID,支持英文、数字与下划线。",
@@ -4,15 +4,13 @@ import cc.carm.lib.configuration.core.ConfigurationRoot;
import cc.carm.lib.configuration.core.annotation.HeaderComment; import cc.carm.lib.configuration.core.annotation.HeaderComment;
import cc.carm.lib.easyplugin.utils.ColorParser; import cc.carm.lib.easyplugin.utils.ColorParser;
import cc.carm.lib.mineconfiguration.bukkit.builder.message.CraftMessageListBuilder; import cc.carm.lib.mineconfiguration.bukkit.builder.message.CraftMessageListBuilder;
import cc.carm.lib.mineconfiguration.bukkit.builder.message.CraftMessageValueBuilder;
import cc.carm.lib.mineconfiguration.bukkit.builder.title.TitleConfigBuilder;
import cc.carm.lib.mineconfiguration.bukkit.value.ConfiguredMessage;
import cc.carm.lib.mineconfiguration.bukkit.value.ConfiguredMessageList; import cc.carm.lib.mineconfiguration.bukkit.value.ConfiguredMessageList;
import cc.carm.lib.mineconfiguration.bukkit.value.ConfiguredTitle;
import de.themoep.minedown.MineDown; import de.themoep.minedown.MineDown;
import me.clip.placeholderapi.PlaceholderAPI; import me.clip.placeholderapi.PlaceholderAPI;
import net.md_5.bungee.api.chat.BaseComponent; import net.md_5.bungee.api.chat.BaseComponent;
import net.md_5.bungee.api.chat.TextComponent;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.command.ConsoleCommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
@@ -22,23 +20,21 @@ import java.util.function.BiFunction;
@HeaderComment({ @HeaderComment({
"TimeReward 在线奖励插件的消息配置文件", "TimeReward 在线奖励插件的消息配置文件",
"如特定的消息不需要任何提示,可直接留下单行空内容消息。", "如特定的消息不需要任何提示,可直接留下单行空内容消息。",
"支持 支持 &+颜色代码(原版颜色)、§(#XXXXXX)(RGB颜色) 与 &<#XXXXXX>(前后标注RGB颜色渐变)。", "支持 &+颜色代码(原版颜色)、&(#XXXXXX)(RGB颜色) 与 &<#XXXXXX>(前后标注RGB颜色渐变)。",
" " " "
}) })
public class PluginMessages extends ConfigurationRoot { public class PluginMessages extends ConfigurationRoot {
public static @NotNull CraftMessageListBuilder<BaseComponent[]> list() { public static @NotNull CraftMessageListBuilder<BaseComponent[]> list() {
return ConfiguredMessageList.create(getParser()) return ConfiguredMessageList.create(getParser())
.whenSend((sender, message) -> message.forEach(m -> sender.spigot().sendMessage(m))); .whenSend((sender, message) -> {
} if (sender instanceof ConsoleCommandSender) {
message.forEach(m -> sender.sendMessage(TextComponent.toLegacyText(m)));
public static @NotNull CraftMessageValueBuilder<BaseComponent[]> value() { return;
return ConfiguredMessage.create(getParser()) }
.whenSend((sender, message) -> sender.spigot().sendMessage(message)); Player player = (Player) sender;
} message.forEach(m -> player.spigot().sendMessage(m));
});
public static @NotNull TitleConfigBuilder title() {
return ConfiguredTitle.create().whenSend((player, in, stay, out, line1, line2) -> player.sendTitle(line1, line2, in, stay, out));
} }
public static @NotNull BiFunction<CommandSender, String, BaseComponent[]> getParser() { public static @NotNull BiFunction<CommandSender, String, BaseComponent[]> getParser() {
@@ -48,6 +44,28 @@ public class PluginMessages extends ConfigurationRoot {
}; };
} }
public static final class USAGE extends ConfigurationRoot {
public static final ConfiguredMessageList<BaseComponent[]> ADMIN = list().defaults(
"&6&l在线奖励 &f管理员指令帮助",
"&8#&f claim &6[奖励ID]",
"&8-&7 为自己手动领取对应奖励。",
"&8-&7 若不填写奖励ID,则自动领取全部可领取的奖励。",
"&8#&f reload",
"&8-&7 重载插件配置文件。",
"&8#&f user &6<玩家>",
"&8-&7 查看用户的在线时长信息与奖励领取情况。",
"&8#&f list",
"&8-&7 列出所有奖励与条件。",
"&8#&f test &6<奖励ID>",
"&8-&7 测试执行奖励配置的指令。"
).build();
public static final ConfiguredMessageList<BaseComponent[]> USER = list().defaults(
"&6&l在线奖励 &f您可以输入 &e/tr claim &6[奖励ID] &f领取对应奖励。"
).build();
}
public static final ConfiguredMessageList<BaseComponent[]> NO_PERMISSION = list().defaults( public static final ConfiguredMessageList<BaseComponent[]> NO_PERMISSION = list().defaults(
"&c&l抱歉!&f但您没有足够的权限使用该指令。" "&c&l抱歉!&f但您没有足够的权限使用该指令。"
).build(); ).build();
@@ -64,6 +82,14 @@ public class PluginMessages extends ConfigurationRoot {
"&f奖励 &e%(award) &f并不存在。" "&f奖励 &e%(award) &f并不存在。"
).params("award").build(); ).params("award").build();
public static final ConfiguredMessageList<BaseComponent[]> NOT_CLAIMABLE = list().defaults(
"&c&l抱歉!&f但您暂时未满足领取奖励 &e%(award) &f的条件。"
).params("award").build();
public static final ConfiguredMessageList<BaseComponent[]> NO_UNCLAIMED_REWARD = list().defaults(
"&f您暂时没有未领取的奖励。"
).build();
public static final ConfiguredMessageList<BaseComponent[]> USER_INFO = list().defaults( public static final ConfiguredMessageList<BaseComponent[]> USER_INFO = list().defaults(
"&f玩家 &6%(player) &f已在线&e%(time)&f秒,共领取了 &e%(amount)&f 次奖励。", "&f玩家 &6%(player) &f已在线&e%(time)&f秒,共领取了 &e%(amount)&f 次奖励。",
"&7已领取的奖励列表如下:&r%(rewards) &7。" "&7已领取的奖励列表如下:&r%(rewards) &7。"
@@ -73,18 +99,6 @@ public class PluginMessages extends ConfigurationRoot {
"&f正在执行奖励 %(award) 的指令列表..." "&f正在执行奖励 %(award) 的指令列表..."
).params("award").build(); ).params("award").build();
public static final ConfiguredMessageList<BaseComponent[]> COMMAND_USAGE = list().defaults(
"&6&l在线奖励 &f指令帮助",
"&8#&f reload",
"&8-&7 重载插件配置文件。",
"&8#&f user &6<玩家>",
"&8-&7 查看用户的在线时长信息与奖励领取情况。",
"&8#&f listUserData",
"&8-&7 列出所有奖励与条件。",
"&8#&f test &6<奖励ID>",
"&8-&7 测试执行奖励配置的指令。"
).build();
public static class LIST extends ConfigurationRoot { public static class LIST extends ConfigurationRoot {
@@ -118,8 +132,8 @@ public class PluginMessages extends ConfigurationRoot {
).build(); ).build();
public static final ConfiguredMessageList<BaseComponent[]> COMPLETE = list().defaults( public static final ConfiguredMessageList<BaseComponent[]> COMPLETE = list().defaults(
"&f配置文件重载完成,共耗时 &d%(time)&fms " "&f配置文件重载完成耗时 &d%(time)&fms,共加载了 &d%(count) &f个奖励配置"
).params("time").build(); ).params("time", "count").build();
} }
@@ -19,14 +19,27 @@ public class PAPIExpansion extends EasyPlaceholder {
super(plugin, rootIdentifier); super(plugin, rootIdentifier);
handle("time", userHandler(UserData::getAllSeconds)); handle("time", userHandler(UserData::getAllSeconds));
handle("reward", handle("reward",
rewardHandler(RewardContents::getDisplayName), rewardHandler(RewardContents::getDisplayName),
Collections.singletonList("<奖励ID>") Collections.singletonList("<奖励ID>")
); );
handle("claimed", userHandler((user, args) -> { handle("claimed", userHandler((user, args) -> {
if (args.length < 1) return "请填写奖励ID"; if (args.length < 1) return "请填写奖励ID";
else return user.isClaimed(args[0]); else return user.isClaimed(args[0]);
}), Collections.singletonList("<奖励ID>")); }), Collections.singletonList("<奖励ID>"));
handle("claimable", (offlinePlayer, args) -> {
if (offlinePlayer == null || !offlinePlayer.isOnline()) return "加载中...";
if (args.length < 1) return "请填写奖励ID";
RewardContents reward = TimeRewardAPI.getRewardManager().getReward(args[0]);
if (reward == null) return "奖励不存在";
return TimeRewardAPI.getRewardManager().isClaimable((Player) offlinePlayer, reward);
}, Collections.singletonList("<奖励ID>"));
handle("version", (player, args) -> getVersion()); handle("version", (player, args) -> getVersion());
} }
@@ -3,6 +3,7 @@ package cc.carm.plugin.timereward.manager;
import cc.carm.lib.easyplugin.utils.MessageUtils; import cc.carm.lib.easyplugin.utils.MessageUtils;
import cc.carm.plugin.timereward.Main; import cc.carm.plugin.timereward.Main;
import cc.carm.plugin.timereward.TimeRewardAPI; import cc.carm.plugin.timereward.TimeRewardAPI;
import cc.carm.plugin.timereward.conf.FunctionConfig;
import cc.carm.plugin.timereward.conf.PluginConfig; import cc.carm.plugin.timereward.conf.PluginConfig;
import cc.carm.plugin.timereward.storage.RewardContents; import cc.carm.plugin.timereward.storage.RewardContents;
import cc.carm.plugin.timereward.storage.UserData; import cc.carm.plugin.timereward.storage.UserData;
@@ -26,6 +27,7 @@ public class RewardManager {
this.runnable = new BukkitRunnable() { this.runnable = new BukkitRunnable() {
@Override @Override
public void run() { public void run() {
if (!FunctionConfig.AUTO_CLAIM.getNotNull()) return;
if (Bukkit.getOnlinePlayers().isEmpty()) return; if (Bukkit.getOnlinePlayers().isEmpty()) return;
for (Player player : Bukkit.getOnlinePlayers()) { for (Player player : Bukkit.getOnlinePlayers()) {
@@ -61,21 +63,23 @@ public class RewardManager {
@Unmodifiable @Unmodifiable
public @NotNull List<RewardContents> getUnclaimedRewards(@NotNull Player player) { public @NotNull List<RewardContents> getUnclaimedRewards(@NotNull Player player) {
UserData user = TimeRewardAPI.getUserManager().getData(player);
return listRewards().values().stream() return listRewards().values().stream()
.filter(reward -> reward.isTimeEnough(user.getAllSeconds())) // 时间足够 .filter(reward -> isClaimable(player, reward))
.filter(reward -> !user.isClaimed(reward.getRewardID())) // 未曾领取
.filter(reward -> reward.checkPermission(player)) // 满足权限
.collect(Collectors.toList()); .collect(Collectors.toList());
} }
public boolean claimReward(Player player, RewardContents reward, boolean check) {
UserData user = TimeRewardAPI.getUserManager().getData(player);
if (check && user.isClaimed(reward.getRewardID())) return false;
if (check && !reward.isTimeEnough(user.getAllSeconds())) return false;
if (check && !reward.checkPermission(player)) return false;
user.addClaimedReward(reward.getRewardID()); public boolean isClaimable(Player player, RewardContents reward) {
UserData user = TimeRewardAPI.getUserManager().getData(player);
return !user.isClaimed(reward.getRewardID()) // 未曾领取
&& reward.isTimeEnough(user.getAllSeconds()) // 时间足够
&& reward.checkPermission(player); // 满足权限
}
public boolean claimReward(Player player, RewardContents reward, boolean check) {
if (check && !isClaimable(player, reward)) return false;
TimeRewardAPI.getUserManager().getData(player).addClaimedReward(reward.getRewardID());
executeCommand(player, reward); executeCommand(player, reward);
return true; return true;
} }
+3 -1
View File
@@ -1,7 +1,9 @@
main: cc.carm.plugin.timereward.Main main: cc.carm.plugin.timereward.Main
name: TimeReward name: TimeReward
version: ${project.version} version: ${project.version}
author: CarmJos authors:
- CarmJos
- Yurinann
website: ${project.url} website: ${project.url}
description: ${project.description} description: ${project.description}