Dota 2 Compendium Scriptfiles
Dota 2 Compendiums are in-game items associated with leagues. They're described by a script file that third parties upload to the Dota 2 backend via the Edit League page on Dota2.com. This page will describe that script file, and the process we recommend to develop your compendium.
Building and Testing
First, ensure your league is allowed to have a compendium. You can contact the Valve league admin team via your League pages. Once compendiums have been enabled for your league, you should download the example compendium script file from your league's Edit page (or grab it directly from here: http://media.steampowered.com/apps/dota2/images/leagues/CompendiumExample.zip)
Compendiums should be built and tested on your local machine before they're uploaded to the Dota 2 backend. You can test your compendium using the test_compendium command. For example:
test_compendium "c:/compendium/example_compendium.txt"
Once your compendium is open, you can make changes to your script file and instantly reload the compendium with the test_compendium_refresh command. We recommend doing all your script file editing live in this way, so you're testing quickly as you go.
Place any images for your compendium in the same directory as your script file, and they'll be found automatically while testing. Note that any selections in your compendium won't be actually saved, and some other data will be faked for testing purposes (progress bars will constantly move, the prize pool will roll forward, etc)
Once you're getting ready to publish, submit your compendium & images through the league admin page, but don't set it public yet. Non public compendiums will be visible to all the admins for your league. Start your Dota 2 client and look through the compendium to make sure you're happy with it. Once you are, submit it again and mark it as public, and then all players who've purchased a ticket for your league will have access to it.
Concepts
Compendiums contain several concepts that will be referred to throughout the script file.
Pages
The compendium is a virtual book containing pages. Each page contains a list of elements, which are used to display that page to the player. Elements range from visuals (like text fields and images) to input (like buttons and combo boxes) to layout helpers (like containers and templates).
Elements
Pages are made up of a list of elements. Each element must have a unique name, and an element type. Each type then has a list of required and optional parameters.
Selections
Selections are used to store a dynamic value in the compendium. The value is either set by the player, or by the Dota 2 backend. Many elements inside compendiums can then interact with selection values. Each selection must have a unique index to identify it.
Selections are what you use any time you'd like to accept a player's input inside your compendium - to allow them to make a prediction on a future match, vote on who they'd like in a show match, to select a favorite Hero or item, etc. The actual UI method by which a user sets the selection can vary.
Selections that are set by players can be set to become locked at some point in time. Once locked, players cannot change them. Selections can also choose to lock themselves based on the value of other selections.
Templates
Templates allow you to easily replicate a chunk of script Keys & Values throughout your script file. Templates must be registered with a unique name somewhere in your script file, and then they can be instantiated by name anywhere else in your compendium.
Templates also support "defines", which are essentially variables that instances of the template must provide values for. The template can then use those defines inside elements in the template, knowing that the defines will be replaced later by the values provided in instances. See Template Element Parameters for syntax and examples.
Localization
Localization is automatically handled for you when you publish your compendium. Any text that appears in your compendium will be extracted and replaced with localization keys. The text is then published on the [Steam Translation Web page]. The other language strings for your compendium will be shipped after the community has finished translating them.
Some best practices for ensuring your compendium localizes well:
- Don't put text inside your images, because it can't be localized. Instead, ise text fields to overlay text over images.
- Don't rename pages or elements when updating your compendium after it's shipped. The localization keys are generated based on page & element names, so renaming them shifts localization keys around, which causes pain for our translators.
- Try and provide extra space for text in other languages. If you have text that fits exactly inside its textfield, it probably won't fit once it's translated to other languages.
- Try not to break sentences into multiple textfields. Some languages have concepts that prevent you from assembling valid sentences from multiple chunks of separately localized text (like gender specific nouns).
- You can force any text to not be localized by adding ^^ at the start of it. i.e. "text" "^^DON'T LOCALIZE".
The Script File Format
The compendium script file is a KeyValues text file that's easily edited in any text editor. It contains a series of sections that each have a set of parameters, some required and some optional. The test_compendium command will report any errors it finds in your compendium when you try to open it.
Root Level Parameters
The root level of the script file must contain the following keys:
- "version" "3"
 - This is the version for the scriptfile. Don't change it.
 
 - "table_of_contents_page" "<name of your table of contents page>"
 - The value should be the name of the page that you want the user to be taken to when they click the "Table Of Contents" button in the navigation controls.
 
 - "table_of_contents_version" "<version of the Table of Contents>"
 - The value is simply a number that you increment whenever you like. Whenever a user opens your compendium, and this number is higher than it was the last time they opened it, an alert "!" image will be shown on the Table of Contents button in the navigation controls. We recommend increasing this number any time you add new pages to your compendium.
 
 - "precache"
 - This section should contain a list of images that must be fully downloaded before the compendium opens. You definitely want to have you cover & page backgrounds here, but if you don't have large images you could make players download most/all of your compendium before it opens. Images not in this list will be downloaded when the user browses to the page with the image on it (i.e. they'll appear after a the download finishes).
 
 
 Example Example- "precache"
 - { 
 - "compendium2014_cover.jpg"       "1"
- "compendium2014_blankpage.jpg"   "1"
- "compendium2014_insidecover.jpg" "1"
 - }
- "compendium2014_cover.jpg"       "1"
- "timers"
 - This section contains the master list of times that other elements will refer to. Timers must be specified in the following format:
- "HH:MM:SS DD-MM-YYYY GMT+ZZZZ" (timezone + can be a - instead)
 
 
 Example Example- "precache"
 - { 
 - "always_locked"    "00:00:00 01-01-2000 GMT+0000"
- "qualifiers_start" "12:00:00 12-05-2014 GMT-0500"
- "qualifiers_end"   "23:59:59 27-05-2014 GMT+0200"
- "mainevent"        "09:00:00 18-07-2014 GMT+0700"
 - }
