Compare commits

...

16 Commits

Author SHA1 Message Date
Deauthorized 170a671f7e
Merge 87d94909bc into 315e16488b 2024-04-28 03:02:45 -04:00
Deauthorized 87d94909bc
Update ToggleCMD.java / requested changes 2024-04-28 03:02:43 -04:00
Deauthorized 99c70eb713
Update ToggleMenu.java / requested changes 2024-04-28 03:02:14 -04:00
Deauthorized e79141b415
Update messages.yml / requested changes 2024-04-28 03:01:42 -04:00
Deauthorized 810a547059
Update ToggleCMD.java / requested changes 2024-04-28 02:08:31 -04:00
Deauthorized 4a1f2bd3e3
Update TogglesListener.java / requested changes 2024-04-28 02:08:02 -04:00
Deauthorized 947332307d
Update ToggleMenu.java / requested changes 2024-04-28 02:07:12 -04:00
Deauthorized 90d69dbcc3
Update commands.yml / requested changes 2024-04-28 02:06:33 -04:00
Deauthorized b286ee01ff
Update messages.yml / requested changes 2024-04-28 02:06:13 -04:00
Deauthorized d6837b8b27
Update toggles.yml / requested changes 2024-04-28 02:05:55 -04:00
Deauthorized 47bd1b6170
Add the restricted chat toggle to the consoles version of the command as well 2024-04-27 22:41:09 -04:00
Deauthorized 0b824fc7fd
Add the restricted chat toggle to the toggle gui 2024-04-27 22:40:03 -04:00
Deauthorized 49b0d3a5d2
Implement the restricted chat toggle 2024-04-27 22:39:29 -04:00
Deauthorized ad9aa32831
Add block_on_modmode list for commands to block, should be separate from block_on_mute so pms can still work 2024-04-27 22:38:20 -04:00
Deauthorized 2580c05404
Add new messages to messages.yml for modmode toggle 2024-04-27 22:37:24 -04:00
Deauthorized 38d6e043f2
Add moderated mode toggle option 2024-04-27 22:36:40 -04:00
6 changed files with 86 additions and 3 deletions

View File

