RemmyChat is a lightweight, feature-rich chat management solution for PaperMC servers that enhances player communication with a clean, modern design.
RemmyChat transforms your server's communication with a sleek, modern interface while providing powerful customization through MiniMessage formatting. From immersive proximity chat to comprehensive anti-spam features, RemmyChat balances simplicity with functionality to create the perfect chat experience.
- Advanced MiniMessage Formatting — Rich text with colors, gradients, hover effects, and clickable elements
- Multi-Channel System — Global, local, staff, and trade channels with completely customizable formats
- Proximity Chat — Configurable radius-based local chat for immersive gameplay
- Private Messaging System — Seamless player-to-player communication with reply functionality
- Message Toggle — Allow players to enable/disable private messages
- Social Spy — Staff monitoring of player private messages
- Flexible Permission System — Granular control over all plugin features and channels
- Group-Based Formatting — Different chat formats based on player permissions
- Custom Placeholders — Create reusable text elements for consistency across formats
- Template System — Hover templates, channel prefixes, and name styles for easy configuration
- Interactive Elements — Hoverable player names with customizable information tooltips
- Automatic URL Detection — Link formatting with configurable click-to-open functionality
- Chat Cooldown — Configurable anti-spam system to prevent message flooding
- Message Persistence — Database storage for player preferences and chat history
- PlaceholderAPI Integration — Unlimited customization possibilities
- LuckPerms Integration — Seamless permission management
- Optimized Performance — Minimal resource usage even on busy servers
RemmyChat supports custom symbols and emoji replacement in chat messages. You can define your own codes (like 😄, :diamond:, etc.) and their replacements (emoji, text, or MiniMessage) in a separate symbols.yml
file. This feature works with both Unicode emojis and custom resource pack textures.
- Players can type codes like
:smile:
in chat. - The plugin will automatically replace these codes with whatever you configure in
symbols.yml
. - Supports case-insensitive codes and dashes (e.g.,
:smile-face:
). - Works seamlessly with resource packs for custom textures and emojis.
symbols:
":smile:": "😄"
":heart:": "❤️"
":star:": "⭐"
":smile-face:": "😊"
You can add as many codes as you want. The replacement can be any string, emoji, or MiniMessage component. Resource pack textures will display correctly for players using the appropriate resource pack.
Installation is straightforward:
- Download the latest RemmyChat release
- Place the JAR file in your server's
plugins
folder - Restart your server
- Configuration files will be generated automatically
For detailed setup instructions and advanced configuration, visit our official documentation.
RemmyChat's configuration is highly flexible while remaining intuitive. Here's a sample of what you can accomplish:
# Channel configurations
channels:
global:
permission: "" # Empty means everyone can use
radius: -1 # -1 means global chat
prefix: "" # No prefix for global
hover: "player-info"
display-name: ""
local:
permission: "remmychat.channel.local"
radius: 100 # Chat radius in blocks
prefix: "local"
hover: "local-chat"
display-name: "<gray>[Local]</gray>"
staff:
permission: "remmychat.channel.staff"
radius: -1
prefix: "staff"
hover: "staff-chat"
display-name: "<gold>[Staff]</gold>"
# Group-based formatting with customizable styles
groups:
admin:
name-style: "admin"
prefix: ""
format: "%admin-hover% %player_name%: %default-message%"
vip:
name-style: "vip"
prefix: ""
format: "<click:suggest_command:'/msg %player_name%'><hover:show_text:'VIP Player'>%vip-prefix%</hover></click> %player_name%: %default-message%"
# Templates for reuse across formats
templates:
hovers:
player-info: "<#778899>Player information\n<#F8F9FA>Name: <#E8E8E8>%player_name%\n<#F8F9FA>Click to message"
name-styles:
default: "<#4A90E2>%player_name%"
owner: "<bold><gradient:#FF0000:#FFAA00>%player_name%</gradient></bold>"
admin: "<italic><color:#CC44FF>%player_name%</color></italic>"
Command | Description | Permission |
---|---|---|
/remchat channel <name> |
Switch between chat channels | remmychat.use |
/remchat reload |
Reload plugin configuration | remmychat.admin |
/msg <player> <message> |
Send private message | remmychat.msg |
/reply <message> |
Reply to last private message | remmychat.msg |
/msgtoggle |
Toggle receiving private messages | remmychat.msgtoggle |
/socialspy |
Monitor private messages between players | remmychat.socialspy |
Permission | Description | Default |
---|---|---|
remmychat.use |
Basic plugin access | true |
remmychat.msg |
Send private messages | true |
remmychat.msgtoggle |
Toggle private messages | true |
remmychat.msgtoggle.bypass |
Bypass message toggle | op |
remmychat.socialspy |
Use social spy feature | op |
remmychat.admin |
Administrative access | op |
remmychat.channel.<name> |
Access to specific channel | Varies |
RemmyChat automatically integrates with PlaceholderAPI if installed, allowing you to use any placeholders in your chat formats.
When LuckPerms is detected, RemmyChat can use permission groups for chat formatting, simplifying setup for servers with existing permission structures.
This project uses Gradle for building and requires Java 21 or higher.
To build:
./gradlew build
The output JAR will be in the build/libs
directory.
- Documentation: remmychat.noximity.com
- Website: noximity.com
- Issues & Feature Requests: Please use our GitHub issues tracker
- Version: 1.4.5
- License: GPL-3.0