- "always_locked"    "00:00:00 01-01-2000 GMT+0000"
- "preregister_selections"
 - This section contains a list of selections that need to be defined before being used inside elements in the pages. Any selection that's set in some way other than a combo box must be registered here (combo boxes can contain the selection registration themselves). See Selection Parameters to see how to register an individual selection.
 
 - "result_dialog_settings"
 - This section customizes the extra information dialog that pops up when the user clicks the "More Info" button associated with a selection combo box. Generally only used for prediction results. The parameters inside this section are as follows:
- "color_title" : The RGB color of the title text
- "color_bg" : Sets the RGB color for the flat, shaded background. Alternatively, use "image_bg_filename".
- "color_result" : The RGB color of the result text
- "color_extrainfo" : The RGB color of the extra information text
- "color_correctedness" : The RGB color of the CORRECT! / INCORRECT! text
- "image_bg_filename" : An image to be used as the background of the dialog, instead of the flat, shaded background.
 
 
- This section customizes the extra information dialog that pops up when the user clicks the "More Info" button associated with a selection combo box. Generally only used for prediction results. The parameters inside this section are as follows:
 - "templates"
 - This section contains a list of template definitions. See Compendium Templates for more information. Templates can also be specified inside pages themselves, using the "embedded template" element type. For templates that are only used inside a single page, this is preferable for organisational reasons, keeping your template definitions near where they're used. See Template Element Parameters for format details.
 
 - "pages"
 - This section contains the master list of pages, in the order that they should appear in the compendium. Each page then contains a list of elements. See Page Parameters to see how to layout individual pages.
 
 
Page Parameters
Each page must have a unique name, and contain a list of elements. A useful organisational technique is to also store templates used by the page inside the page itself, instead of in the global templates list (which is a good place to store templates used by multiple pages). See the "page_insidecover" in the example to see this.
 Example Example- "pages"
 - { - "page_cover"
- {
- "elementlist"
- {
- "cover_image"
- {
- ...
 
- }
 
- }
 
- }
- "page_insidecover"
- {
- "templatelist"
- {
- "template_image"
- {
- "elementtype" "embedded_template"
- ...
 
- }
 
- }
- "elementlist"
- {
- "background_image"
- {
- ...
 
- }
- "some_text"
- {
- ...
 
- }
 
- }
 
- }
 - }
Element Parameters
There a several types of elements. The first key in any element section should be the "elementtype" parameter, which tells the compendium what kind of element the section is describing. The remaining keys in the section will be parsed depending on the element type.
Valid element types:
- "textfield"
 - A blob of text. Text Element Parameters
 
 - "image"
 - An image. Image Element Parameters
 
 - "selection"
 - A combo box that allows users to set a selection value. Selection Element Parameters
 
 - "button"
 - A clickable button that performs a command, or sets a selection value. Button Element Parameters
 
 - "timer"
 - A timer that shows the amount of time left until a registered timer expires. Timer Element Parameters
 
 - "progressbar"
 - A progress bar that shows the amount of progress towards a goal. ProgressBar Element Parameters
 
 - "video"
 - An embedded youtube / youku video. Video Element Parameters
 
 - "container"
 - A container of other elements. Used in templates to contain a mix of elements, and for controlling visibility of block of elements. Container Element Parameters
 
 - "generic"
 - A generic scaleform element by name. Currently only designed to support scrollable views within pages. Generic Element Parameters
 
 