@ -32,6 +32,7 @@ public class ToggleCMD extends PlexCommand
sender.sendMessage(PlexUtils.mmDeserialize("<gray> - Fluidspread" + status("fluidspread")));
sender.sendMessage(PlexUtils.mmDeserialize("<gray> - Drops" + status("drops")));
sender.sendMessage(PlexUtils.mmDeserialize("<gray> - Redstone" + status("redstone")));
sender.sendMessage(PlexUtils.mmDeserialize("<gray> - Chat" + status("chat")));
return null;
}
switch (args[0].toLowerCase())
@ -52,6 +53,11 @@ public class ToggleCMD extends PlexCommand
{
return toggle("redstone");
}
case "chat" ->
{
PlexUtils.broadcast(PlexUtils.messageComponent("chatToggled", sender.getName(), plugin.toggles.getBoolean("chat") ? "off" : "on"));
return toggle("chat");
}
default ->
{
return messageComponent("invalidToggle");

View File

@ -1,6 +1,12 @@
package dev.plex.listener.impl;
import dev.plex.Plex;
import dev.plex.listener.PlexListener;
import dev.plex.util.PlexUtils;
import io.papermc.paper.event.player.AsyncChatEvent;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.block.BlockExplodeEvent;
import org.bukkit.event.block.BlockFromToEvent;
@ -8,9 +14,13 @@ import org.bukkit.event.block.BlockRedstoneEvent;
import org.bukkit.event.entity.EntityExplodeEvent;
import org.bukkit.event.entity.ExplosionPrimeEvent;
import org.bukkit.event.player.PlayerDropItemEvent;
import org.bukkit.event.player.PlayerCommandPreprocessEvent;
import java.util.List;
public class TogglesListener extends PlexListener
{
List<String> commands = plugin.commands.getStringList("block_on_mute");
@EventHandler
public void onExplosionPrime(ExplosionPrimeEvent event)
{
@ -58,6 +68,48 @@ public class TogglesListener extends PlexListener
}
}
@EventHandler
public void onChat(AsyncChatEvent event)
{
Player player = event.getPlayer();
if (!plugin.toggles.getBoolean("chat") && !Plex.get().getPermissions().has(player, "plex.mute.bypass"))
{
event.getPlayer().sendMessage(PlexUtils.messageComponent("chatIsOff"));
event.setCancelled(true);
}
}
@EventHandler
public void onCommand(PlayerCommandPreprocessEvent event)
{
Player player = event.getPlayer();
if (!plugin.toggles.getBoolean("chat") && !Plex.get().getPermissions().has(player, "plex.mute.bypass"))
{
String message = event.getMessage();
message = message.replaceAll("\\s.*", "").replaceFirst("/", "");
if (commands.contains(message.toLowerCase()))
{
event.getPlayer().sendMessage(PlexUtils.messageComponent("chatIsOff"));
event.setCancelled(true);
return;
}
for (String command : commands)
{
Command cmd = Bukkit.getCommandMap().getCommand(command);
if (cmd == null) {
return;
}
if (cmd.getAliases().contains(message.toLowerCase())) {
event.getPlayer().sendMessage(PlexUtils.messageComponent("chatIsOff"));
event.setCancelled(true);
return;
}
}
}
}
/* I have no idea if this is the best way to do this
There is a very weird bug where if you try to create a loop using two repeaters and a lever, after disabling
and re-enabling redstone, you are unable to recreate the loop with a lever. Using a redstone torch works fine.

View File

@ -24,6 +24,7 @@ public class ToggleMenu extends AbstractMenu
resetFluidspreadItem(this.inventory());
resetDropsItem(this.inventory());
resetRedstoneItem(this.inventory());
resetChatItem(this.inventory());
}
private void resetExplosionItem(Inventory inventory)
@ -66,6 +67,16 @@ public class ToggleMenu extends AbstractMenu
inventory.setItem(3, redstone);
}
private void resetChatItem(Inventory inventory)
{
ItemStack chat = new ItemStack(Material.OAK_SIGN);
ItemMeta chatItemMeta = chat.getItemMeta();
chatItemMeta.displayName(PlexUtils.mmDeserialize("<!italic><light_purple>Toggle chat"));
chatItemMeta.lore(List.of(PlexUtils.mmDeserialize("<!italic><yellow>Chat is currently " + (plugin.toggles.getBoolean("chat") ? "<green>on" : "<red>off"))));
chat.setItemMeta(chatItemMeta);
inventory.setItem(4, chat);
}
@Override
public boolean onClick(InventoryView view, Inventory inventory, Player player, ItemStack clicked)
{
@ -93,6 +104,13 @@ public class ToggleMenu extends AbstractMenu
resetRedstoneItem(inventory);
player.sendMessage(PlexUtils.mmDeserialize("<gray>Toggled redstone."));
}
if (clicked.getType() == Material.OAK_SIGN)
{
plugin.toggles.set("chat", !plugin.toggles.getBoolean("chat"));
PlexUtils.broadcast(PlexUtils.messageComponent("chatToggled", player.getName(), plugin.toggles.getBoolean("chat") ? "on" : "off"));
resetChatItem(inventory);
player.sendMessage(PlexUtils.mmDeserialize("<gray>Toggled chat."));
}
return true;
}
}

View File

@ -54,10 +54,10 @@ commands:
- "r:a:^(co|core|coreprotect) (rb|rollback|l|lookup|rl|reload):_"
- "r:e:^[A-z]*:[A-z]*::<gray>Plugin specific commands are disabled."
# These commands will be blocked when a player is muted
# These commands will be blocked when a player is muted or when chat is toggled off.
block_on_mute:
- me
- say
- msg
- reply
- mail
- mail

View File

@ -110,6 +110,10 @@ playerFrozen: "<red>That player is already frozen!"
playerMuted: "<red>That player is already muted!"
playerLockedUp: "<red>That player is already locked up!"
muted: "<red>You are currently muted - STFU!"
chatIsOff: "<red>Chat is currently toggled off!"
# 0 - The command sender
# 1 - The set value of the chat toggle
chatToggled: "<red>{0} - Toggled chat {1}"
# 0 - The command sender
# 1 - The player
kickedPlayer: "<red>{0} - Kicking {1}"

View File

@ -10,4 +10,7 @@ fluidspread: true
drops: true
# Should redstone be enabled?
redstone: true
redstone: true
# Is chat enabled?
chat: true