Host your Minecraft server on BisectHosting - get 25% off your first month with code MODRINTH.

SimplePrefixes

wakatime

A plugin aiming to allow for simple player-selected prefixes that can be used in chat!

Requirements

Features

  • Player friendly GUI for selecting nicknames.
  • Does not interact with any other plugins directly.
    • The plugin uses and hold prefixes in a placeholder, it will not affect permission groups / meta.
  • Supports PlaceholderAPI Placeholders.
  • Supports Mini-Message formatting.
  • Supports multiple types of requirements: PERMISSION, STATISTIC, ADVANCEMENT, COMPARE_INT

Placeholders, Commands, and Permissions

%sp_prefix%

Placeholder for the prefix. Use this in your chat plugin.

Example Usage: %sp_prefix% %player_displayname% » {message}

%sp_prefix_legacy%

Placeholder for the prefix. Necessary when you need the legacy (&a / §a instead of <green>) way to handle stuff.

Example Usage: %sp_prefix% %player_displayname% » {message}

/sp gui

Opens a generated GUI that organizes the prefixes by prefix-id.

/sp reset

Resets your prefix.

/sp set <prefix-id>

Sets your prefix.

/sp reload

Reloads the plugin.

Configuration

saving-type: "file"
default-prefix: "<white>[<gray>Player</gray>]</white> "

Configuration Settings

Setting Description Valid Values
saving-type What type of saving system should this use? PDC, FILE
default-prefix Fallback prefix, supports Placeholders. String

Saving Types

These are the current implementations of the saving types...

PersistentDataContainer (PDC)

The plugin will save the prefix ID of the currently equipped prefix on the Player themselves. This makes the prefix inaccessible while they are offline.

This was primarily used for initial testing of the plugin but if you don't like file systems for some reason, there.

YML File (FILE)

The plugin will save the prefix IDs of all players to a configuration YML file stored alongside the config. This allows for the prefix to be available while they are offline, but any time a player's prefix is changed, the plugin saves the prefix.

This is default.

Creating Prefixes

prefix-id:
  display-name: "Prefix ID"
  description:
    - "This is to show an example Prefix!"
    - "This is a second line of description!"
  prefix: "<white>[<rainbow>Something</rainbow>]</white>"
  verify-always: false
  show-when-locked: true
  requirements:
    - "permission simpleprefix.example true"
    - "statistic PLAYER_KILLS >= 10"
    - "advancement nether/summon_wither true"
    - "compare_int %placeholder% < 1"

prefix-id

This is the Prefix ID. Every prefix is uniquely identified by this value. This does mean you cannot have two of the same Prefix IDs.

The prefix-id itself is the value you change. Don't include spaces.

display-name

This is the Display Name of the prefix. It is used as basically the formatted way to display this Prefix.

Supports Placeholders from PlaceholderAPI.

prefix

This is the String representation of the prefix that will be displayed in place of %sp_prefix%.

Supports Placeholders from PlaceholderAPI.

# A prefix with the ID "example-prefix"...
example-prefix:
  display-name: "The Example Prefix"
  prefix: "<white>[<rainbow>Example</rainbow>]</white> "

Prefix Requirements

Requirements are things that must be held true in order to equip the prefix. These requirements come in multiple forms that will be explained here.

Note

Requirements that are incorrectly formatted or produce errors are ignored.

Requirements that cannot guarantee failure will not be checked either. To check player permissions, the player has to be online, so while the player is offline, these checks are ignored.

verify-always will make the requirements check every time the player's prefix is requested. If the requirement check fails, the prefix saved is cleared.

Permission

Format: permission <permission.node> [false]

<permission.node> represents a permission the player may have.

[false] is optional and must be provided to invert the result. This means if the permission is example.permission, the player must NOT have this permission.

Example: permission example.permission (Player has permission example.permission)

Example: permission example.permission false (Player does not have permission example.permission)

Statistic

Format: statistic <statistic> <operator> <value>

<statistic> is an enum value from this page. This represents some statistic the player has.

<operator> is a comparison operator. Valid operators are >, <, >=, <=, ==, !=

<value> is an integer and can be compared to the statistic.

Example: statistic ANIMALS_BRED >= 100 (Player has bred 100 or more animals).

Advancement

Format: advancement <namespace:advancement> [false]

<namespace:advancement> is a Namespaced Key representing an Advancement.

You can find vanilla advancements on this page. This represents some advancement the player can earn. Minecraft Advancements use the minecraft namespace.

[false] is optional and must be provided to invert the result. This means that if the advancement is minecraft:nether/summon_wither, the player must not have this advancement.

Example: advancement minecraft:nether/summon_wither (Player has the Minecraft Summon Wither advancement).

Example: advancement minecraft:nether/summon_wither false (Player does not have the Minecraft Summon Wither advancement).

Compare Int

Format: compare_int <placeholder> <operator> <value>

<placeholder> is any PlaceholderAPI placeholder that can return a valid integer.

<operator> is a comparison operator. Valid operators are >, <, >=, <=, ==, !=

<value> is an integer and can be compared to the placeholder.

Example: compare_int %player_absorption% > 0 (Player has absorption value greater than 0).

Unimplemented

  • Compare String, Case Sensitive
  • Compare String, Case Insensitive

WIP Features

  • Configurable Icons
  • Compare String, Requirement Checks

External resources



Project members

Simplexity

Simplexity

Organization

Peashooter101

Member

Rhythmic

Owner


Technical information

License
Project ID