
Update v0.9.16 -- Added --clear to remove all turns from the turn order. If Auto Open Init is enabled, it will also close the turn order window. (Thanks Lucian H.!)
Update v0.9.15 -- Fixed bug with --reroll causing custom entries to be dropped off the Turn Order. (Thanks Three of Swords!)
Update v0.9.14 -- Fixed bug with --reroll not working if Replace Roll was off. (Thanks Three of Swords!)
Update v0.9.13 -- Fixed bug where having 10+ enemies could result in the wrong bonus being applied. (Thanks Jurph!)
Update v0.9.12 -- Split the rolls for initiative across multiple sendChat() calls. This fixes a problem with complex rolls overloading the API dice roller. (Thanks Kevin!)
Update v0.9.11 -- Fixed bug when the dice count attribute has been set with an API script (integer instead of string). (Thanks Dylan S.!)
Update v0.9.10 -- Fixed some bugs with certain attribute values. (Thanks Kevin!)
Update v0.9.9 -- Added --reroll to reroll all the tokens in the Turn Order as if they had all be selected. (Thanks Three of Swords!)
Update v0.9.8 -- Fixed crash bug when a character doesn't have an attribute for a rule. (Thanks Ken L and Three of Swords)
Update v0.9.7 -- Added Observable Pattern notifications (Taken advantage of by Bump v0.2.4 and higher). Other scripts can register to observe when GroupInitiative makes changes to the turn order. Sample code (from Bump):
Update v0.9.6 -- Fixed bug with default installed state for fresh script use (Thanks Joseph l.!)
Update v0.9.5 -- Allow players to execute !group-init and also access the --bonus argument.
Update v0.9.4 -- Fixed crash bug with Stat-DnD (Thanks Greg!)
Update v0.9.3 -- Fixed crash bug with missing attributes. (Thanks Kevin!)
Update v0.9.2 -- Fixed a crash bug with empty bonus groups. (Thanks Greg and Gozer!)
Update v0.9.1 -- Fixed a crash bug that had to do with Dice Count Attributes. (Thanks Vince!)
Update v0.9.0 -- This is a pretty massive change, so there may be some bugs (that Vince hasn't already found... =D ). First off, GroupInitiative is now using the dice engine to calculate rolls. This opens up the use of formula stats among other things. I had to remove the Bounded Stat adjustment, but I don't think anyone used that anyway. There are also a bunch of new configuration options in the help:
Update v0.8.7 - Added four Announcers to show the results of GroupInitiative

Update v0.8.5 - Fixed parsing of bonuses to allow floating point numbers.
Update v0.8.4 - Added Auto Sorting (Ascending,Descending, or None), Setting the Die Size to roll, and Popping up the TurnOrder on Group Init roll.
Update v0.8.3 - Fixed the regular expression for detecting bonuses to support decimals.
Update v0.8.2 - Support for decimal bonuses.
Update v0.8.1 - Removed dependency on isGM, added --bonus to add a number to the rolls:
Update v0.6 - Minor Bugfix to handling of second tier attributes. (Thanks Naz!)
Update v0.41 - Minor fix. HTML Special characters were getting subsisted for their values and breaking the Javascript. I've changed how they are generated to get rid of the "Unexpected identifier" error. (Thanks al e!)
Update v0.4 - Minor fix. A UTF-8 character had slipped into one of the strings. It shouldn't have caused any issues, but just in case, I've pulled it out in v0.4.
Update v0.3 - This version is so different, it's practically a full rewrite.See Below!
You can also chain multiple attribute specifications together. The Bonus is calculated by adding the results of each together. This would create a Bonus Stat Group that is the sum of the dexterity and initiative stats:
A more complicated example. This would specify a Bonus Stat Group which consists of the sum of the Dungeons and Dragons stat bonus computed for the max field of dexterity, the Dungeons and Dragons stat bonus computed from the max field of wisdom limited to a maximum of +2, and the current value ofinitiative.
Example. Assume you have the following 3 stat groups:
Hopefully that will be enough documentation that people can use this! If you have any issues, just let me know!


Git: https://github.com/shdwjk/Roll20API/blob/master/GroupInitiative/GroupInitiative.js
Update v0.9.15 -- Fixed bug with --reroll causing custom entries to be dropped off the Turn Order. (Thanks Three of Swords!)
Update v0.9.14 -- Fixed bug with --reroll not working if Replace Roll was off. (Thanks Three of Swords!)
Update v0.9.13 -- Fixed bug where having 10+ enemies could result in the wrong bonus being applied. (Thanks Jurph!)
Update v0.9.12 -- Split the rolls for initiative across multiple sendChat() calls. This fixes a problem with complex rolls overloading the API dice roller. (Thanks Kevin!)
Update v0.9.11 -- Fixed bug when the dice count attribute has been set with an API script (integer instead of string). (Thanks Dylan S.!)
Update v0.9.10 -- Fixed some bugs with certain attribute values. (Thanks Kevin!)
Update v0.9.9 -- Added --reroll to reroll all the tokens in the Turn Order as if they had all be selected. (Thanks Three of Swords!)
Update v0.9.8 -- Fixed crash bug when a character doesn't have an attribute for a rule. (Thanks Ken L and Three of Swords)
Update v0.9.7 -- Added Observable Pattern notifications (Taken advantage of by Bump v0.2.4 and higher). Other scripts can register to observe when GroupInitiative makes changes to the turn order. Sample code (from Bump):
if('undefined' !== typeof GroupInitiative && GroupInitiative.ObserveTurnOrderChange){ GroupInitiative.ObserveTurnOrderChange(handleTurnOrderChange); }Registered functions currently don't receive any parameters (I'm working on a generalized solution but this is my test case.).
Update v0.9.6 -- Fixed bug with default installed state for fresh script use (Thanks Joseph l.!)
Update v0.9.5 -- Allow players to execute !group-init and also access the --bonus argument.
Update v0.9.4 -- Fixed crash bug with Stat-DnD (Thanks Greg!)
Update v0.9.3 -- Fixed crash bug with missing attributes. (Thanks Kevin!)
Update v0.9.2 -- Fixed a crash bug with empty bonus groups. (Thanks Greg and Gozer!)
Update v0.9.1 -- Fixed a crash bug that had to do with Dice Count Attributes. (Thanks Vince!)
Update v0.9.0 -- This is a pretty massive change, so there may be some bugs (that Vince hasn't already found... =D ). First off, GroupInitiative is now using the dice engine to calculate rolls. This opens up the use of formula stats among other things. I had to remove the Bounded Stat adjustment, but I don't think anyone used that anyway. There are also a bunch of new configuration options in the help:
- For systems that use multiple dice for initiative, you can use the Initiative Dice Count to set the number of initiative dice to roll.
- For ShadowRun, you can now set an attribute to be used to determine the number of dice to roll. Look for Dice Count Attribute in the settings. This can be a simple formula, but it is a bit flakey so just be aware that it may crash your API. Once Nested Inline Rolls hit the API, it will be come more stable. Characters without that attribute (or where that attribute is a 0) will use the Initiative Die Count to determine the number of dice to roll.
- You can now use attributes that have formulas in them as part of your Bonus Stat Groups
!group-init --add-group --Tie-Breaker dexterityUpdate v0.8.8 - Fixed the 3+6.06 = 9.05999999999999999 problem. =D (Thanks Ziechael!)
Update v0.8.7 - Added four Announcers to show the results of GroupInitiative
- None -- Doesn't announce anything
- Hidden -- Announces all rolls via whisper to the gm(s)
- Partial -- Announces rolls for PCs to all, but whispers NPCs to the gm(s) (PCs are any character with either All, or at least one non-gm as a controller)
- Visible -- Announces everything to everyone

Update v0.8.5 - Fixed parsing of bonuses to allow floating point numbers.
Update v0.8.4 - Added Auto Sorting (Ascending,Descending, or None), Setting the Die Size to roll, and Popping up the TurnOrder on Group Init roll.
Update v0.8.3 - Fixed the regular expression for detecting bonuses to support decimals.
Update v0.8.2 - Support for decimal bonuses.
Update v0.8.1 - Removed dependency on isGM, added --bonus to add a number to the rolls:
!group-init --bonus 5Inline rolls are fine too (but note that the same bonus is applied to all selected in that case):
!group-init --bonus [[1d4]]
Update v0.6 - Minor Bugfix to handling of second tier attributes. (Thanks Naz!)
Update v0.41 - Minor fix. HTML Special characters were getting subsisted for their values and breaking the Javascript. I've changed how they are generated to get rid of the "Unexpected identifier" error. (Thanks al e!)
Update v0.4 - Minor fix. A UTF-8 character had slipped into one of the strings. It shouldn't have caused any issues, but just in case, I've pulled it out in v0.4.
Update v0.3 - This version is so different, it's practically a full rewrite.See Below!
Overview:
This script adds a command for rapidly adding large groups of tokens into the turn order. As of v0.3, there are quite a few configuration commands (seeCommands below). The basic process followed by the script is this:- Remove any tokens that already have a turn.
- For all selected tokens, find the character they represent.
- For each character, figure out the initiative bonus.
- Initiative bonuses are calculated using Bonus Stat Groups. Each Bonus Stat Group is a collection of Attribute Names and Stat Adjustmentoperations to apply to them.
- Bonus Stat Groups are evaluated in order. The first one that produces a bonus is used. If a character doesn't have one of the Attribute Nameslisted in the Bonus Stat Group (or that Attribute Name does not contain a valid number), that group does not produce a bonus.
- The selected Roller is used to generate the rolls for each token, with the bonus for its character applied (or 0 if it doesn't have a character).
- Add each token to the turn order.
Commands:
- !group-init
- This is the root api command. If you have any tokens selected, it will add them to the initiative order. If you don't have anything selected, it will show the help.
- !group-init --help
- This shows the help, which includes state information about the currently selected Roller, available Stat Adjustment Options, and the ordered list of Bonus Stat Groups.
- !group-init --add-group --<adjustment> [--<adjustment>] <attribute name[|<max|current>]> ...
- This command adds another Bonus Stat Group to the end of the list. Examples and further explanation below.
- !group-init --del-group <number>
- Removes the Bonus Stat Group identified by number.
- !group-init --promote <number>
- Moves the Bonus Stat Group identified by number up one slot.
- !group-init --set-roller <roller name>
- Sets the Roller to use for figuring initiative.
Rollers:
There are currently 4 different Rollers:- Least-All-Roll -- Roll 1d20+Bonus for every token, then take the lowest number as the initiative for all tokens. (Bryan K.)
- Mean-All-Roll -- Roll 1d20+Bonus for every token, then take the average (rounded down) roll as the initiative for all tokens.
- Individual-Roll -- Roll 1d20+Bonus for each token and set each token's initiative to whatever it rolled. (James the DM, GenKitty, etc)
- Constant-By-Stat -- Set the initiative to whatever the Bonus for that token is. (Michael H.)
Add-Group Detailed Explanation:
The --add-group command creates a new Bonus Stat Group. It takes one or more attribute specifications. An attribute specification is made up of one or more Stat Adjustment Options, followed by an Attribute Name (optionally with |max on the end).Stat Adjustment Options
- Bare -- Use this when you want just the attributes value. This will add a Bonus Stat Group with just the attribute dexterity in it.
!group-init --add-group --Bare dexterity
- Floor -- Use this to compute the floor of the value. This is useful when you have attributes that are decimal values, but you want a whole integer.
- Ceiling -- The same as Floor, but returns the next highest whole integer. The Bonus Stat Group added by this command would turn the attribute skill bonus from 2.35 to 3:
!group-init --add-group --Ceiling skill bonus
- Bounded:<low>:<high> -- Use this to restrict the value of an attribute to a particular range. This would specify a Bonus Stat Group where dexterity can only be between -2 and +2:
!group-init --add-group --Bounded:-2:2 dexterityTo leave a value unrestricted, you can leave the bound for that side empty. This would specify a Bonus Stat Group where dexterity has a maximum value of +4, but can be as low as it wants:
!group-init --add-group --Bounded::4 dexterity
- Stat-DnD -- Use this to convert an attribute from a Dungeons and Dragons Stat into the Stat's associated bonus. 18 becomes 4, 7 becomes -2, etc. This would specify a Bonus Stat Group which finds the stat bonus for the dexterity stat:
!group-init --add-group --Stat-DnD dexterity
Advanced Examples
You can chain multiple Stat Adjustment Options together. This would specify a Bonus Stat Group where dexterity is first converted to a Dungeons and Dragons stat bonus, and then is bounded to a maximum of +2:!group-init --add-group --Bounded::2 --Stat-DnD dexterityStat Adjustment Options always operate on the value to the right. In the example above, Bounded would be applied to whatever is returned from Stat-DnD.
You can also chain multiple attribute specifications together. The Bonus is calculated by adding the results of each together. This would create a Bonus Stat Group that is the sum of the dexterity and initiative stats:
!group-init --add-group --Bare dexterity --Bare initiative
A more complicated example. This would specify a Bonus Stat Group which consists of the sum of the Dungeons and Dragons stat bonus computed for the max field of dexterity, the Dungeons and Dragons stat bonus computed from the max field of wisdom limited to a maximum of +2, and the current value ofinitiative.
!group-init --add-group --Stat-DnD dexterity|max --Bounded::2 --Stat-DnD wisdom|max --Bare initiative
Computing the Bonus
When the Bonus is computed for a character, the Bonus Stat Groups are considered in order. The first Bonus Stat Group to produce a number is used. When a Bonus Stat Group is evaluated, it will produce a number as long as every referenced attribute is present and numeric on the character.Example. Assume you have the following 3 stat groups:
- dexterity|current + initiative|current + rage|current
- dexterity|current + initiative|current
- dexterity|current
Hopefully that will be enough documentation that people can use this! If you have any issues, just let me know!


Git: https://github.com/shdwjk/Roll20API/blob/master/GroupInitiative/GroupInitiative.js
If you use my scripts, want to contribute, and have the spare bucks to do so, go right ahead. However, please don't feel like you must contribute just to use them! I'd much rather have happy Roll20 users armed with my scripts than people not using them out of some sense of shame. Use them and be happy, completely guilt-free!
Disclaimer: This Patreon campaign is not affiliated with Roll20; as such, contributions are voluntary and Roll20 cannot provide support or refunds for contributions.