Smart Key Prompts

Smart Key Prompts

Flexible on-screen key prompts and convenient key remapping features.

by
58.6K Downloads
fabricforgeneoforgeutility
Rent Server with this Mod

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:

img

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:

img

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

Smart Key Prompts 1.1.3-hotfixrelease
MC 1.20.1fabric
April 2, 2026
Smart Key Prompts 1.1.3-hotfixrelease
MC 1.20.1forge
April 2, 2026
Smart Key Prompts 1.1.3release
MC 1.20.1forge
March 26, 2026
Smart Key Prompts 1.1.3release
MC 1.20.1fabric
March 26, 2026
Smart Key Prompts 1.1.3release
MC 1.21.1neoforge
January 12, 2026

How to Install Smart Key Prompts on Your Server

1

Order Server

Order a Minecraft Java server with at least 3 GB RAM (4 GB recommended).

2

Set fabric Loader

In the panel under "Egg", select the fabric loader and matching Minecraft version (1.21.1).

3

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

fabricforgeneoforge

Minecraft Versions

1.21.1, 1.21, 1.20.6 (+5 more)

Server-side

Unsupported

Recommended 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.

Rent Modded Server

Install Smart Key Prompts with just one click on your server.

Recommended RAM
4 GBab €8/mo
Min. 3 GB | +1 GB pro 8 Spieler
Create Server Now
1-Click Mod Install
NVMe SSD Storage
DDoS Protection included

Details

License
GNU General Public License v3.0 only
Server-side
Unsupported

Supported Versions

1.21.11.211.20.61.20.51.20.41.20.31.20.21.20.1