Skip to content

Commit 58bedc6

Browse files
committed
Updated 3 Scripts
1 parent bb5c395 commit 58bedc6

File tree

9 files changed

+2671
-164
lines changed

9 files changed

+2671
-164
lines changed

GroupInitiative/0.9.28/GroupInitiative.js

+1,709
Large diffs are not rendered by default.

GroupInitiative/GroupInitiative.js

+39-2
Original file line numberDiff line numberDiff line change
@@ -5,8 +5,8 @@
55
var GroupInitiative = GroupInitiative || (function() {
66
'use strict';
77

8-
var version = '0.9.27',
9-
lastUpdate = 1498239221,
8+
var version = '0.9.28',
9+
lastUpdate = 1515682154,
1010
schemaVersion = 1.1,
1111
bonusCache = {},
1212
observers = {
@@ -674,6 +674,13 @@ var GroupInitiative = GroupInitiative || (function() {
674674
'</ul>'+
675675
'</div>'+
676676
'</div>'+
677+
678+
'<div style="padding-left:10px;">'+
679+
'<b><span style="font-family: serif;">!group-init <i>--toggle-turnorder</i> '+ch('[')+'bonus'+ch(']')+'</span></b>'+
680+
'<div style="padding-left: 10px;padding-right:20px">'+
681+
'<p>Opens or closes the Turnorder window.</p>'+
682+
'</div>'+
683+
'</div>'+
677684

678685
'<div style="padding-left:10px;">'+
679686
'<b><span style="font-family: serif;">!group-init <i>--sort</i></span></b>'+
@@ -994,6 +1001,9 @@ var GroupInitiative = GroupInitiative || (function() {
9941001
break;
9951002

9961003
case 'stack': {
1004+
if(!playerIsGM(msg.playerid)){
1005+
return;
1006+
}
9971007
cmds.shift();
9981008
let operation=cmds.shift(),
9991009
showdate=function(ms){
@@ -1250,6 +1260,21 @@ var GroupInitiative = GroupInitiative || (function() {
12501260
}
12511261
break;
12521262

1263+
case 'toggle-turnorder':
1264+
if(!playerIsGM(msg.playerid)){
1265+
return;
1266+
}
1267+
if(false !== Campaign().get('initiativepage') ){
1268+
Campaign().set({
1269+
initiativepage: false
1270+
});
1271+
} else {
1272+
let player = (getObj('player',msg.playerid)||{get: ()=>true});
1273+
Campaign().set({
1274+
initiativepage: player.get('_lastpage')
1275+
});
1276+
}
1277+
break;
12531278
case 'reroll':
12541279
isReroll=true;
12551280
if(cmds[1] && cmds[1].match(/^[-+]?\d+(\.\d+)?$/)){
@@ -1268,6 +1293,9 @@ var GroupInitiative = GroupInitiative || (function() {
12681293
break;
12691294

12701295
case 'sort':
1296+
if(!playerIsGM(msg.playerid)){
1297+
return;
1298+
}
12711299
Campaign().set('turnorder', JSON.stringify(
12721300
sorters[state.GroupInitiative.config.sortOption](
12731301
JSON.parse(Campaign().get('turnorder'))||[]
@@ -1277,6 +1305,9 @@ var GroupInitiative = GroupInitiative || (function() {
12771305
break;
12781306

12791307
case 'adjust':
1308+
if(!playerIsGM(msg.playerid)){
1309+
return;
1310+
}
12801311
if(cmds[1] && cmds[1].match(/^[-+]?\d+(\.\d+)?$/)){
12811312
manualBonus=parseFloat(cmds[1]);
12821313
manualBonusMin=parseFloat(cmds[2]);
@@ -1303,6 +1334,9 @@ var GroupInitiative = GroupInitiative || (function() {
13031334
break;
13041335

13051336
case 'adjust-current':
1337+
if(!playerIsGM(msg.playerid)){
1338+
return;
1339+
}
13061340
if(cmds[1] && cmds[1].match(/^[-+]?\d+(\.\d+)?$/)){
13071341
manualBonus=parseFloat(cmds[1]);
13081342
manualBonusMin=parseFloat(cmds[2]);
@@ -1330,6 +1364,9 @@ var GroupInitiative = GroupInitiative || (function() {
13301364

13311365

13321366
case 'clear':
1367+
if(!playerIsGM(msg.playerid)){
1368+
return;
1369+
}
13331370
Campaign().set({
13341371
turnorder: '[]',
13351372
initiativepage: (state.GroupInitiative.config.autoOpenInit ? false : Campaign().get('initiativepage'))

GroupInitiative/script.json

+3-2
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
{
22
"name": "GroupInitiative",
3-
"version": "0.9.27",
3+
"version": "0.9.28",
44
"description": "Rolls initiative for the selected tokens and adds them to the turn order if they don't have a turn yet.\r\rThe calculation of initiative is handled by the combination of Roller (See **Roller Options** below) and a Bonus. The Bonus is determined based on an ordered list of Stat Groups (See **Bonus Stat Groups** below). Stat Groups are evaluated in order. The bonus computed by the first Stat Group for which all attributes exist and have a numeric value is used. This allows you to have several Stat Groups that apply to different types of characters. In practice you will probably only have one, but more are there if you need them.\r\r\r## Commands\r\r```!group-init ```\r\rThis command uses the configured Roller to determine the initiative order for all selected tokens.\r\r```!group-init --help```\r\rThis command displays the help and configuration options, as well as the currently configured groups.\r\r```!group-init --promote <index>```\r\rIncreases the importance the specified Bonus Stat Group.\r\rThis command requires 1 parameter:\r\r* `index` -- The numeric index of the Bonus Stat Group to promote.\r\r`!group-init --del-group <index>`\r\rDeletes the specified Bonus Stat Group.\r\rThis command requires 1 parameter:\r\r* `index` -- The numeric index of the Bonus Stat Group to delete.\r\r```!group-init --add-group --<adjustment> [--<adjustment>] <attribute name[|<max|current>]> [--<adjustment> [--<adjustment>] <attribute name[|<max|current>]> ...]```\r\rAdds a new Bonus Stat Group to the end of the list. Each adjustment operation can be followed by another adjustment operation, but eventually must end in an attriute name. Adjustment operations are applied to the result of the adjustment operations that follow them.\r\rFor example: `--Bounded:-2:2 --Stat-DnD wisdom|max` would first computer the DnD Stat bonus for the max field of the wisdom attribute, then bound it between `-2` and `+2`.\r\rThis command takes multiple parameters:\r\r* `adjustment` -- One of the Stat Adjustment Options.\r* `attribute name` -- The name of an attribute. You can specify `|max` or `|current` on the end to target those specific fields (defaults to `|current`).\r\r```!group-init --reroll```\r\rRerolls all the tokens in the turn order as if they were selected when you executed the bare `!group-init` command.\r\r```!group-init --clear```\r\rRemoves all tokens from the turn order. If Auto Open Init is enabled it will also close the turn order box.\r\r## Roller Options\r\r* `Least-All-Roll` -- Sets the initiative to the lowest of all initiatives rolled for the group.\r* `Mean-All-Roll` -- Sets the initiative to the mean (average) of all initiatives rolled for the group.\r* `Individual-Roll` -- Sets the initiative individually for each member of the group.\r* `Constant-By-Stat` -- Sets the initiative individually for each member of the group to their bonus with no roll.\r\r## Stat Adjustment Options\r\r* `Stat-DnD` -- Calculates the bonus as if the value were a DnD Stat.\r* `Bare` -- No Adjustment.\r* `Floor` -- Rounds down to the nearest integer.\r* `Tie-Breaker` -- Adds the accompanying attribute as a decimal (`0.01`)\r* `Ceiling` -- Rounds up to the nearest integer.\r* `Bounded` -- **DEPREICATED** - will not work with expresions.",
55
"authors": "The Aaron",
66
"roll20userid": "104025",
@@ -26,6 +26,7 @@
2626
"0.9.23",
2727
"0.9.24",
2828
"0.9.25",
29-
"0.9.26"
29+
"0.9.26",
30+
"0.9.27"
3031
]
3132
}

Mark/0.3.5/Mark.js

+221
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,221 @@
1+
// Github: https://github.com/shdwjk/Roll20API/blob/master/Mark/Mark.js
2+
// By: The Aaron, Arcane Scriptomancer
3+
// Contact: https://app.roll20.net/users/104025/the-aaron
4+
5+
var Mark = Mark || (function() {
6+
'use strict';
7+
8+
var version = '0.3.5',
9+
lastUpdate = 1514912751,
10+
schemaVersion = 0.2,
11+
markerURL = 'https://s3.amazonaws.com/files.d20.io/images/4994795/7MdfzjgXCkaESbRbxATFSw/thumb.png?1406949835',
12+
13+
ch = function (c) {
14+
var entities = {
15+
'<' : 'lt',
16+
'>' : 'gt',
17+
"'" : '#39',
18+
'@' : '#64',
19+
'{' : '#123',
20+
'|' : '#124',
21+
'}' : '#125',
22+
'[' : '#91',
23+
']' : '#93',
24+
'"' : 'quot',
25+
'-' : 'mdash',
26+
' ' : 'nbsp'
27+
};
28+
29+
if(_.has(entities,c) ){
30+
return ('&'+entities[c]+';');
31+
}
32+
return '';
33+
},
34+
35+
showHelp = function(who) {
36+
sendChat('',
37+
'/w "'+who+'" '
38+
+'<div style="border: 1px solid black; background-color: white; padding: 3px 3px;">'
39+
+'<div style="font-weight: bold; border-bottom: 1px solid black;font-size: 130%;">'
40+
+'Mark v'+version
41+
+'</div>'
42+
+'<div style="padding-left:10px;margin-bottom:3px;">'
43+
+'<p>Mark places a numbered marker under each token whose id is supplied '
44+
+'to it. Markers are cleared when the Turn Order changes, is closed, '
45+
+'or when the player page changes. This script is intended to allow players '
46+
+'to mark their targets for discussion with the GM, usually as part of an '
47+
+'attack.</p>'
48+
+'</div>'
49+
+'<b>Commands</b>'
50+
+'<div style="padding-left:10px;">'
51+
+'<b><span style="font-family: serif;">!mark '+ch('<')+'Token ID'+ch('>')+' ['+ch('<')+'Token ID'+ch('>')+' ... ]</span></b>'
52+
+'<div style="padding-left: 10px;padding-right:20px">'
53+
+'<p>This command requires a minimum of 1 parameter. For each supplied Token ID, a marker is placed beneath it with a numbered status. The status number starts at 1, increases with each marker placed, and resets the when markers are cleared.</p>'
54+
+'<p><b>Note:</b> If you are using multiple '+ch('@')+ch('{')+'target'+ch('|')+'token_id'+ch('}')+' calls in a macro, and need to mark fewer than the suppled number of arguments, simply select the same token several times. The duplicates will be removed.</p>'
55+
+'<ul>'
56+
+'<li style="border-top: 1px solid #ccc;border-bottom: 1px solid #ccc;">'
57+
+'<b><span style="font-family: serif;">'+ch('<')+'Token ID'+ch('>')+'</span></b> '+ch('-')+' A Token ID, usually supplied with something like '+ch('@')+ch('{')+'target'+ch('|')+'Target 1'+ch('|')+'token_id'+ch('}')+'.'
58+
+'</li> '
59+
+'</ul>'
60+
+'</div>'
61+
+'<b><span style="font-family: serif;">!mark-clear</span></b>'
62+
+'<div style="padding-left: 10px;padding-right:20px">'
63+
+'<p>Clears all the markers. (GM Only)</p>'
64+
+'</div>'
65+
+'</div>'
66+
+'</div>'
67+
);
68+
},
69+
70+
reset = function() {
71+
state.Mark.count=0;
72+
_.each(findObjs({
73+
type: 'graphic',
74+
subtype: 'token',
75+
imgsrc: markerURL
76+
}), (g)=>g.remove());
77+
},
78+
79+
getStatusForCount = function(count) {
80+
var colorOrder=["red", "blue", "green", "brown", "purple", "pink", "yellow"];
81+
return _.chain(count.toString().split(''))
82+
.reduce(function(memo,d){
83+
if(colorOrder.length) {
84+
memo.push(colorOrder.shift()+'@'+d);
85+
}
86+
return memo;
87+
}, [])
88+
.value()
89+
.reverse()
90+
.join(',');
91+
},
92+
93+
handleInput = function(msg) {
94+
var args,
95+
who,
96+
errors=[],
97+
tokens;
98+
99+
if (msg.type !== "api" ) {
100+
return;
101+
}
102+
103+
who=(getObj('player',msg.playerid)||{get:()=>'API'}).get('_displayname');
104+
105+
args = msg.content.split(/ +/);
106+
switch(args[0]) {
107+
case '!mark-clear':
108+
if(playerIsGM(msg.playerid)) {
109+
reset();
110+
}
111+
break;
112+
113+
case '!mark':
114+
if(1 === args.length) {
115+
showHelp(who);
116+
break;
117+
}
118+
119+
tokens=_.chain(args)
120+
.rest()
121+
.uniq()
122+
.map(function(a){
123+
var t=getObj('graphic',a);
124+
if(! t) {
125+
errors.push('Argument [<b>'+a+'</b>] is not a valid token id.');
126+
}
127+
return t;
128+
},errors)
129+
.filter(function(t){
130+
return undefined !== t;
131+
})
132+
.value();
133+
134+
if(errors.length) {
135+
sendChat('','/w "'+who+'" '
136+
+'<div style="border: 1px solid black; background-color: white; padding: 3px 3px;">'
137+
+'<div><span style="font-weight:bold;color:#990000;">Error:</span> '
138+
+errors.join('</div><div><span style="font-weight:bold;color:#990000;">Error:</span> ')
139+
+'</div>'
140+
+'</div>'
141+
);
142+
}
143+
144+
_.each(tokens, function (t) {
145+
let size=( Math.max(t.get('width'), t.get('height') ) * 1.7),
146+
count=++state.Mark.count,
147+
status=getStatusForCount(count),
148+
m = createObj('graphic',{
149+
imgsrc: markerURL,
150+
subtype: 'token',
151+
pageid: t.get('pageid'),
152+
width: size,
153+
height: size,
154+
top: t.get('top'),
155+
left: t.get('left'),
156+
layer: 'objects',
157+
statusmarkers: status
158+
});
159+
160+
toBack(m);
161+
});
162+
163+
break;
164+
}
165+
166+
},
167+
168+
checkInstall = function() {
169+
log('-=> Mark v'+version+' <=- ['+(new Date(lastUpdate*1000))+']');
170+
171+
if( ! _.has(state,'Mark') || state.Mark.version !== schemaVersion)
172+
log(' > Updating Schema to v'+schemaVersion+' <');
173+
{
174+
/* Default Settings stored in the state. */
175+
state.Mark = {
176+
version: schemaVersion,
177+
count: 0,
178+
markedtokens: {}
179+
};
180+
}
181+
},
182+
183+
handlePlayerPageChange = function() {
184+
reset();
185+
},
186+
187+
handleTurnOrderChange = function(obj,prev) {
188+
var to = JSON.parse(obj.get("turnorder")),
189+
po = JSON.parse(prev.turnorder);
190+
191+
if( (_.isArray(to) && _.isArray(po) && !_.isEqual(to[0],po[0]) ) || (_.isArray(to) && ! _.isArray(po)) ) {
192+
reset();
193+
}
194+
},
195+
196+
handleInitiativePageChange = function(obj) {
197+
if(false === obj.get('initiativepage')) {
198+
reset();
199+
}
200+
},
201+
202+
registerEventHandlers = function() {
203+
on('chat:message', handleInput);
204+
on('change:campaign:playerpageid', handlePlayerPageChange);
205+
on('change:campaign:turnorder', handleTurnOrderChange);
206+
on('change:campaign:initiativepage', handleInitiativePageChange);
207+
};
208+
209+
return {
210+
RegisterEventHandlers: registerEventHandlers,
211+
CheckInstall: checkInstall,
212+
Reset: reset
213+
};
214+
}());
215+
216+
on("ready",function(){
217+
'use strict';
218+
219+
Mark.CheckInstall();
220+
Mark.RegisterEventHandlers();
221+
});

0 commit comments

Comments
 (0)