index : btroops | |
Virtual board game-aid for BattleTroops, an infantry combat simulator wargame published by FASA in 1989. |
aboutsummaryrefslogtreecommitdiff |
diff options
-rw-r--r-- | public/assets/images/counters.svg | 139 | ||||
-rw-r--r-- | public/assets/images/map4.svg | 21 | ||||
-rw-r--r-- | src/modules/game/soldier.js | 145 | ||||
-rw-r--r-- | src/modules/gameboard.js | 150 | ||||
-rw-r--r-- | src/modules/record_sheet.js | 116 |
5 files changed, 364 insertions, 207 deletions
diff --git a/public/assets/images/counters.svg b/public/assets/images/counters.svg index f433d97..4ff96a3 100644 --- a/public/assets/images/counters.svg +++ b/public/assets/images/counters.svg @@ -49,122 +49,134 @@ </g> </defs> - <g id="rifle" style="r: inherit;" class="weapon-symbol"> + <!--Semi-Automatic Firearms--> + + <g id="pistol" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> <use href="#semi-auto" /> <line x1="0" y1="-5" x2="0" y2="5"/> - <polyline points="-2,-3.5 0,-5 2,-3.5"/> </g> </g> - <g id="smg" style="r: inherit;" class="weapon-symbol"> + <g id="rifle" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <use href="#auto"/> - <line x1="0" y1="-5" x2="0" y2="4.5"/> - <line x1="-2" y1="4.5" x2="2" y2="4.5"/> + <use href="#semi-auto" /> + <line x1="0" y1="-5" x2="0" y2="5"/> + <polyline points="-2,-3.5 0,-5 2,-3.5"/> </g> </g> - <g id="blazer" style="r: inherit;" class="weapon-symbol"> + <g id="riflegl" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <use href="#auto"/> - <use href="#laser"/> + <use href="#semi-auto" /> + <circle cy="-2.25" r="1"/> + <line x1="0" y1="-5" x2="0" y2="5"/> <polyline points="-2,-3.5 0,-5 2,-3.5"/> </g> </g> - <g id="lmg" style="r: inherit;" class="weapon-symbol"> + <g id="laserpistol" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <line x1="-2" y1="4.5" x2="2" y2="4.5"/> - <line x1="0" y1="-4.5" x2="0" y2="4.5"/> - <line x1="-2" y1="0.5" x2="2" y2="0.5"/> - <polyline points="-2,-3.25 0,-4.75 2,-3.25"/> + <use href="#semi-auto"/> + <use href="#laser"/> </g> </g> - <g id="srm" style="r: inherit;" class="weapon-symbol"> + <g id="laserrifle" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <line x1="0" y1="-4.75" x2="0" y2="5"/> - <line x1="-2" y1="0.5" x2="2" y2="0.5"/> - <path d="M -2,4.75 V -2.5 C -2,-5.5 2,-5.5 2,-2.5 V 4.75"/> + <use href="#semi-auto"/> + <use href="#laser"/> + <polyline points="-2,-3.5 0,-5 2,-3.5"/> </g> </g> - <g id="hsplaser" style="r: inherit;" class="weapon-symbol"> + <g id="gyrojetrifle" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <line x1="-2" y1="4.5" x2="2" y2="4.5"/> - <use href="#auto"/> - <polyline points="0,-5 0,-3 -3,-2.5 3,-1.5 0,-1 0,2.5 0,4.5"/> + <line x1="-2" y1="-1" x2="-2" y2="3"/> + <line x1="2" y1="-1" x2="2" y2="3"/> + <line x1="0" y1="-5" x2="0" y2="5"/> <polyline points="-2,-3.5 0,-5 2,-3.5"/> </g> </g> - <g id="smggl" style="r: inherit;" class="weapon-symbol"> + <!--Automatic Firearms--> + + <g id="blazer" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> <use href="#auto"/> - <circle cy="-2.25" r="1"/> - <line x1="0" y1="-5" x2="0" y2="4.5"/> - <line x1="-2" y1="4.5" x2="2" y2="4.5"/> + <use href="#laser"/> + <polyline points="-2,-3.5 0,-5 2,-3.5"/> </g> </g> - <g id="riflegl" style="r: inherit;" class="weapon-symbol"> + <g id="autopistol" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <use href="#semi-auto" /> - <circle cy="-2.25" r="1"/> + <use href="#auto" /> <line x1="0" y1="-5" x2="0" y2="5"/> - <polyline points="-2,-3.5 0,-5 2,-3.5"/> </g> </g> - <g id="pistol" style="r: inherit;" class="weapon-symbol"> + <g id="smg" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <use href="#semi-auto" /> - <line x1="0" y1="-5" x2="0" y2="5"/> + <use href="#auto"/> + <line x1="0" y1="-5" x2="0" y2="4.5"/> + <line x1="-2" y1="4.5" x2="2" y2="4.5"/> </g> </g> - <g id="laserpistol" style="r: inherit;" class="weapon-symbol"> + <g id="smggl" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <use href="#semi-auto"/> - <use href="#laser"/> + <use href="#auto"/> + <circle cy="-2.25" r="1"/> + <line x1="0" y1="-5" x2="0" y2="4.5"/> + <line x1="-2" y1="4.5" x2="2" y2="4.5"/> </g> </g> - <g id="laserrifle" style="r: inherit;" class="weapon-symbol"> + <!--Hand-to-Hand Weapons--> + + <g id="nonlethalhand" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <use href="#semi-auto"/> - <use href="#laser"/> - <polyline points="-2,-3.5 0,-5 2,-3.5"/> + <line x1="-2" y1="-4.25" x2="2" y2="-4.25"/> + <line x1="0" y1="-4.25" x2="0" y2="5"/> </g> </g> - <g id="gyrojetrifle" style="r: inherit;" class="weapon-symbol"> + <g id="lethalhand" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <line x1="-2" y1="-1" x2="-2" y2="3"/> - <line x1="2" y1="-1" x2="2" y2="3"/> <line x1="0" y1="-5" x2="0" y2="5"/> - <polyline points="-2,-3.5 0,-5 2,-3.5"/> </g> </g> - <g id="autopistol" style="r: inherit;" class="weapon-symbol"> + <!--Area-Effect Weapons--> + + <g id="srm" style="r: inherit;" class="weapon-symbol"> + <use style="r: inherit;" href="#counter-base"/> + <g style="stroke: white; stroke-width: 0.5px; fill: none;"> + <line x1="0" y1="-4.75" x2="0" y2="5"/> + <line x1="-2" y1="0.5" x2="2" y2="0.5"/> + <path d="M -2,4.75 V -2.5 C -2,-5.5 2,-5.5 2,-2.5 V 4.75"/> + </g> + </g> + + <g id="hsrm" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> + <line x1="0" y1="-4.75" x2="0" y2="5"/> <use href="#auto" /> - <line x1="0" y1="-5" x2="0" y2="5"/> + <path d="M -2,4.75 V -2.5 C -2,-5.5 2,-5.5 2,-2.5 V 4.75"/> </g> </g> @@ -178,12 +190,11 @@ </g> </g> - <g id="hsrm" style="r: inherit;" class="weapon-symbol"> + <g id="grenade" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> - <line x1="0" y1="-4.75" x2="0" y2="5"/> - <use href="#auto" /> - <path d="M -2,4.75 V -2.5 C -2,-5.5 2,-5.5 2,-2.5 V 4.75"/> + <circle cy="-2.25" r="1"/> + <line x1="0" y1="-5" x2="0" y2="5"/> </g> </g> @@ -248,6 +259,18 @@ </g> </g> + <!--Support Weapons--> + + <g id="lmg" style="r: inherit;" class="weapon-symbol"> + <use style="r: inherit;" href="#counter-base"/> + <g style="stroke: white; stroke-width: 0.5px; fill: none;"> + <line x1="-2" y1="4.5" x2="2" y2="4.5"/> + <line x1="0" y1="-4.5" x2="0" y2="4.5"/> + <line x1="-2" y1="0.5" x2="2" y2="0.5"/> + <polyline points="-2,-3.25 0,-4.75 2,-3.25"/> + </g> + </g> + <g id="mmg" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> @@ -278,12 +301,24 @@ </g> </g> + <g id="hsplaser" style="r: inherit;" class="weapon-symbol"> + <use style="r: inherit;" href="#counter-base"/> + <g style="stroke: white; stroke-width: 0.5px; fill: none;"> + <line x1="-2" y1="4.5" x2="2" y2="4.5"/> + <use href="#auto"/> + <polyline points="0,-5 0,-3 -3,-2.5 3,-1.5 0,-1 0,2.5 0,4.5"/> + <polyline points="-2,-3.5 0,-5 2,-3.5"/> + </g> + </g> + <g id="mpppc" style="r: inherit;" class="weapon-symbol"> <use style="r: inherit;" href="#counter-base"/> <g style="stroke: white; stroke-width: 0.5px; fill: none;"> <polyline points="-2,-3.5 0,-5 2,-3.5"/> - <path d="M -3,-2 h 2 m 2,0 h 2 m -1, -1 v 2"/> - <line x1="0" y1="-5" x2="0" y2="5"/> + <circle cx="-1.5" cy="-2" style="fill: white;" r="0.25" /> + <circle cx="1.5" cy="-2" style="fill: white;" r="0.25" /> + <line x1="-2" y1="4.5" x2="2" y2="4.5"/> + <line x1="0" y1="-5" x2="0" y2="4.5"/> </g> </g> diff --git a/public/assets/images/map4.svg b/public/assets/images/map4.svg index d38738c..bf5a220 100644 --- a/public/assets/images/map4.svg +++ b/public/assets/images/map4.svg @@ -1,23 +1,6 @@ <?xml version="1.0" standalone="no"?> <svg xmlns="http://www.w3.org/2000/svg" viewBox="-10 -10 200 300"> <defs> - <g id="building1" class="building"> - <g class="footprint"> - <g data-q="0" data-r="0" data-s="0" data-left="1" data-top="3" data-right="2" data-bottom="4" data-offset="left" /> - </g> - - <g class="structure"> - <path id="building1-floor" class="floor" d="M -30.309999,-52.5 H 38.97 l 0,119.999999 H -30.31 Z" /> - <path id="building1-outer-wall" class="outer-wall" d="M 38.969998,-7.500001 21.65,-7.5 V 7.4999997 L 12.989997,7.5 m 0,30 25.980001,0 M 12.989997,67.5 v -60 l -17.319997,0 0,-30.0000007 M -4.330003,67.5 v -45 H -30.31 m 0,-74.999999 L 38.97,-52.5 38.969999,67.499999 -30.31,67.5 Z" /> - <path id="building1-inner-wall" class="inner-wall" d="M 38.969998,-7.500001 21.65,-7.5 V 7.4999997 L 12.989997,7.5 m 0,30 25.980001,0 M 12.989997,67.5 v -60 l -17.319997,0 0,-30.0000007 M -4.330003,67.5 v -45 H -30.31 m 0,-74.999999 L 38.97,-52.5 38.969999,67.499999 -30.31,67.5 Z" /> - <path id="building1-door-edges" class="door-edges" d="m 12.99,52.5 0,-15 M -4.33,45.000003 v -15 M 12.990002,30 l 0,-15" /> - <path id="building1-doors" class="doors" d="m 12.99,48.169997 0,-6.34 M -4.33,40.67 v -6.34 m 17.320002,-8.66 0,-6.34" /> - <path id="building1-exit-edges" class="exits door-edges" d="M 0,-52.5 H 17.32 M -30.31,8.66 V -8.66" /> - <path id="building1-exits" class="doors exits" d="M 4.3300002,-52.5 H 12.99 m -43.3,56.8300023 v -8.660003" /> - <path id="building1-windows" class="windows" d="m 32.501739,67.499994 -13.043478,0 m -49.768256,-8.478265 0,-13.043478 m 0,-69.456522 0,-13.043479" /> - </g> - </g> - <polygon id="desk" points="-1.5,-7 4.5,-7 4.5,7 -1.5,7 -2.5,6 -2.5,3 -4.5,3 -4.5,-3 -2.5,-3 -2.5,-6" /> <rect id="couch" x="-4.25" y="-8" width="8.5" height="16" /> <rect id="bed" x="-5" y="-9" width="10" height="18" /> @@ -25,7 +8,7 @@ <g id="mapsheet" class="mapsheet"> <g class="building1" data-q="3" data-r="-5" data-s="2"> - <use href="#building1"/> + <use href="mapsheets.svg#building1"/> <g class="furniture"> <use href="#couch" transform="rotate(90,10.34,-27.66)" /> <use href="#bed" transform="translate(-17.32,45)" /> @@ -56,7 +39,7 @@ <g class="start-locations" data-attacker-name="liao" data-defender-name="davion"> <g data-edge="north" style="--i: -2"> <g class="counter" data-allegiance="attacker" data-number="1" data-squad="1" data-armor="4"> - <use class="primary-weapon" href="counters.svg#blazer"/> + <use class="primary-weapon" href="counters.svg#pistol"/> <use class="troop-number" href="counters.svg#number-1"/> <use class="squad-number" href="counters.svg#number-1"/> </g> diff --git a/src/modules/game/soldier.js b/src/modules/game/soldier.js index 8407621..efca3ef 100644 --- a/src/modules/game/soldier.js +++ b/src/modules/game/soldier.js @@ -7,9 +7,9 @@ function dataSelector({ dataset: { allegiance, number, squad }}) { return `[data-number="${number}"][data-allegiance="${allegiance}"][data-squad="${squad}"]`; } -function traceSelector(counter) { - return `polyline.move-trace${dataSelector(counter)}`; -} +//function traceSelector(counter) { +// return `polyline.move-trace${dataSelector(counter)}`; +//} function getCellPosition(cell) { const [x, y] = cell.getAttributeNS(null, 'transform').match(/-?\d+\.?\d*/g); @@ -17,44 +17,44 @@ function getCellPosition(cell) { return { x, y }; } -function getClones(svg, counter) { - return svg.querySelectorAll(`.counter.clone${dataSelector(counter)}`); -} - -function addMoveToHistory(selected) { - const clone = selected.cloneNode(true); - clone.classList.remove(selectedClass); - clone.classList.add('clone'); - selected.parentElement.appendChild(clone); - - return clone; -} - -function updatePlacement(cell, selected, clone) { - const { q, r, s, t } = clone.parentElement.dataset; - - selected.dataset.previous = [q, r, s, t]; - placeIn(cell, selected); - - Array.from(selected.children).forEach(n => { - if (n.classList.contains('removed')) { - n.remove(); - } else if ('preexisting' in n.dataset) { - delete n.dataset.preexisting; - } - }); -} - -function createTrace(previous, current, selected) { - const trace = document.createElementNS(svgns, 'polyline'); - - trace.dataset.number = selected.dataset.number; - trace.dataset.allegiance = selected.dataset.allegiance; - trace.classList.add('move-trace'); - trace.setAttributeNS(null, 'points', `${previous.x},${previous.y} ${current.x},${current.y}`); - - return trace; -} +//function getClones(svg, counter) { +// return svg.querySelectorAll(`.counter.clone${dataSelector(counter)}`); +//} + +//function addMoveToHistory(selected) { +// const clone = selected.cloneNode(true); +// clone.classList.remove(selectedClass); +// clone.classList.add('clone'); +// selected.parentElement.appendChild(clone); +// +// return clone; +//} + +//function updatePlacement(cell, selected, clone) { +// const { q, r, s, t } = clone.parentElement.dataset; +// +// selected.dataset.previous = [q, r, s, t]; +// placeIn(cell, selected); +// +// Array.from(selected.children).forEach(n => { +// if (n.classList.contains('removed')) { +// n.remove(); +// } else if ('preexisting' in n.dataset) { +// delete n.dataset.preexisting; +// } +// }); +//} + +//function createTrace(previous, current, selected) { +// const trace = document.createElementNS(svgns, 'polyline'); +// +// trace.dataset.number = selected.dataset.number; +// trace.dataset.allegiance = selected.dataset.allegiance; +// trace.classList.add('move-trace'); +// trace.setAttributeNS(null, 'points', `${previous.x},${previous.y} ${current.x},${current.y}`); +// +// return trace; +//} function placeIn(location, target) { location.querySelector('use[href="#hex"]').after(target); @@ -87,29 +87,30 @@ export function createCounter(selected, weapon = 'rifle') { return g; } -export function handleTrace(svg, selected, clone, current) { - let trace = getTrace(svg, selected); - - if (!trace) { - trace = createTrace(getCellPosition(clone.parentElement), current, selected); - svg.querySelector('.grid').before(trace); - } else { - const points = `${trace.getAttribute('points')} ${current.x},${current.y}`; - trace.setAttributeNS(null, 'points', points); - } -} +//export function handleTrace(svg, selected, clone, current) { +// let trace = getTrace(svg, selected); +// +// if (!trace) { +// trace = createTrace(getCellPosition(clone.parentElement), current, selected); +// svg.querySelector('.grid').before(trace); +// } else { +// const points = `${trace.getAttribute('points')} ${current.x},${current.y}`; +// trace.setAttributeNS(null, 'points', points); +// } +//} export function getAllCounters(container) { return container.querySelectorAll('g.counter[data-allegiance][data-number]'); } export function getCounter(svg, selected) { - return svg.querySelector(`.counter${dataSelector(selected)}:not(.clone)`); + //return svg.querySelector(`.counter${dataSelector(selected)}:not(.clone)`); + return svg.querySelector(`.counter${dataSelector(selected)}`); } -export function getTrace(svg, counter) { - return svg.querySelector(traceSelector(counter)); -} +//export function getTrace(svg, counter) { +// return svg.querySelector(traceSelector(counter)); +//} export function place(svg, selected, cell) { //console.log(selected.parentElement); @@ -134,23 +135,23 @@ export function place(svg, selected, cell) { //} } -export function removeClones(svg, counter) { - getClones(svg, counter).forEach(c => c.remove()); -} +//export function removeClones(svg, counter) { +// getClones(svg, counter).forEach(c => c.remove()); +//} -export function endMove(svg, counter) { - Array.from(counter.children).forEach(n => { - if (n.classList.contains('removed')) { - n.remove(); - } else { - n.dataset.preexisting = ''; - } - }); - - svg.querySelector(traceSelector(counter))?.remove(); - delete counter.dataset.previous; - removeClones(svg, counter); -} +//export function endMove(svg, counter) { + //Array.from(counter.children).forEach(n => { + // if (n.classList.contains('removed')) { + // n.remove(); + // } else { + // n.dataset.preexisting = ''; + // } + //}); + + //svg.querySelector(traceSelector(counter))?.remove(); + //delete counter.dataset.previous; + //removeClones(svg, counter); +//} export function getSelectedClass() { return selectedClass; diff --git a/src/modules/gameboard.js b/src/modules/gameboard.js index fd2aaf1..8c91ee5 100644 --- a/src/modules/gameboard.js +++ b/src/modules/gameboard.js @@ -46,16 +46,16 @@ function isMechTemplate(el) { return el && el.getAttribute('class') === 'mech-template'; } -function isClone(counter) { - const isClone = counter.classList.contains('clone'), - { allegiance: clAl, number: clNum } = counter.dataset; - - return { - of: function ({ dataset: { allegiance, number }}) { - return isClone && clAl == allegiance && clNum == number; - } - }; -} +//function isClone(counter) { +// const isClone = counter.classList.contains('clone'), +// { allegiance: clAl, number: clNum } = counter.dataset; +// +// return { +// of: function ({ dataset: { allegiance, number }}) { +// return isClone && clAl == allegiance && clNum == number; +// } +// }; +//} function getCellPosition(cell) { const [x, y] = cell.getAttributeNS(null, 'transform').match(/-?\d+\.?\d*/g); @@ -127,56 +127,56 @@ function drawSightLine(sourceCell, targetCell) { svg.querySelector('.gameboard').appendChild(line); } -function moveBackOneStepInHistory(counter) { - const trace = soldier.getTrace(svg, counter); - - counter.remove(); - counter = getCounterAtGridIndex(...counter.dataset.previous.split(',')); - counter.classList.remove('clone'); - counter.classList.add(soldier.getSelectedClass()); - - if (!('previous' in counter.dataset)) { - trace.remove(); - } else { - const points = trace.getAttribute('points').split(' '); - points.pop(); - trace.setAttributeNS(null, 'points', points.join(' ')); - } - - return counter; -} - -function clearMoveHistory(clone, counter) { - clone.classList.remove('clone'); - clone.classList.add(soldier.getSelectedClass()); - counter.remove(); - counter = clone; - soldier.removeClones(svg, counter); - soldier.getTrace(svg, counter).remove(); - - return counter; -} - -function deleteClone(occupant, counter, cell) { - const index = getGridIndex(occupant), - trace = soldier.getTrace(svg, counter), - pos = getCellPosition(cell), - points = trace.getAttribute('points').split(' ').filter(p => p != `${pos.x},${pos.y}`).join(' ');; - - let current = counter; - trace.setAttributeNS(null, 'points', points); - - while (current.dataset.previous != `${index.q},${index.r},${index.s},${index.t}`) { - current = getCounterAtGridIndex(...current.dataset.previous.split(',')); - } - - current.dataset.previous = occupant.dataset.previous; - occupant.remove(); -} - -function hasPreviousMoveInHistory(counter) { - return 'previous' in counter.dataset; -} +//function moveBackOneStepInHistory(counter) { +// const trace = soldier.getTrace(svg, counter); +// +// counter.remove(); +// counter = getCounterAtGridIndex(...counter.dataset.previous.split(',')); +// counter.classList.remove('clone'); +// counter.classList.add(soldier.getSelectedClass()); +// +// if (!('previous' in counter.dataset)) { +// trace.remove(); +// } else { +// const points = trace.getAttribute('points').split(' '); +// points.pop(); +// trace.setAttributeNS(null, 'points', points.join(' ')); +// } +// +// return counter; +//} + +//function clearMoveHistory(clone, counter) { +// clone.classList.remove('clone'); +// clone.classList.add(soldier.getSelectedClass()); +// counter.remove(); +// counter = clone; +// soldier.removeClones(svg, counter); +// soldier.getTrace(svg, counter).remove(); +// +// return counter; +//} + +//function deleteClone(occupant, counter, cell) { +// const index = getGridIndex(occupant), +// trace = soldier.getTrace(svg, counter), +// pos = getCellPosition(cell), +// points = trace.getAttribute('points').split(' ').filter(p => p != `${pos.x},${pos.y}`).join(' ');; +// +// let current = counter; +// trace.setAttributeNS(null, 'points', points); +// +// while (current.dataset.previous != `${index.q},${index.r},${index.s},${index.t}`) { +// current = getCounterAtGridIndex(...current.dataset.previous.split(',')); +// } +// +// current.dataset.previous = occupant.dataset.previous; +// occupant.remove(); +//} + +//function hasPreviousMoveInHistory(counter) { +// return 'previous' in counter.dataset; +//} function selectOffBoard() { Observable.notify('select', this, { revealRecord: true }); @@ -229,7 +229,7 @@ function endMove() { const selected = getSelected(); if (selected) { - soldier.endMove(svg, selected); + //soldier.endMove(svg, selected); deselect(); } } @@ -405,9 +405,33 @@ export function start(el) { //cell2.classList.add('hover'); // - //const trooper1 = soldier.createCounter({ dataset: { allegiance: 'attacker', number: 1, squad: 1 }}, 'blazer'); + ['lmg', 'mmg', 'hmg', 'splaser', 'hsplaser', 'mpppc'].forEach((w, i) => { + soldier.place( + svg, + soldier.createCounter({ dataset: { allegiance: 'attacker', number: i + 1, squad: 1 }}, w), + getCell(-3 - i, 9, -6 + i, 0) + ) + }); + + ['srm', 'hsrm', 'law', 'gl', 'autogl', 'lrrifle'].forEach((w, i) => { + soldier.place( + svg, + soldier.createCounter({ dataset: { allegiance: 'attacker', number: i + 1, squad: 2 }}, w), + getCell(-2 - i, 8, -6 + i, 0) + ) + }); + + ['satchelcharge', 'grenade', 'nonlethalhand', 'lethalhand', 'flamer', 'hflamer', 'inferno'].forEach((w, i) => { + soldier.place( + svg, + soldier.createCounter({ dataset: { allegiance: 'attacker', number: i + 1, squad: 3 }}, w), + getCell(-2 - i, 7, -5 + i, 0) + ) + }); + //const weapon = 'mpppc'; + //const trooper1 = soldier.createCounter({ dataset: { allegiance: 'attacker', number: 1, squad: 1 }}, weapon); //soldier.place(svg, trooper1, getCell(-3, 9, -6, 0)); - // + //soldier.place( // svg, // soldier.createCounter({ dataset: { allegiance: 'defender', number: 1, squad: 1 }}, 'blazer'), diff --git a/src/modules/record_sheet.js b/src/modules/record_sheet.js index 5abb108..3c933d5 100644 --- a/src/modules/record_sheet.js +++ b/src/modules/record_sheet.js @@ -49,7 +49,121 @@ const weapons = { damage: '4/2/1 L', shortRange: '1-10', longRange: '11-24' - } + }, + pistol: { + name: 'Pistol', + damage: '3L', + shortRange: '1-7', + longRange: '8-20' + }, + laserpistol: { + name: 'Laser Pistol', + damage: '4L', + shortRange: '1-12', + longRange: '13-30' + }, + laserrifle: { + name: 'Laser Rifle', + damage: '5L', + shortRange: '1-17', + longRange: '18-105' + }, + gyrojetrifle: { + name: 'Gyrojet Rifle', + damage: '6L', + shortRange: '1-57', + longRange: '58-180' + }, + autopistol: { + name: 'Auto Pistol', + damage: '2L', + shortRange: '1-7', + longRange: '8-20' + }, + law: { + name: 'LAW', + damage: '7/3/1 L', + shortRange: '1-22', + longRange: '23-80' + }, + hsrm: { + name: 'Heavy SRM', + damage: '13/6/3/1 L', + shortRange: '1-54', + longRange: '55-96' + }, + gl: { + name: 'Grenade Launcher', + damage: '4/2/1 L', + shortRange: '1-10', + longRange: '11-24' + }, + autogl: { + name: 'Auto Grenade Launcher', + damage: '3/2/1 L', + shortRange: '1-22', + longRange: '23-50' + }, + lrrifle: { + name: 'Light Recoilless Rifle', + damage: '4/2/1 L', + shortRange: '1-36', + longRange: '37-70' + }, + satchelcharge: { + name: 'Satchel Charge', + damage: '10/5/2 L', + shortRange: 'NA', + longRange: 'NA' + }, + flamer: { + name: 'Flamer', + damage: '2/1 L', + shortRange: '1-6', + longRange: '7-12' + }, + hflamer: { + name: 'Heavy Flamer', + damage: '2/2/1 L', + shortRange: '1-6', + longRange: '7-12' + }, + inferno: { + name: 'Inferno', + damage: '4/2/1 L', + shortRange: '1-44', + longRange: '45-108' + }, + mmg: { + name: 'Medium MG', + damage: '6L', + shortRange: '1-30', + longRange: '31-84' + }, + hmg: { + name: 'Heavy MG', + damage: '7L', + shortRange: '1-36', + longRange: '37-110' + }, + splaser: { + name: 'Semi-Portable Laser', + damage: '11L', + shortRange: '1-80', + longRange: '81-240' + }, + mpppc: { + name: 'Man-Pack PPC', + damage: '8L', + shortRange: '1-50', + longRange: '51-110' + }, + grenade: { + name: 'Grenade', + damage: '6/3/1 L', + shortRange: 'Special', + longRange: 'Special' + }, } function createIcon(number) { |