84 lines
No EOL
5 KiB
Markdown
84 lines
No EOL
5 KiB
Markdown
# Config Guide
|
|
According to the [Wynntils Artemis encoding proposal Github Issue](https://github.com/Wynntils/Wynntils/issues/2246),
|
|
the allowed blocks should look like this:
|
|
|
|
![An image of the original encoding proposal table, present on GitHub](images/encodingproposaltable.png)
|
|
|
|
However, it's inaccurate. This is what it SHOULD look like:
|
|
|
|
##### Key to Type Mapping Table
|
|
|
|
| Key | Type | Required blocks | Optional blocks |
|
|
|-----|--------------------------|--------------------------------------------|-------------------------------------------------------------|
|
|
| `0` | Gear Item | Name | Identifications, Powders, Shiny, Reroll |
|
|
| `1` | Tome Item | Name | Identifications, Reroll |
|
|
| `2` | Charm Item | Name | Identifications, Reroll |
|
|
| `3` | Crafted Gear Item | Custom Gear Type, Durability, Requirements | NameAfter, Damage, Defense, Custom Identifications, Powders |
|
|
| `4` | Crafted Consumable Item | Custom Consumable Type, Uses, Requirements | Effects, NameAfter, Custom Identifications |
|
|
| `5` | Crafted Item from Recipe | TODO | TODO |
|
|
|
|
## Shiny ID
|
|
Inside the Shiny{} list, there will be two elements: "key" and "value".
|
|
The potential keys for any shiny value are listed here: https://raw.githubusercontent.com/Wynntils/Static-Storage/main/Data-Storage/shiny_stats.json
|
|
The value is the shown amount.
|
|
## Item type
|
|
WIP. This will support crafteds in the future, but for now you must have this:
|
|
```
|
|
"item_type": "Gear"
|
|
```
|
|
|
|
## Powders
|
|
|
|
### Powder Limit
|
|
Powder limit cannot be increased beyond 255. This is because the powder count is stored as a byte.
|
|
Potential value range: 0<->255.
|
|
|
|
### Format
|
|
Inside the "powders":[ ] array, set it up in the following structure.
|
|
**{ "type":"$TYPE", "tier":$TIER, "amount": $AMOUNT }**
|
|
**TYPE** is stored as a single character.
|
|
Potential Values: "E" "T" "W" "F" "A" . These represent Earth, Thunder, Wind, Fire, Air.
|
|
**TIER** is stored as a single digit integer.
|
|
Potential value range: 1<->6.
|
|
**AMOUNT** is stored as an integer. It is optional. If not provided it falls back to 1.
|
|
Potential value range: 1<->255.
|
|
#### Other things about powder format:
|
|
Each value in the array must have a comma at the end except the last.
|
|
The use of spaces is optional, as well as letter case for the $TYPE value.
|
|
The keys ("type" "tier" "amount") must All be lowercase.
|
|
If type is invalid, it will default back to being Thunder powder.
|
|
#### Powders Example (yes, this looks wacky to show that this is allowed)
|
|
```
|
|
"powders": [
|
|
{ "type":"T", "tier":6, "amount":5 },
|
|
{"type" :"e","tier":1,"amount":5},
|
|
{"type": "F", "tier": 3,"amount":1},
|
|
{ "type" : "w" , "tier":6 }
|
|
]
|
|
```
|
|
Note that the last powder block in array has no comma at the end.
|
|
### Which items can have powders?
|
|
Powders can only be encoded on an item that originally supported powders in the first place.
|
|
Unfortunately you can't add powders to an item that didn't originally have them.
|
|
e.g. can't put powder on depressing shears, as depressing weapons don't have powder slot.
|
|
|
|
## Identifications
|
|
### Format
|
|
Inside the "ids":[] array, set it up in the following structure.
|
|
**{"id": "$ID","base": $BASE,"roll": $ROLL}**
|
|
**ID** is stored as a string corresponding to the Wynntils internal ID string of any roll. See here for a list: https://raw.githubusercontent.com/Wynntils/Static-Storage/main/Reference/id_keys.json .
|
|
**BASE** is the base roll. The default base data is defined in (WARNING: EXTREMELY MASSIVE TEXT FILE) https://raw.githubusercontent.com/Wynntils/Static-Storage/main/Reference/gear.json .
|
|
Beautify it then look for `ITEMNAME > identifications > IDENTIFICATIONNAME > raw` for default value. This base value defines the listed ID ranges.
|
|
**ROLL** defines the actual rolled value for the Identification. The formula is `BASE * ROLL / 100`. Most values are in the range 30-130 due to how Wynncraft handles many Identifications as 30-130 percent of a base stat. Thus, if you are trying to find the ROLL value, try your desired roll **(NOT the roll percentage 1-100)** divided by the BASE then round it to the nearest integer. This value is optional, and you should only exclude it when it is a fixed value e.g. Skill Points.
|
|
|
|
## Rerolls
|
|
Optional single value, i8. Stores number of rerolls. If missing or is 0, rerolls are not encoded.
|
|
Potential range: 0<->255.
|
|
|
|
### Other things about this
|
|
The format obeys the same json rules as the powders.
|
|
If you are trying to get the 100% or 0% roll and the value you calculated is close to 130 or 30, change it to 130 or 30 because that is the real value.
|
|
However, if the value is negative it will be between 70%-130%.
|
|
|
|
# Current issues
|
|
Crafteds are not implemented |