Module:HeroData/doc

From The Deadlock Wiki
Jump to navigation Jump to search

This is the documentation page for Module:HeroData

Also see:

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

  • Page - translates to english
  • Page/en - translates to english
  • Page/es - translates to spanish

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

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}}

+0.1

Round to 2 sig figs

{{#invoke:HeroData|get_hero_scalar|hero_atlas|Level|BulletDamage|2}}

+0.1

No template

{{#invoke:HeroData|get_hero_scalar|hero_atlas|Level|BulletDamage|2|no_template=true}}

0.1

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}}
Hero Dash Buckets
Bucket 1 Bucket 2 Bucket 3
Calico Apollo Abrams
Celeste Billy Bebop
Grey Talon Drifter Dynamo
Haze Graves Kelvin
Holliday Infernus Lady Geist
Ivy Lash Mo & Krill
Mina McGinnis Paige
Paradox Mirage Shiv
The Doorman Pocket Venator
Rem Victor
Seven
Silver
Silver (Transformed)
Sinclair
Vindicta
Viscous
Vyper
Warden
Wraith
Yamato

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