Resource Colors
This page is about the JSON in Mantle assigning colors to various resources. For the common JSON format for a color, see Basic Types.
Since 1.18.2, mods using Mantle can assign colors to a component in JSON. This is most commonly used for the colors of tooltip strings, since methods for setting tooltip colors via language files are both unreliable and limited in options.
Color Format
Colors are defined in resource packs under assets/<domain>/mantle/color.json
. The domain <domain>
has no impact on the behavior of the JSON, it is simply used to allow multiple mods to define a color list without conflicting (as before 1.19.4 Forge did not allow multiple mods to define a resource at the same location in resource packs). In addition, between 1.18 and 1.20 this file can also be loaded from assets/<domain>/tinkering/color.json
, though it will generate a log warning directing users to the new location.
The color JSON has the following format:
<key>
to the given color. Ifnull
, will be skipped (useful for comments).
Assigns the key <prefix>.
.<prefix>.<key>
to the given color. Ifnull
, will be skipped (useful for comments).
Assigns the key <prefix>.<prefix2>.
.<prefix>.<prefix2>.<key>
to the given color. Ifnull
, will be skipped (useful for comments).
Assigns the key - May additionally nest any number of prefixes.
Recursive definition of a color object. All keys inside the object will be prefixed with
Recursive definition of a color object. All keys inside the object will be prefixed with
A color object.
Example
The key example.color.key
may be set to #123456
using any of the following formats:
{
"some.comment": null,
"example.color.key": "#123456"
}
{
"example": {
"color.key": "#123456"
}
}
{
"example.color": {
"key": "#123456"
}
}
{
"example": {
"color": {
"key": "#123456"
}
}
}
These formats may be freely mixed throughout the file, though note that the same JSON key cannot be defined as both a color and a color object. In other words, if trying to set both example.color
and example.color.key
, the following is allowed:
{
"example": {
"color": "#123456",
"color.key": "#123456"
}
}
but the following is not allowed:
{
"example": {
"color": "#123456",
"color": {
"key": "#123456"
}
}
}
Usages
Tinkers’ Construct uses the resource color list with the following keys:
- The modifier
<domain>:<name>
defines its text color using the keymodifier.<domain>.<name>
. - The material
<domain>:<name>
defines its text color using the keymaterial.<domain>.<name>
. - The material variant
<domain>:<name>#<variant>
defines its text color using the keymaterial.<domain>.<name>.<variant>
. - The mining tier
<domain>:<name>
defines its text color using the keyharvest_tier.<domain>.<name>
. - Since 1.20, the slot type
<name>
defines its text color using the keystat.tconstruct.slot.<name>
.