Module:HeroData/doc
This is the documentation page for Module:HeroData
Also see:
- Module:HeroData/nav - For nav box purposes
- Module:HeroData/release - For determining the release status of a hero
- Module:HeroDataArrays - For tables in stat pages
Overview
[edit source]This module provides functions to create hero infoboxes, statboxes, or retrieve hero information using the data uploaded to Data:HeroData.json.
Both will automatically be translated depending on the language selected. If called on
See Template:Lang for more
Functions
[edit source]get_hero_var
[edit source]Retrieve a hero variable's value, such as Abram's MaxHealth
Parameters
[edit source]- hero_name - Name of the hero in english, or key of the hero. Preferred and recommended to use hero key, as its much more efficient. Search for the key in Data:HeroData.json
- hero_var - Key of the hero's variable, see Data:HeroData.json
- sig_figs_or_localize - OPTIONAL, # of sig figs to round to if retrieving a float, or "true" if its a string that should be localized. See Localizable values section.
Note: Recommended to use hero key where possible, i.e. hero_atlas as its O(1) time complexity instead of hero name (Abrams) which is O(N).
Examples
[edit source]From wikitext:
Using hero name in english
{{#invoke:HeroData|get_hero_var|Abrams|MaxHealth}}
800
Using hero key
{{#invoke:HeroData|get_hero_var|hero_atlas|MaxHealth}}
800
{{#invoke:HeroData|get_hero_var|Abrams|FalloffStartRange}}
17
Round to 2 sig figs
{{#invoke:HeroData|get_hero_var|Abrams|FalloffStartRange|2}}
17
{{#invoke:HeroData|get_hero_var|Abrams|WeaponName}}
0
Localize
{{#invoke:HeroData|get_hero_var|Abrams|WeaponName|true}}
0
Notes
[edit source]Only usable on variables that are integers, strings, or floats (meaning not dictionaries/hashes or arrays/lists).
If using sig_figs parameter, ensure the value is a float.
If using localize parameter, ensure the value is a string. See Data:HeroData.json, you will notice that hero_astro's "Lore" variable has the value "hero_astro_lore". This key is then sent to Module:Lang which checks for it in Data:Lang_en.json (or a different language).
This function will automatically search for the variable in the hero's top-level data, then the 'Weapon' block, then the 'AltFire' block.
get_alt_fire_var
[edit source]Retrieve a hero's variable's value from "AltFire" table. Works the same as get_hero_var
Examples
[edit source]{{#invoke:HeroData|get_alt_fire_var|Viscous|BulletDamage}}
42
get_list_elem
[edit source]Retrieve a specified element from a list
Parameters
[edit source]- hero_name - Name of the hero in english, or hero key. Preferred and recommended to use hero key, as its much more efficient. Search for the key in Data:HeroData.json
- hero_var - Key of the hero's variable, see Data:HeroData.json
- number - Index to retrieve from the list. 1 for 1st element, 2 for 2nd element, etc.
- localize - OPTIONAL - "true" if its a string that should be localized. See Localizable values section.
Example
[edit source]From wikitext:
Using hero name in english
{{#invoke:HeroData|get_list_elem|Abrams|WeaponTypes|2}}
Attribute_EWeaponAttribute_CloseRange
Using hero key
{{#invoke:HeroData|get_list_elem|hero_atlas|WeaponTypes|2}}
Attribute_EWeaponAttribute_CloseRange
{{#invoke:HeroData|get_list_elem|Abrams|WeaponTypes|2|true}}
Close Range
get_hero_scalar
[edit source]Retrieve a hero variable's scalar value that is inside either "Spirit Scaling" or "Level Scaling", such as Abram's BulletDamage (scaling).
Parameters
[edit source]- hero_key - Key of the hero. Search for the key of a given hero in Data:HeroData.json
- scaling_type - "Spirit" or "Level"
- hero_var - Key of the hero's variable that is inside either "Spirit Scaling" or "Level Scaling", see Data:HeroData.json
- sig_figs_or_localize - OPTIONAL, # of sig figs to round to.
- no_template - OPTIONAL, return numerical value instead of scaling template. Has to be defined as "true"
Examples
[edit source]{{#invoke:HeroData|get_hero_scalar|hero_atlas|Level|BulletDamage}}
Round to 2 sig figs
{{#invoke:HeroData|get_hero_scalar|hero_atlas|Level|BulletDamage|2}}
No template
{{#invoke:HeroData|get_hero_scalar|hero_atlas|Level|BulletDamage|2|no_template=true}}
0.1
Notes
[edit source]If the scaling type or the stat key is not found in the hero's data, this function returns an empty string instead of an error message.
hero_has_stat
[edit source]Checks if a hero possesses a specific stat in their Base data, Level Scaling (Boons), or Spirit Scaling. Used primarily for conditionally hiding rows in infoboxes.
Parameters
[edit source]- hero_key - Key of the hero.
- stat_key - Key of the stat to check (e.g., BulletResist, TechResist).
Example
[edit source]{{#invoke:HeroData|hero_has_stat|hero_kelvin|TechResist}}
true
get_hero_key
[edit source]Returns the key of the specified hero's english name
Parameters
[edit source]- hero_name - Name of the hero in english
Example
[edit source]{{#invoke:HeroData|get_hero_key|Abrams}}
get_ability_key
[edit source]Gets the ability key from a hero's bound ability slot
Parameters
[edit source]- hero_key - Key of the hero
- slot_number - Slot number (1-based index)
Example
[edit source]{{#invoke:HeroData|get_ability_key|hero_atlas|1}}
get_hero_tag
[edit source]Retrieve a hero's description tags with Module:Lang, to be used in Template:HeroRosterCard and Template:Infobox hero
Parameters
[edit source]- name - Name of the hero in english. This is normally referenced from the template parameters
- number - Which tag to call (1, 2 or 3)
Example
[edit source]{{#invoke:HeroData|get_hero_tag|Abrams|1}}
write_role_playstyle_quote
[edit source]Writes a formatted role and playstyle quotation for a hero
Parameters
[edit source]- hero_key - Key of the hero
Example
[edit source]{{#invoke:HeroData|write_role_playstyle_quote|hero_atlas}}
write_default_items
[edit source]Writes the recommended items list for a hero
Parameters
[edit source]- hero_key - Key of the hero (unlocalized)
Example
[edit source]{{#invoke:HeroData|write_default_items|hero_atlas}}
write_ground_dash_buckets
[edit source]Outputs a wikitable of heroes grouped by their GroundDashDuration using Template:HeroIcon
Example
[edit source]{{#invoke:HeroData|write_ground_dash_buckets}}
| Bucket 1 | Bucket 2 | Bucket 3 |
|---|---|---|
Localizable values
[edit source]Localizable values as of writing this:
- Hero names (via hero keys)
- Lore
- Playstyle
- Role
- WeaponDescription
- WeaponName
- elements in WeaponTypes
- elements in RecommendedItems
- All stat labels and postfixes
- Ability descriptions and names
- Hero tags (1, 2, 3)
Internal Utility Functions
[edit source]The following functions are primarily for internal use but may be useful for advanced users:
get_json_item
[edit source]Returns the table of a specific hero by name
Parameters
[edit source]- name - Name of the hero in english
get_similar_items
[edit source]Returns an array of hero tables that have a specified property
Parameters
[edit source]- property - Property key to search for
Scaling System
[edit source]The module supports two types of scaling:
- Spirit Scaling - Affects stats based on Spirit Power
- Level Scaling - Affects stats based on Power Increases/Levels/Boons