
Smart Key Prompts
Flexible on-screen key prompts and convenient key remapping features.
About this Mod
Smart Key Prompts
Need OneEngoughLib from 1.1.2 on!
This mod provides a flexible and dynamic key prompt system, along with extended features for customizable key modification.
It improves the overall player experience and helps streamline key management.
How to Use
For regular players, simply install and play—no setup required.
For developers, there are four ways to add new key prompts in-game:
- The target mod actively integrates with Smart Key Prompts.
- Use KubeJS to call the API provided by this mod.
- Add support via datapacks (with certain limitations; see the Datapack Extension Guide).
- Added directly through built-in adaptation within this mod.
Main Features
This mod selectively displays relevant key prompts at appropriate times.
It provides flexible APIs for mod or modpack developers to show context-based key hints.
// Display an existing registered keybinding.
show(String group, String desc);
// Display a fully custom key prompt.
custom(String group, String key, String desc);
// Display an existing registered keybinding under an alias.
alias(String group, String desc, String alias);
Simply call these methods under certain conditions (e.g., during the client tick event) to display contextual key prompts.
For detailed implementation examples, see below.
Datapack-based prompts are also supported, though with limited condition logic and syntax—best suited for simpler use cases.
See Datapack Extension Guide for more information.
Example output:
Each method’s group parameter represents a key prompt group ID.
For example, this mod uses "jei_skp" as the group ID when integrating with JEI, which is disabled by default.
You can freely enable or disable any group in the configuration file using its group ID.
When key prompts are visible on screen, pressing Control Key (default: K) + Left Click will open the corresponding keybinding menu directly—no need to search through the full list.
Example:
Note that this shortcut only works for prompts linked to registered keybindings (show, alias),
and not for fully custom prompts (custom).
Additionally, you can programmatically trigger the configuration interface for specific keybindings:
ConfigAction.modifyKey(List<String> keyDescList);
Holding the control key locks the current key prompts, making them persist temporarily.
Lastly, Control Key + Right Click toggles HUD visibility and position.
While holding Control, you can use the mouse wheel to adjust the HUD size.
Flexible Prompting System
The "key" and "desc" fields refer to entries in the language files.
For example, in Minecraft’s default language file \assets\minecraft\lang\en_us.json:
{
"key.keyboard.f11": "F11",
"key.keyboard.left.shift": "Left Shift",
"key.mouse.left": "Left Button"
}
And in TaCZ’s language file \assets\tacz\lang\zh_cn.json:
{
"key.tacz.fire_select.desc": "Fire Mode",
"key.tacz.inspect.desc": "Inspect",
"key.tacz.interact.desc": "Interact while armed"
}
Example usage in a mod:
@SubscribeEvent
public static void tick(TickEvent.ClientTickEvent event) {
if (!ModList.get().isLoaded("immersive_aircraft")) return;
Player player = Minecraft.getInstance().player;
if (player == null || Minecraft.getInstance().screen != null) return;
String vehicle = Utils.getVehicleType(player);
if (vehicle != null && vehicle.startsWith("immersive_aircraft:")) {
SmartKeyPrompts.custom(modid, Utils.getKeyByDesc("key.inventory"), "immersive_aircraft.slot.upgrade");
SmartKeyPrompts.show(modid, "key.immersive_aircraft.dismount");
String keyUse = Utils.getKeyByDesc("key.immersive_aircraft.fallback_use");
SmartKeyPrompts.custom(modid, Objects.equals(keyUse, "key.keyboard.unknown") ? "key.mouse.right" : keyUse, "item.immersive_aircraft.item.weapon");
if (vehicle.equals("immersive_aircraft:biplane")) {
SmartKeyPrompts.custom(modid, Utils.getKeyByDesc("key.jump"), "item.immersive_aircraft.engine");
}
}
}
Usage in KubeJS:
ClientEvents.tick(event => {
let player = event.player;
if (["key.left", "key.right", "key.forward", "key.back"].map(desc => SKP$KeyUtils.isKeyPressedOfDesc(desc)).includes(true)) {
SKP$PromptUtils.show("parcool", "key.parcool.Dodge");
}
if (!player.onGround() && !player.isInWater()) {
SKP$PromptUtils.show("parcool", "key.parcool.Breakfall");
SKP$PromptUtils.show("parcool", "key.parcool.ClingToCliff");
}
if (player.isSprinting()) {
SKP$PromptUtils.show("parcool", "key.parcool.FastRun");
}
if (SKP$KeyUtils.isKeyPressedOfDesc("key.parcool.FastRun")) {
SKP$PromptUtils.show("parcool", SKP$KeyUtils.getKeyByDesc("key.parcool.Dodge"));
SKP$PromptUtils.custom("parcool", SKP$KeyUtils.getKeyByDesc("key.sneak"), "parcool.action.CatLeap");
}
});
For combination keys, you can use:
SmartKeyPrompts.custom(modid, "key.keyboard.left.shift+key.mouse.left", "Transfer items in bulk");
Datapack-based configuration example (see the guide):
{
"modid": "tacz_skp",
"vars": {
"modLoaded": "isModLoaded('tacz')",
"hasTaczGun": "mainHandItem == 'tacz:modern_kinetic_gun'",
"isNotInVehicle": "!isInVehicle()"
},
"entries": [
{
"when": {
"modLoaded": "true",
"hasTaczGun": "true",
"isNotInVehicle": "true"
},
"then": [
"show('tacz_skp', 'key.tacz.shoot.desc')",
"show('tacz_skp', 'key.tacz.zoom.desc')",
"show('tacz_skp', 'key.tacz.reload.desc')"
]
}
]
}
Extended example: show interaction prompts below the crosshair when targeting an entity.
@SubscribeEvent
public static void tick(TickEvent.ClientTickEvent event) {
if (!ModList.get().isLoaded(modid)) return;
if (PlayerUtils.getTargetedEntityType() == "minecraft:pig") {
PromptUtils.addDesc("key.pig.feed").forKey("key.mouse.right").withCustom(true).atPosition("crosshair").toGroup(modid);
}
}
Both "custom" and "position" can be customized.
The "custom" flag determines whether the prompt appears in the filtered keybinding menu,
and "position" controls where the prompt is displayed (fixed, unaffected by HUD repositioning).
Smart Key Prompts also provides various utility methods—such as key detection and entity targeting—to simplify mod development.
Flexible Disabling
When holding the control key (default: K), prompts become locked, and their full identifiers (group:desc) are displayed.
In KubeJS, you can enable or disable prompts dynamically:
SKP$PromptUtils.disablePromptByGroup(String group)
SKP$PromptUtils.enablePromptByGroup(String group)
SKP$PromptUtils.disablePromptByDesc(String desc)
SKP$PromptUtils.enablePromptByDesc(String desc)
SKP$PromptUtils.disablePrompt(String group, String desc)
SKP$PromptUtils.enablePrompt(String group, String desc)
You can also disable or re-enable specific keybindings:
SKP$KeyUtils.isKeyDisabled(String desc)
SKP$KeyUtils.getDisabledKeyMappingList()
SKP$KeyUtils.disableKeyMapping(String desc)
SKP$KeyUtils.disableKeyMapping(List<String> list)
SKP$KeyUtils.disableAllKeyMapping()
SKP$KeyUtils.enableKeyMapping(String desc)
SKP$KeyUtils.enableKeyMapping(List<String> list)
SKP$KeyUtils.enableAllKeyMapping()
For example, calling disableKeyMapping("key.jump") prevents the player from jumping.
Other Information
If you’d like this mod to support another mod, feel free to reach out.
You can also submit new key prompt groups directly to the repository.
Recommended companion mod: KeyBindJS
Planned features:
- More prompt positions (e.g., follow mouse).
- Support for double-tap and long-press keys.
- HUD visual improvements.
- Potential backports to more Minecraft versions.
See the full list of supported mods in the official documentation.
Available Versions
How to Install Smart Key Prompts on Your Server
Order Server
Order a Minecraft Java server with at least 3 GB RAM (4 GB recommended).
Set fabric Loader
In the panel under "Egg", select the fabric loader and matching Minecraft version (1.21.1).
Install Mod
Open the mod browser in the dashboard and search for "Smart Key Prompts". Click "Install" – done! Alternatively, upload the .jar via SFTP to the /mods folder.
Compatibility
Mod Loaders
Minecraft Versions
1.21.1, 1.21, 1.20.6 (+5 more)
Server-side
✗ UnsupportedRecommended RAM
4 GB(min. 3 GB)Frequently Asked Questions
Smart Key Prompts server crashes on startup – what to do?
Most common cause: wrong fabric version or insufficient RAM. Check the server log (latest.log) for "OutOfMemoryError" or "Mixin" errors. With Mado Hosting: ensure at least 3 GB RAM is allocated and the loader matches the mod version (1.21.1). You can switch loaders with one click in the panel.
Is Smart Key Prompts compatible with fabric and forge and neoforge?
Smart Key Prompts officially supports fabric, forge, neoforge for Minecraft 1.21.1, 1.21, 1.20.6. Note: Forge and Fabric mods are NOT cross-compatible – pick one loader and stick with it. The Mado dashboard automatically detects incompatible loader combinations.
Server lagging with Smart Key Prompts – how to optimize performance?
Recommended RAM: 4 GB (per 8 players). Use /spark profiler to check if Smart Key Prompts consumes the most tick time. Common fixes: reduce server view-distance to 8-10, install "performant" or "starlight" as supplementary mods on Forge. With Mado Hosting, your server runs on NVMe SSDs with dedicated CPU cores for minimal latency.
Similar Mods
Rent Modded Server
Install Smart Key Prompts with just one click on your server.