In addition to an "elementtype", a section can also optionally contain an "embedded_template" key, set to "1". If done so, this element will be registered as a template instead of actually being instantiated on the page. It's exactly the same as putting the element in the root "templates" section, except that it's stored inside a page. Useful for keeping your templates near where they're used. See Template Element Parameters for additional template-only parameters.
Text Element Parameters
Text elements are fields that contain chunks of localizable text.
Parameters:
- "text"
 - Text to display. Can contain Text Escape Sequences.
 
 - "font"
 - Can be one of the Dota fonts: "text", "textbold", "title". Or it can be the name of a font (like "courier" or "arial". Note that you can only really use fonts that are widely available in Windows, Linux, and OSX).
 
 - "size"
 - Font size.
 
 - "bold"
 - Makes the font bold.
 
 - "italic"
 - Makes the font italic.
 
 - "x"
 - Element X position. Pages are 512x608.
 
 - "y"
 - Element Y position. Pages are 512x608.
 
 - "w"
 - Text width. Make sure you leave enough room for other languages (good rule of thumb is to leave 2x the amount required for english)
 
 - "h"
 - Text height. Another way to how localization is to provide enough height for an extra line of text beyond what you're using, so localized text can word wrap down to the next line.
 
 - "spacing_horizontal"
 - Horizontal spacing between each text character.
 
 - "spacing_vertical"
 - Vertical spacing between multiple lines of text in word wrapped elements.
 
 - "align"
 - Sets how the text inside the element will be aligned within the element's width & height. Must be one of these: "left", "right", "center" ("left" if unspecified).
 
 - "depth"
 - Either "front" or "back" ("front" if unspecified). Front elements will be placed in front of existing content in the template. Back will be behind. Bear in mind that the order that elements are specified is the order they're placed on the page.
 
 - "color"
 - RGB values of the text ("255 255 255" if unspecified).
 
 - "link_to_page"
 - Value must match the name of one of your pages in your compendium. Clicking on this text will jump to that page. Great for Table Of Contents, or rapid jumps back & forth in your compendium.
 
 - "link_to_url"
 - Value should be a URL. Clicking on this text will popup that URL in an external browser.
 
 - "min"
 - Minimum value used by the %prizepool_togo% and %prizepool_perc% Text Escape Sequences.
 
 - "max"
 - Maximum value used by the %prizepool_togo% and %prizepool_perc% Text Escape Sequences.
 
 - "show_selection_tooltip"
 - If set to the index of a Selection, rolling the mouse over this text will pop up a tooltip. The tooltip will be configured based on the "tooltip_data" section of the Selection (not this text field's). This allows custom tooltips per choice in the Selection.
 
 - Used to make a tooltip popup when the user moves their mouse cursor over this element.
 
 - Used to control when this element is visible / non visible. Elements are always visible by default.
 
 
Selection Points Displays
Instead of displaying normal text, a text element can elect to show the total points earned by the user for a set of Selections. Mostly used for showing the user's points earned for predictions. To do this, the text element needs a "Points" section setup in one of the two following ways:
- List Selection indices individually by index (key is the selection index, value is just "1")
- Specify a min & max selection index range with the "index_min" and "index_max" keys, which sums all indices between them inclusively.
These two methods can also be combined. Examples:
 Example Example- "points"
 - { - "1" "1"
- "3" "1"
- "6" "1"
 - } 
 "points"
 {- "index_min" "8"
- "index_max" "11"
 - } 
 "points"
 {- "index_min" "1"
- "index_max" "7"
- "10" "1"
- "11" "2"
 - }
Textlists
Text fields can also be setup to act as Textlists. A Textlist is a Text Element that dynamically updates the text it's displaying based on some other data (like the Compendium Level, or the League's Prizepool). A good example of what they're useful for is displaying text describing what the player will unlock once their compendium levels up. To setup a Text Element as a Textlist, you need to set the following parameters:
- "textlist_var"
 - The data value you want to use to decide which piece of dynamic text to display. Currently only "prizepool" (for the League Prizepool) and "level" (For the player's Compendium Level) are supported.
 
 - "textlist_rule"
 - The mathematical way you want to compare the data value specified in "textlist_var" to the values in the "textlist" below when deciding which piece of dynamic text to display. Valid rules are "=", "!=", ">", "<", ">=", and "<="
 
 - "textlist"
 - A section containing a list of all the dynamic text chunks that can be shown in this Text Element. The section's keys should be the number to compare against the the data value specified in "textlist_var" (using the mathematical rule in "textlist_rule"). The section's values should be the dynamic text chunks.
 
 
In this example, the text field is configured as a Textlist based on the player's Compendium Level. The text will be dynamically set to the entry in the "textlist" that has the key that's less than or equal the player's Compendium Level. So if the Compendium Level is 3, the text would be "Extra Loading Screen Treasures". If the level was 8, the text would be "Kunkka's Courier: Lieutenant Squawkins". If the levels was above 10, there would be no visible text.
 Example Example- "recent_rewardname"- { - "elementtype" "textfield"
- "text" ""
- "font" "title"
- "size" "15"
- "x" "40"
- "y" "242"
- "w" "432"
- "h" "80"
- "align" "center"
- "color" "51 51 51"
- "textlist_var" "level"
- "textlist_rule" "<="
- "textlist"
- {
- "1" "200% Battle Point Booster"
- "3" "Extra Loading Screen Treasures"
- "4" "Kunkka's Courier: Lieutenant Squawkins"
- "10" "220% Battle Point Booster"
- }
 - }
Image Element Parameters
Image elements are used to display an image.
Parameters:
- "x"
 - Element X position. Pages are 512x608.
 
 - "y"
 - Element Y position. Pages are 512x608.
 
 - "w"
 - Element width. The image will be scaled to fit.
 
 - "h"
 - Element height. The image will be scaled to fit.
 
 - "scaleX"
 - An amount to scale the image by horizontally. Defaults to 1. Negative values will flip the image, so -1 would draw the image fully flipped along the horizontal axis.
 
 - "scaleY"
 - An amount to scale the image by vertically. Defaults to 1. Negative values will flip the image, so -1 would draw the image fully flipped along the vertical axis.
 
 - "depth"
 - Either "front" or "back" ("front" if unspecified). Front elements will be placed in front of existing content in the template. Back will be behind. Bear in mind that the order that elements are specified is the order they're placed on the page.
 
 - "filename"
 - The filename of the image. It should match the filename of an image sitting in the same directory as the compendium script file. Alternatively, you can specify the relative path of an existing image inside Dota 2's resource\flash3 directory (i.e. "images/heroes/beastmaster.png" or "images/items/abyssal_blade.png")
 
 - "color"
 - An optional RGB value to multiply the image color by.
 
 - "tooltip_data"
 - An optional section describing the tooltip for this image, if you want one. See Tooltip Parameters.
 
 - "link_to_page"
 - Value must match the name of one of your pages in your compendium. Clicking on this image will jump to that page.
 
 - "link_to_url"
 - Value should be a URL. Clicking on this text will popup that URL in an external browser.
 
 - "show_selection_tooltip"
 - If set to the index of a Selection, rolling the mouse over this image will pop up a tooltip. The tooltip will be configured based on the "tooltip_data" section of the Selection (not this text field's). This allows custom tooltips per choice in the Selection.
 
 - "show_selection_index"
 - If set to the index of a Selection, this image will change the image it's displaying to match the image specified in the "show_selection_images" section of the selection.
 
 - "imagestyle"
 - Set to "movie" if you want this image to show the Hero portrait movie of the Hero matching the value of the selection in the "show_selection_index" selection, instead of the static Hero icon.
 
 
Selection Element Parameters
Selections require several parameters to tell Dota 2 how to store and display them. If the Selection is shown as a combo box in the compendium, those parameters can be specified in the combo box section itself. If the Selection isn't a combo box (i.e. it's set by a button, or it's set by something on the Dota 2 backend), then the parameters can be specified in the root "preregister_selections" section.
Parameters shared by all types of selections are as follows:
- selection_index
 - The index of this selection. No two selections can share the same index. Other elements will use this index to refer to this selection.
 
 - "choice_type"
 - The type of choices that this selection is using. Available choices are:
- "generic" - Choices are a list of strings and corresponding IDs. The strings will be used to display the choices, and the backend will store the IDs.
- "hero" - Choices must be a list of Hero IDs. They'll be displayed with Hero names.
- "all_heroes" - Choices will be automatically filled out for you with a list of all Hero names.
- "all_items" - Choices will be automatically filled out for you with a list of all Item names.
- "counter" - Set by the Dota 2 Backend, not selected by users. Displayed as a raw number.
- "accountid" - Set by the Dota 2 Backend, not selected by users. Displayed as the profile name on the Steam Profile matching the account ID.
 
 
- The type of choices that this selection is using. Available choices are:
 - "choices"
 - This must be a section that lists all the valid choices for this selection. Not required for "all_heroes", "all_items", or "counter" selections. Each choice should have a text description, and a unique choice value. For selections of type "hero", the choice values should match the Hero IDs.
 
 - "time"
 - The time at which this selection can no longer be changed by players. Should be set to the name of a timer specified in the root "timers" section.
 
 - "description"
 - The text description of this selection.
 
 - "backend_desc"
 - A description for this selection shown only to you when using the Edit League web page to view your compendium stats.
 
 - "points"
 - The number of points this selection is worth. Generally used only for predictions. If unspecified it defaults to 0, and won't be shown in the UI.
 
 - "selection_element_color"
 - In addition to being changeable by a combo box, selections can also be setup to be changeable by buttons. The standard method is to have a button that the player clicks (something like "CHOOSE A TEAM"), which then highlights a set of images on the page (such as a set of team logos), and once the player then clicks on one of those logos the selection is set to the matching team's ID. If this selection works like that, set "selection_element_color" to the RGB value that you want the highlight element around the images to have.
 
 - "selection_set"
 - An optional string that, if matching other selections in the compendium, ensures that no two selections in the set are ever set to the same choice. Useful for things like All-Star match votes, where you don't want players to be able to select the same player in multiple slots.
 
 - "empty_string"
 - An optional string that will be shown instead of "Make A Selection" when the user hasn't selected a choice.
 
 - "tooltip_data"
 - An optional section that lists all the choices for this selection, and their associated tooltip data. Any textfield setup to show the value of this selection will use the tooltip data for the current choice. See Tooltip Parameters to see how to setup an individual tooltip.
 
 - "show_selection_images"
 - An optional section that lists all the choices in this selection, and their associated image filename. Any image setup to show the image for this selection will use the image corresponding to the current choice.
 
 - "action"
 - The name of a registered action in the root "event_actions" list. If an action has selections listed for it, the action will be considered completed once all the selections for it have been set by the player. Not available to third party compendiums at this time.
 
 - "result"
 - A section used to specify the result for selections that are being used as predictions. The result section contains the correct answer for the selection, and any extra information for the user if they click the "More Info" button (shown only for combo box selections). The parameters inside the result section are:
- "answer"
 - The choice value of the correct answer for this selection.
 
 
 - "answers"
 - If there were multiple right answers, then use this instead of "answer". This should be a section containing a list of choice values (key is the choice value, value can just be "1").
 
 
 - "info_dialog"
 - An optional section containing extra information about the result. If this exists, the "More Info" button will be shown on the selection's combo box UI. Parameters inside this section are:
- "match_id"
 - If set the ID of a tournament match, the "Watch Replay" button will be shown, and clicking on it will start the replay downloading & watching process.
 
 
 - "info"
 - A string containing extra information about this result. Will be shown in the results popup dialog.
 
 
 - "result_override"
 - An optional string that overrides the result showing in the results popup dialog. By default, the popup dialog will show the correct answer using the text description of the choice value of the "answer" key. But if you have multiple "answers", it's generally best if you write a more custom description here (i.e. "Bob & Mike tied for first place with matching scores of 100").
 
 
 
 
- An optional section containing extra information about the result. If this exists, the "More Info" button will be shown on the selection's combo box UI. Parameters inside this section are:
 
 
 
- A section used to specify the result for selections that are being used as predictions. The result section contains the correct answer for the selection, and any extra information for the user if they click the "More Info" button (shown only for combo box selections). The parameters inside the result section are:
 
Selections that are shown as combo boxes also require the following parameters:
- "x"
 - Element X position. Pages are 512x608.
 
 - "y"
 - Element Y position. Pages are 512x608.
 
 - "textcolor"
 - The RGB color of the description text above the combo box.
 
 - "bgcolor"
 - The RGB color of the shaded background in the combo box itself.
 
 - "combotextcolor"
 - The RGB color of the text inside the combo box.
 
 - "style"
 - The visual style of the combo box. Right now, only "s_CompendiumSelectionPlain" is supported.
 
 
Examples
A selection holding the votes for arcana items. It's a generic choice type, so the heroes aren't specified by ID. The selection UI used a button and images, not a combo box, so it has the selection element color specified.
 Example Example- "arcana_select_group1"
 - {
 "selection_index" "301"
 "selection_element_color" "0 255 0"
 "time" "arcana"
 "description" "YOUR PICK FROM GROUP 1"
 "choice_type" "generic"
 "choices"
 {
 "Storm Spirit" "1"
 "Faceless Void" "2"
 "Huskar" "3"
 "Pudge" "4"
 "Spectre" "5"
 "Jakiro" "6"
 "Lone Druid" "7"
 }
 }
A selection holding the player's favorite team. This selection uses a combo box for the selection, but it's part of a full page with a "PICK YOUR PAVORITE TEAM" treatment. As a result, it leaves the "description" key blank, and specifies a "backend_desc" so that we can easily find the result in the compendium stats report. Note also that the team names have the ^^ escape sequence at the start of them to tell the localization system that these strings should not be localized.
 Example Example- "favorite_team_selection"
 - {
 "x" "100"
 "y" "20"
 "textcolor" "93 57 93"
 "bgcolor" "93 57 93"
 "combotextcolor" "243 234 217"
 "selection_index" "601"
 "time" "mainevent"
 "backend_desc" "Favorite Team"
 "choice_type" "generic"
 "choices"
 {
 "^^Alliance" "1"
 "^^Titan" "2"
 "^^EG" "3"
 "^^Fnatic" "4"
 "^^NewBee" "5"
 "^^VG" "6"
 "^^Na'Vi" "7"
 "^^DK" "8"
 "^^IG" "9"
 "^^C9" "10"
 "^^Empire" "11"
 "^^Na'Vi.US" "12"
 "^^Arrow Gaming" "13"
 "^^LGD Gaming" "14"
 "^^Mousesports" "15"
 "^^Liquid" "16"
 "^^MVP Phoenix" "17"
 "^^CIS-Game" "18"
 "^^Virtus.Pro" "19"
 }
 }
A selection that handles a combo box for predicting which Hero had the most kills. Since it's an "all_heroes" selection, it doesn't need a list of choices. Now that the prediction time is over, it contains the results in the form of Hero IDs - in this case, Axe & Slark tied. Note that it also contains an optional info dialog block with some extra information.
 Example Example- "hero_with_most_kills"
 - {
 "x" "100"
 "y" "150"
 "textcolor" "93 57 93"
 "bgcolor" "93 57 93"
 "combotextcolor" "243 234 217"
 "selection_index" "30"
 "description" "HERO WITH THE MOST KILLS"
 "points" "4"
 "choice_type" "all_heroes"
 "time" "qualifiers"
 "result"
 {
 "answers"
 {
 "2" "1" // Axe's Hero ID
 "93" "1" // Slark Hero ID
 }
 "info_dialog"
 {
 "info" "Axe and Slark tied with 22 kills"
 "match_id" "679787098"
 }
 }
 }
Button Element Parameters
Button elements are clickable buttons that allow users to provide input. Generally used as an alternative to combo boxes for setting selections.
Parameters:
- "x"
 - Element X position. Pages are 512x608.
 
 - "y"
 - Element Y position. Pages are 512x608.
 
 - "style"
 - The style of the button. Valid styles are "button_transparent", "button_solid", "button_gradient", and "button_close".
 
 - "color"
 - An optional RGB value to multiply the button color by. Not all button styles support color setting at this time.
 
 - "text"
 - The text inside the button. Not all button styles support text ("button_close" is just an X, for instance)
 
 - "align"
 - How the X position of the button should be used, since button automatically expand to contain their text. "left" will make the button expand to the right (so the X position will be the left edge of the button), "right" will make it expand to the left (so the X position will be the right edge of the button), and "center" will make it expand equally in both directions (so the X position will be the middle of the button).
 
 - "show_confirmdialog"
 - If you want to show an Are You Sure? dialog when the user clicks on this button, then this should be the descriptive text to be shown in the dialog. If unspecified, the button will apply its effects immediately on being clicked.
 
 - "selection_index"
 - If you want this button to set the value of a selection when clicked by the user, this should be the selection index of the selection you want to set. The selection must be described in the root "preregister_selections" section. Only useful if you also specify "selection_elements" or "selection_force_to".
 
 - "selection_elements"
 - A section containing a list of elements that should be highlighted when the user clicks on this button. Each element must have a corresponding choice value. When the user clicks on one of the highlighted elements, the selection will be set to the choice value. The button will automatically change to a "Cancel" button while the elements are being highlighted. See examples below to see how useful this is.
 
 - "selection_force_to"
 - If you want this button to immediately set the value of a selection when clicked by the user, this should be the choice value you want the selection to be set to.
 
 - "link_to_page"
 - If you want this button to take the user to a compendium page when clicked by the user, this should be the name of one of your pages in your compendium.
 
 - "link_to_url"
 - If you want this button to take the user to a URL in their external browser, this should be the target URL.
 
 - Used to control when this element is visible / non visible. Elements are always visible by default.
 
 - "command"
 - If you want this button to issue a command issued when clicked by the user, this should be the command. Valid commands are as follows:
- "goto_tournament"
 - The compendium will close and the user will be taken to the Live Games section of the Watch tab.
 
 
 - "goto_offerings"
 - The compendium will close and the user will be taken to the Offerings section of the Armory.
 
 
 - "compendium_buy_and_useX"
 - X must be the index of an item definition. This will initiate the purchase of the specified item.
 
 
 - "request_heroes", "reroll_heroes", and "roll_daily_hero"
 - These are used to handle the TI4 challenges, and are now obsolete.
 
 
 
 
- If you want this button to issue a command issued when clicked by the user, this should be the command. Valid commands are as follows:
 
An example button for selecting a favorite hero. When the user clicks the button, a set of hero icons are highlighted to allow the user to click directly on the hero they want to choose. Note that this button is only visible when selection 301 is 0 (unset).
 Example Example- "selecthero1"- {
 "elementtype" "button"
 "style" "button_transparent"
 "text" "SELECT HERO"
 "x" "380"
 "y" "175"
 "align" "center"
 "color" "255 255 255"
 "visible_when_selection_is" "0"
 "selection_index" "301"
 "selection_elements"
 {
 "heroicon1" "15"
 "heroicon2" "22"
 "heroicon3" "36"
 "heroicon4" "41"
 "heroicon5" "50"
 "heroicon6" "65"
 "heroicon7" "77"
 }
 }
An example button that simply clears the specified selection. Note that it's only visible when selection 301 is not 0 (i.e. has been set).
 Example Example- "clearhero1"
 - {
 "elementtype" "button"
 "style" "Button_Close"
 "x" "435"
 "y" "145"
 "align" "center"
 "color" "255 255 255"
 "selection_index" "301"
 "selection_force_to" "0"
 "visible_when_selection_not" "0"
 }
Timer Element Parameters
Timer elements are non-interactive displays showing the amount of time left until a specified time is reached. Generally used as countdown displays on pages with user selections that close at some point.
Parameters:
- "x"
 - Element X position. Pages are 512x608.
 
 - "y"
 - Element Y position. Pages are 512x608.
 
 - "time"
 - The name of the time entry in the root "timers" section that this timer display is referring to.
 
 - "textcolor_title"
 - The RGB value of the title text in the display.
 
 - "textcolor_sub"
 - The RGB value of the subtitle text in the display.
 
 - "maxseconds"
 - If you want to clamp the maximum time the timer is allowed to show, set this value to that max time (in seconds).
 
 - "timerstyle"
 - Can be set to "hero_challenge" for 24 Hour Hero Challenge timers. Should be left out otherwise.
 
 
 Example Example- "mainevent_timer"
 - {
 "elementtype" "timer"
 "x" "156"
 "y" "525"
 "time" "mainevent"
 "textcolor_title" "93 57 93"
 "textcolor_sub" "93 57 93"
 }
ProgressBar Element Parameters
Progress Bars are non interactive elements designed to show the percentage progress towards something. Note that progress bar elements only draw the filled portion of a progress bar. It's generally best to place them on top of an image that acts as the underlying unfilled portion.
Parameters:
- "x"
 - Element X position. Pages are 512x608.
 
 - "y"
 - Element Y position. Pages are 512x608.
 
 - "w"
 - Element width. This is the maximum width of the filled bar. The actual drawn width of the bar will be between 0 and this value.
 
 - "h"
 - Element height.
 
 - "data"
 - The data source that this progress bar is reading from. Currently supported sources are "prizepool" and "level" (of the compendium).
 
 - "min"
 - The value of the data source at which the bar should be 0 width. Values below this will be clamped.
 
 - "max"
 - The value of the data source at which the bar should be at 100% width. Values above this will be clamped.
 
 - "color"
 - The RGB color of the filled portion of the bar.
 
 - "filename"
 - If you'd like to use an image to represent the portion of the filled bar, instead of a filled block of color, then specify the image filename here. It should match the filename of an image sitting in the same directory as the compendium script file. Alternatively, you can specify the relative path of an existing image inside Dota 2's resource\flash3 directory (i.e. "images/heroes/beastmaster.png" or "images/items/abyssal_blade.png")
 
 
 Example Example- "main_progressbar"
 - {
 "elementtype" "progressbar"
 "x" "53"
 "y" "190"
 "w" "406"
 "h" "21"
 "data" "prizepool"
 "min" "1600000"
 "max" "6000000"
 "filename" "compendium2014_bar_stretchgoalbar_filler.png"
 }
Video Element Parameters
Video elements display an embedded, playable video. Note that these videos are set to a fixed size of 494x278.
Parameters:
- "x"
 - Element X position. Pages are 512x608.
 
 - "y"
 - Element Y position. Pages are 512x608.
 
 - "url"
 - This should be the embedded Youtube link. The best way to generate this URLs is to click on the Share option under your video and extract the URL. It's recommended that you add the following to the end of Youtube URLs: ?autoplay=1&fs=0&modestbranding=1&rel=0&showinfo=0
 
 - ch_url"
 - Chinese Dota 2 clients will use this url instead, since they often have tenuous access to Youtube. It's recommended that you add the following to the end of Youku URLs: &isAutoPlay=true
 
 
 Example Example- "embedded_video"
 - {
 "elementtype" "video"
 "x" "9"
 "y" "150"
 "url" "http://youtube.googleapis.com/v/Eqk9C1wVT0U?autoplay=1&fs=0&modestbranding=1&rel=0&showinfo=0"
 "ch_url" "http://static.youku.com/v1.0.0401/v/swf/loader.swf?VideoIDS=XNjc3MTU2Mzk2&isAutoPlay=true"
 }
Container Element Parameters
Container elements are invisible elements that contain other elements. Extremely useful for organisational purposes, and powerful tools in templates.
Parameters:
- "x"
 - Element X position. Pages are 512x608.
 
 - "y"
 - Element Y position. Pages are 512x608.
 
 - "elementlist"
 - A section containing one or more child elements, to be created and contained inside this Container.
 
 - Relative Coordinates: "rx" & "ry"
 - Any child element inside a Container can also choose to use x/y positions relative to the Container's x/y. This allows you to easily position repeated blocks of elements. To use relative coordinates, the child element should use the "rx" and "ry" keys instead of the "x" and "y" keys.
 
 - Used to control when this element is visible / non visible. Elements are always visible by default. Note that elements contained inside this Container will only evaluate their own Visibility Parameters if this Container is visible. Hence, you can use visibility parameters inside Containers and their embedded children to do AND visibility operations.
 
 
This example container has three elements inside it. The container itself is only visible when selection 500 has a value of 0, and since the three elements are contained inside it, they follow the same rule. Note that the description text has additional visibility rules - it's only visible if selection 600 is not 0. That rule will only be evaluated if the container itself is visible, so the description text is only visible when selection 500 is 0 AND selection 600 is not 0. Note also that the lock button is using relative coordinates, so that its X & Y position are offset from the container's (resolving here to 55,100).
 Example Example- "favorite_hero_unset"
 - {
 "elementtype" "container"
 "x" "50"
 "y" "100"
 "visibility_selection_index" "500"
 "visible_when_selection_is" "0"
 "elementlist"
 {
 "selection_hero"
 {
 ...
 }
 "lockbutton"
 {
 "rx" "5"
 "ry" "0"
 ...
 }
 "description_text"
 {
 "visibility_selection_index" "600"
 "visible_when_selection_not" "0"
 ...
 }
 }
 }
Template Element Parameters
Templates are sections of KeyValues that can be easily replicated throughout your script file. They're essential for building easily maintainable compendiums. Note that templates must still specify an "elementtype", unless they expect all their instanced objects to specify one.
To build templates effectively, you must understand how they're implemented in the compendium. The easiest way to understand them is via an example. First, imagine we have a template called "template_pagetitle":
 Example Example- "template_pagetitle"
 - { 
 - "embedded_template" "1"
- "elementtype"       "textfield"
- "x" "0"
- "y" "46"
- "w" "512"
- "h" "20"
- "font" "title"
- "size" "16"
- "align" "center"
- "color" "93 57 93"
 - }
- "embedded_template" "1"
This is a useful template for our compendium - it's a textfield designed to show the title of a page. It has everything specified for a page title, minus the exact text to display. Note that it looks like a normal textfield, except that it has the "embedded_template" key set, which tells the compendium that it shouldn't create the textfield, it should register it as a template instead. Now we can instantiate that template in a page in the following way:
 Example Example- "page_example"
 - { 
 - "elementlist"
- {
 - "title"
- {
 - "t"    "template_pagetitle"
- "text" "MY BIG PAGE TITLE"
- "size" "20"
 
- "t"    "template_pagetitle"
- }
 
- "title"
- }
 - }
- "elementlist"
When the compendium system finds the "t" key, it goes looking for a template with the specified name. Once it finds the template, it merges all the template's keys into this section. Any keys that are in the derived instances will override any key inside the template, so in this case the larger size (20) will be left intact, and the template's smaller size (16) will be ignored. Post template resolution, the script file would be as follows:
 Example Example- "page_example"
 - { 
 - "elementlist"
- {
 - "title"
- {
 - "text"         "MY BIG PAGE TITLE"
- "size"         "20"
- "elementtype"  "textfield"
- "x" "0"
- "y" "46"
- "w" "512"
- "h" "20"
- "font" "title"
- "align" "center"
- "color" "93 57 93"
 
- "text"         "MY BIG PAGE TITLE"
- }
 
- "title"
- }
 - }
- "elementlist"
Note that the "embedded_template" key is not copied down into the instance, so that the instance doesn't become a template as well. As a result, if you have templates derived from other templates, you'll need to make sure they also have the "embedded_template" key set inside them, since they won't inherit it from their parent template.
Defines
Templates can also contain a section called "required_defines". This section contains a list of defines that any derived instances of the template must provide values for. When the templates are resolved by the compendium system, the values of the derived defines will replace any instances of the defines inside the template.
Define names must also follow a strict format:
- Start and end with the % character.
- Start with %def_ or %defloc_. If the define will contain text that needs to be localized, use %defloc_. Otherwise, use %def_.
To understand, let's look at an example. Lets say we want every one of our compendium pages to have a title, and a nice border image under it. We could define a template as follows. It contains both the textfield and the image, and a define for the text inside the textfield. Note that we want the title text to be localized, so we use the %defloc_ preface for our define name.
 Example Example- "titlesection_template"
 - { 
 - "elementtype"        "container"
- "required_defines"
- {
 - "%defloc_title%" "1"
 
- }
- "elementlist"
- {
 - "titletext"
- {
 - "t"            "t_page_title"
- "text"         "%defloc_title%"
 
- "t"            "t_page_title"
- }
- "background_image"
- {
 - "elementtype"  "image"
- "filename"     "compendium2014_titlebackground.png"
- "x"            "185"
- "y"            "35"
- "w"            "142"
- "h"            "42"
- "depth"        "back"
 
- "elementtype"  "image"
- }
 
- "titletext"
- }
 - }
- "elementtype"        "container"
We could then instantiate that template on a page as follows:
 Example Example- "page_example"
 - { 
 - "elementlist"
- {
 - "title"
- {
 - "t"    "titlesection_template"
- "defines"
- {
- "%defloc_title%" "MY PAGE TITLE"
 
- }
 
- "t"    "titlesection_template"
- }
 
- "title"
- }
 - }
- "elementlist"
This page would now display the title text field and image. The instance must contain a "defines" block with a value for every one of the defines listed in the template's "required_defines". The advantage of using defines are as follows:
- Instances don't need to know the internal structure of the template. In the case above, the "title" instance of the "titlesection_template" template doesn't need to contain a matching elementlist to put the "text" key into the right place within the "titletext" textfield. This allows the template to be redesigned without breaking any derived instances.
- Defines are error checked, so instances can't forget to specify a define necessary to the operation of the template.
- The define can be used in multiple places in the template, reducing the chances of incorrect data being specified by instances.
Here's a slightly more complex example. Note how it uses the %defloc_name% define in multiple textfields. It also uses the %def_ prefix for the logo, because it's an image filename and hence shouldn't be localized.
 Example Example- "template_qualifier_attendee"
 - { 
 - "embedded_template"   "1"
- "elementtype"         "container"
- "required_defines"
- {
 - "%defloc_name%"    "1"
- "%def_logo%"       "1"
 
- "%defloc_name%"    "1"
- }
- "elementlist"
- {
 - "name"
- {
 - "t"         "attendee_name"
- "text"      "%defloc_name%"
 
- "t"         "attendee_name"
- }
- "logo"
- {
 - "t"         "img_teambig"
- "filename"  "%def_logo%"
 
- "t"         "img_teambig"
- }
- "tiny_name"
- {
 - "t"         "attendee_name"
- "size"      "8"
- "text"      "%defloc_name%"
 
- "t"         "attendee_name"
- }
 
- "name"
- }
 - }
- "embedded_template"   "1"
Nested Templates
One useful technique is having templates that derived from other templates. For instance, you may want to have a root textfield template that sets up your fonts and colors, and then some derived templates for titles, subtitles, and descriptive blocks. KeysValues inside nested templates are merged downwards through the template chain just like any other key - keys in the lower templates will override the keys in the upper templates.
Debugging
Liberal usage of templates and defines can lead to situations where your compendium script file is reporting bugs that are tricky to track down. A useful tool for debugging them is the "test_compendium_writeposttemplates" convar. If you set it to 1 in the Dota 2 console, and then run your "test_compendium" command, the compendium system will save your script file to disk after it's resolved all the templates in it.
You can find the resolved script file under your Dota 2 directory in the following file: \dota\compendium_datafile.txt
Generic Element Parameters
Generic elements are specific scaleform elements embedded in the compendium .FLA file. The only current usage for them is to create Scrolling View elements (i.e. embedded windows with scrollbars).
Standard Parameter Sections
Some parameters are available to more than one element type. This section contains a list of these standard parameter blocks.
Visibility Parameters
There are a wide variety of visibility controls that allow you to control the visibility of your elements. Combining multiple visibility controls in the same element can be confusing, so think of it this way: Elements are visible by default, and become invisible when they fail one of the rules below.
- "visible_when_prizepool_less"
 - Element will only be visible when the League's prizepool is less than the specified value.
 
 - "visible_when_prizepool_more"
 - Element will only be visible when the League's prizepool is more than the specified value.
 
 - "visible_when_level_less"
 - Element will only be visible when the compendium level is less than the specified value.
 
 - "visible_when_level_more"
 - Element will only be visible when the compendium level is more than the specified value.
 
 - "visibility_selection_index"
 - This is the selection index used in the following two selection-based visibility keys.
 
 - "visible_when_selection_is"
 - Element will only be visible when the visibility selection's current choice matches the specified value.
 
 - "visible_when_selection_not"
 - Element will only be visible when the visibility selection current choice is not the specified value.
 
 - "visible_when_selection_less"
 - Element will only be visible when the visibility selection current choice is less than the specified value.
 
 - "visible_when_selection_more"
 - Element will only be visible when the visibility selection current choice is more than the specified value.
 
 - "visible_after_time"
 - The value should be the name of a timer inside the root compendium "timers" section. This element will only be visible when the current time is past the timer's time.
 
 - "visible_until_time"
 - The value should be the name of a timer inside the root compendium "timers" section. This element will only be visible when the current time is earlier than the timer's time.
 
 - "visible_when_game_live"
 - Element will only be visible when the League has a live game being played.
 
 - "visible_when_action_started"
 - Value must be a valid Action ID. Element will only be visible when the corresponding Action has been started.
 
 
Tooltip Parameters
Text and Image elements support tooltips, and hence can contain the following tooltip settings. Selections can also contain a section with tooltip settings for every valid choice in the Selection - text fields that are showing the value of the Selection will then show the matching tooltip when moused over.
The following settings are used to configure a tooltip:
- "style"
 - The layout style of the tooltip. Must be "tooltip_titleandtext" or "tooltip_titletextandcountryflag".
 
 - "tooltip_title"
 - The text shown in the title of the tooltip.
 
 - "tooltip_text"
 - The text shown in the body of the tooltip.
 
 - "color_title"
 - The RGB value of the title text of the tooltip.
 
 - "color_text"
 - The RGB value of the body text of the tooltip.
 
 - "color_bg"
 - The RGB value of the background of the tooltip.
 
 - "filename"
 - The filename of an image, required only if the tooltip style has an image in it. "tooltip_titletextandcountryflag" contains a small country flag image.
 
 
Text Escape Sequences
Text elements can used escape sequences inside their "text" values. Escape sequences are chunks of text that will be replaced by dynamic information when the text is shown on screen. Some escape sequences require extra information to be specified in the "min" and "max" keys of the textfield.
Valid escape sequences:
- %prizepool%
 - Will be replaced by the current value of the League's prize pool.
 
 - %prizepool_togo%
 - Will be replaced by the difference between the League's current prize pool and the text field's "max" value.
 
 - %prizepool_perc%
 - Will be replaced by the percentage that the League's current prizepool is between the text field's "min" and "max" values.
 
 - %prizepool_owner%
 - Will be replaced by the amount of money the compendium owner has contributed to the League's prizepool.
 
 - %selection_X%
 - X must be a valid selection index. The escape sequence will be replaced with the current value of the Selection, based on the type of the selection.
 
 - %owner%
 - Will be replaced by the Steam Profile name of the compendium owner.
 
 - %level%
 - Will be replaced by the current level of the compendium.
 
 - %levelup_pts%
 - Will be replaced with the amount of compendium points needed to reach the next compendium level.
 
 - %textlistvalue_X%
 - X must the name of a valid textlist. Will be replaced by the currently visible text in the textlist.
 
 - %price_X%
 - X must be the definition index of a Dota 2 virtual item. Will show the price of that item in the Dota 2 store, in the user's local currency.
 
 - %action_X%
 - X must be a valid action ID. Will be replaced by the user's earned points for the specified action.
 
 - %actionmax_X%
 - X must be a valid action ID. Will be replaced by the maximum possible points for the specified action.
 
 - %actionscore_X%
 - X must be a valid action ID. Will be replaced by the user's score for the specified action.
 
 
Examples of valid escape sequence usage in textfield "text" keys:
 Example Example- "text" "$%prizepool%"
 - "text" "$%prizepool_togo% to go!"
 "text" "$%prizepool_owner%"
 "text" "You have won %selection_65211% of 10 games with your favorite hero."
 "text" "from %owner%"
 "text" "%levelup_pts% PTS TO NEXT LEVEL"
 "text" "LEVEL %textlistvalue_mytextlist%"