Web Dev Solutions

Catalin Mititiuc

aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--public/assets/css/map.css16
-rw-r--r--public/assets/css/style.css4
-rw-r--r--public/assets/images/counter_grenade2.svg3
-rw-r--r--public/index.html1
-rw-r--r--src/index.js15
-rw-r--r--src/modules/game/soldier.js18
-rw-r--r--src/modules/gameboard.js17
7 files changed, 11 insertions, 63 deletions
diff --git a/public/assets/css/map.css b/public/assets/css/map.css
index 7d7de6f..feda870 100644
--- a/public/assets/css/map.css
+++ b/public/assets/css/map.css
@@ -78,24 +78,12 @@ g.troop-counter-template text {
stroke: none;
}
-[href="#counter-prone"] {
- transform: translate(-5px, 6px);
-}
-
g.clone {
stroke: white;
stroke-width: 0.5px;
stroke-dasharray: 1;
}
-g.clone [href="#counter-prone"] {
- opacity: 0.5;
-}
-
-.removed[href="#counter-prone"] {
- opacity: 0.5;
-}
-
g[data-allegiance="defender"].clone {
fill: rgb(255, 126, 126);
}
@@ -505,8 +493,8 @@ use[class^="counter-"] {
}
g.counter use[class^="counter-"] {
- --translateX: calc(var(--x) - 5px);
- --translateY: var(--y);
+ --translateX: calc((var(--x)) * 1.25 - 5px);
+ --translateY: calc((var(--y)) * 1.25 - 5px);
}
[data-q][data-r][data-s][data-t] > use[class^="counter-"] {
diff --git a/public/assets/css/style.css b/public/assets/css/style.css
index af9dd2a..f2eef7b 100644
--- a/public/assets/css/style.css
+++ b/public/assets/css/style.css
@@ -91,10 +91,6 @@ g.troop-counter-template text {
stroke: none;
}
-g.troop-counter [href="#counter-prone"] {
- transform: translate(-5px, 6px);
-}
-
text.counter, #troop-counter text {
font-size: 12px;
font-weight: bold;
diff --git a/public/assets/images/counter_grenade2.svg b/public/assets/images/counter_grenade2.svg
index 21e6804..218c54f 100644
--- a/public/assets/images/counter_grenade2.svg
+++ b/public/assets/images/counter_grenade2.svg
@@ -40,8 +40,7 @@
d="m -112.96867,-44.88343 c 0.31818,-1.267751 0.40144,-1.27559 1.53278,-0.144251 l 1.02359,1.023591 h -1.38854 c -1.35472,0 -1.38316,-0.0214 -1.16783,-0.87934 z m 65.509434,-0.29747 c -0.15191,-1.06689 -0.93555,-1.590421 -1.68243,-1.12398 -0.33532,0.20941 -0.84526,0.38074 -1.13319,0.38074 -0.41477,0 -0.44556,-0.0939 -0.14825,-0.45218 0.20641,-0.2487 1.1214,-0.55481 2.03332,-0.68023 0.91192,-0.12542 1.80468,-0.41702 1.9839,-0.648 0.19541,-0.25184 0.668,-0.35085 1.18048,-0.24733 0.76081,0.1537 0.83624,0.28591 0.68717,1.20451 -0.21849,1.34641 0.5897,2.21528 1.88391,2.02533 0.50737,-0.0745 1.00008,-0.01 1.09492,0.14362 0.0949,0.15348 -1.17119,0.23745 -2.81409,0.18664 -2.79039,-0.0863 -2.99304,-0.13812 -3.08574,-0.78912 z m -5.82078,-1.044351 c 0,-0.554389 0.56323,-0.656959 0.96292,-0.175359 0.32908,0.39651 0.28146,0.47647 -0.28374,0.47647 -0.37355,0 -0.67918,-0.1355 -0.67918,-0.301111 z m 28.78253,17.53086 c -0.91817,0.047 -1.98383,-0.16419 -2.88,-0.57074 -0.78239,-0.35493 -1.96253,-0.64848 -2.62253,-0.65235 -0.66,-0.004 -1.2,-0.15314 -1.2,-0.33173 0,-0.43733 -1.81782,-1.52869 -3.2,-1.92117 -0.616,-0.17492 -1.45206,-0.57585 -1.8579,-0.89095 l -0.73789,-0.57292 1.63987,-0.74113 c 1.62404,-0.73397 1.65897,-0.73581 3.6179,-0.19057 1.08791,0.3028 2.91402,1.16823 4.05802,1.92317 1.144,0.75494 3.03822,1.84351 4.20939,2.41904 1.42104,0.69832 2.07374,1.19143 1.9621,1.48236 -0.11119,0.28976 -0.39602,0.35823 -0.84939,0.20417 -0.37516,-0.12747 -1.33796,-0.1982 -2.13957,-0.15718 z M -133.5987,-40.09757 c -0.001,0.50842 0.65059,0.53319 9.15692,0.34806 8.44709,-0.18384 9.1821,-0.15664 9.46583,0.35036 0.70277,1.25578 3.13596,1.38973 3.13596,0.17264 0,-0.91161 1.5088,-0.81029 2.40972,0.16181 0.39771,0.42914 0.65307,0.85029 0.56748,0.93589 -0.31054,0.31054 0.28191,1.49298 0.91882,1.833849 0.47175,0.252471 0.74962,0.252371 1.00233,-3.39e-4 0.50515,-0.50515 1.63097,-0.430221 2.94409,0.19596 1.06276,0.506799 1.15103,0.346969 2.17085,0.0236 0,0 2.780534,-1.035029 4.226714,-1.340219 0.35121,-0.0741 1.07046,-0.11704 1.07046,-0.11704 1.41931,-0.155181 1.70264,-0.0153 2.41997,1.22713 0.47875,0.829219 0.42899,0.943019 0.61044,1.050429 0.18145,0.10741 0.61888,0.0505 2.05247,0.0505 1.53435,0 1.92644,0.12887 2.67751,0.88 l 0.87993,0.88 h 5.79489 c 6.21793,0 6.94578,0.14118 9.37434,1.81833 0.66,0.45579 1.2,1.02822 1.2,1.27205 0,0.75491 1.50772,1.24477 2.58255,0.83906 1.12879,-0.42607 1.13344,-0.39582 0.4229,2.75052 -0.28299,1.25315 -0.44016,2.47229 -0.34924,2.7092 0.20725,0.54011 3.26619,1.17084 5.67833,1.17084 1.95621,0 2.02366,-0.0618 2.70577,-2.48063 0.15275,-0.54169 0.3766,-0.68066 0.90145,-0.55964 0.38403,0.0885 1.63424,-0.0606 2.77824,-0.33151 5.28277,-1.25084 4.90918,-1.21964 6.42733,-0.53681 2.12287,0.95481 4.59278,1.40115 5.61112,1.01397 1.64609,-0.62584 2.77651,0.13121 7.96669,5.33539 2.70843,2.71572 5.2082,5.33623 5.55506,5.82334 0.34686,0.48712 1.54171,1.34645 2.65522,1.90964 1.85289,0.93713 2.48435,1.06512 7.44637,1.50928 l 5.42179,0.48531 1.4551,-0.72417 c 2.00954,-1.0001 5.6614201,-5.58485 7.5654101,-9.49796 0.80749,-1.65959 1.8316,-3.49391 2.27578,-4.07627 l 0.80761,-1.05883 5.00626,0.1633 c 2.75344,0.0898 8.9662499,0.29208 13.8062499,0.44948 7.32969,0.23838 9.19738,0.3973 11.17836,0.95115 1.3081,0.36573 2.86117,0.66496 3.45126,0.66496 2.40666,0 5.29398,2.92177 6.32453,6.4 0.13037,0.44 0.94665,2.46622 1.81396,4.5027 1.31472,3.08701 1.81113,3.89847 2.98536,4.88 1.3924,1.1639 1.44051,1.17716 4.22748,1.16449 1.7628,-0.008 3.12183,-0.17757 3.62713,-0.45254 l -4e-5,4e-5 c 0.44444,-0.24184 1.80531,-0.76189 3.02415,-1.15566 1.96466,-0.63471 2.56275,-1.04527 5.27192,-3.61884 5.45007,-5.17728 7.86888,-7.76976 8.44847,-9.05507 0.37239,-0.8258 0.89214,-1.38245 1.50783,-1.61484 0.70588,-0.26644 0.93955,-0.56053 0.93955,-1.18244 0,-1.20726 1.01032,-2.03196 2.77694,-2.26673 0.84868,-0.11278 2.26306,-0.35376 3.14306,-0.5355 0.97794,-0.20196 3.96383,-0.25711 7.68,-0.14184 3.344,0.10372 6.4709,0.19651 6.94867,0.2062 1.47703,0.0299 4.02446,-1.26617 4.72896,-2.40608 0.99965,-1.61747 0.86533,-3.76037 -0.35489,-5.66192 -0.5485,-0.85475 -1.35992,-1.839359 -1.80316,-2.18801 l -0.80589,-0.63392 h 1.05764 c 1.15858,0 5.42867,-1.827769 5.42867,-2.323689 0,-0.18419 0.41998,-0.21255 1.04,-0.0703 0.572,0.13129 1.976,0.20946 3.119996,0.17371 5.58884,-0.17463 9.52414,-0.11722 13.76,0.20073 4.28284,0.32147 4.80296,0.43108 6.75698,1.423889 1.16433,0.59159 3.21786,1.92221 4.56338,2.95693 2.72809,2.09794 3.19517,2.16529 6.10128,0.87978 l 1.45836,-0.64511 v -2.05891 c 0,-1.13241 -0.20974,-2.560899 -0.46609,-3.174419 -1.47611,-3.53285 -6.463,-8.88266 -8.28007,-8.88266 -1.42233,0 -2.77384,-1.12877 -2.77384,-2.3167 0,-0.79715 -0.36307,-1.330991 -1.84,-2.705411 -1.012,-0.94177 -2.07451,-1.93184 -2.36115,-2.20016 -0.28663,-0.26832 -1.04856,-0.63349 -1.69318,-0.81147 -1.10769,-0.30585 -1.28111,-0.24293 -3.15885,1.14618 -1.09275,0.80838 -2.93796,2.22906 -4.10048,3.15705 l -2.11366,1.687251 -4.23551,0.0829 c -3.457186,0.0677 -4.303656,-0.005 -4.606336,-0.39722 -0.91185,-1.180601 -14.76386,-2.145321 -17.50554,-1.219171 -0.62409,0.21081 -2.50969,0.431491 -4.19023,0.490391 -1.68054,0.0589 -3.19217,0.19154 -3.35917,0.29475 -0.85075,0.5258 -5.33699,0.27011 -6.35589,-0.36224 -0.176,-0.109231 -1.04,-0.207921 -1.92,-0.219331 -0.88,-0.0114 -2.42385,-0.3369 -3.43078,-0.72334 -1.00694,-0.38643 -2.77047,-0.76173 -3.91898,-0.83399 -1.21905,-0.0767 -2.66341,-0.40985 -3.47024,-0.80043 -0.81354,-0.39383 -2.03158,-0.67311 -2.96103,-0.67893 -0.86843,-0.005 -2.63779,-0.14734 -3.93191,-0.31536 -2.11369,-0.27442 -2.47304,-0.42797 -3.53402,-1.51012 -3.7932,-3.86889 -7.03258,-5.32746 -11.71304,-5.27391 -4.43433,0.0507 -9.55342,0.40675 -9.91475,0.68955 -0.17889,0.14001 -1.04923,0.34644 -1.93409,0.45873 -0.88487,0.11229 -2.35339,0.4763 -3.26337,0.80891 -1.52746,0.5583 -1.84625,0.5707 -4.15115,0.16146 -1.37315,-0.2438 -3.4326399,-0.59419 -4.5766299,-0.77864 -2.20332,-0.35524 -5.0295,-1.82724 -4.86878,-2.53588 0.16226,-0.71541 -0.6347,-1.3483 -1.44254,-1.14555 -0.56084999,0.14076 -1.23487999,-0.14345 -2.58374,-1.08949 -1.00372,-0.70396 -2.75177,-1.65647 -3.88456,-2.11668 -1.76258,-0.71607 -2.38779,-0.81337 -4.33509,-0.67462 -1.4839601,0.10574 -2.9380601,0.45796 -4.1803801,1.01261 -1.11961,0.49987 -2.63047,0.88902 -3.66491,0.94397 -0.968,0.0514 -1.904,0.14318 -2.08,0.20391 -0.176,0.0607 -1.52911,-1.07313 -3.00691,-2.51971 -2.4005,-2.34978 -2.91582,-2.6983 -4.8345,-3.26971 -1.49857,-0.4463 -3.14994,-0.59676 -5.21851,-0.61541 -0.52645,-0.005 -1.4926,-0.0113 -2.62003,0.0342 -2.61058,0.10552 -3.53951,0.28591 -5.04321,0.9796 -2.28816,1.05558 -5.2822,3.33353 -6.7735,5.15346 -1.18229,1.44283 -2.23311,3.58039 -1.96966,4.00666 0.0847,0.13705 -0.0652,1.82172 -0.33303,3.74372 -0.26786,1.92201 -0.44058,4.46787 -0.38381,5.65747 0.0968,2.027611 -0.16149,2.774891 -0.58107,1.681471 -0.21164,-0.551511 -1.8897,-0.655151 -2.21025,-0.13649 -0.13228,0.21404 -0.39207,0.0868 -0.68929,-0.33751 -0.36569,-0.522101 -0.74726,-0.658251 -1.63523,-0.583501 -1.02522,0.0863 -1.18285,0.21881 -1.3725,1.153741 -0.2794,1.37733 -0.35249,1.42776 -1.44407,0.99631 -1.21213,-0.4791 -6.12689,-1.572551 -7.06817,-1.572551 -0.63927,0 -0.73621,0.160311 -0.73621,1.217351 0,0.79564 0.32388,1.72806 0.93494,2.6916 l 0.93494,1.47425 -0.77494,0.1945 c -0.42622,0.10697 -0.77494,0.40775 -0.77494,0.6684 0,0.558 -1.77891,0.61635 -13.44,0.44092 -8.98755,-0.13522 -8.03605,-0.14198 -20,0.14204 -5.280004,0.12535 -9.820474,0.29578 -10.089924,0.37875 -0.30111,0.0927 -1.28413,-0.6505 -2.55076,-1.92849 -2.2612,-2.28148 -3.48854,-2.69269 -4.18009,-1.40052 -0.33895,0.63335 -0.22319,3.05409 0.23918,5.0012 l 0.17097,0.72 h -9.47469 c -8.20862,0 -9.47469,0.0641 -9.47469,0.48 z" /><path
style="font-weight:bold;font-size:85.3333px;line-height:1;font-family:Sans;-inkscape-font-specification:'Sans Bold';text-align:center;letter-spacing:-1px;word-spacing:0px;text-anchor:middle;white-space:pre;fill:#000000;stroke:none;stroke-width:2"
d="m -132.95828,20.234776 h 26.62499 q 11.874996,0 18.208326,5.29166 6.374998,5.25 6.374998,14.99999 0,9.79167 -6.374998,15.08333 -6.33333,5.25 -18.208326,5.25 h -10.58333 v 21.58332 h -16.04166 z m 16.04167,11.62499 v 17.37499 h 8.87499 q 4.66666,0 7.20833,-2.25 2.541664,-2.29166 2.541664,-6.45833 0,-4.16666 -2.541664,-6.41666 -2.54167,-2.25 -7.20833,-2.25 z m 79.499959,16.62499 q -1.958333,-0.91666 -3.916665,-1.33333 -1.916666,-0.45833 -3.874999,-0.45833 -5.749997,0 -8.874996,3.70833 -3.083332,3.66666 -3.083332,10.54166 v 21.49999 h -14.91666 v -46.66664 h 14.91666 v 7.66666 q 2.874999,-4.58333 6.583331,-6.66667 3.749998,-2.12499 8.958329,-2.12499 0.75,0 1.624999,0.0833 0.875,0.0417 2.541666,0.25 z m 28.624985,-3.16666 q -4.958332,0 -7.583331,3.58333 -2.583332,3.54167 -2.583332,10.25 0,6.70833 2.583332,10.29166 2.624999,3.54166 7.583331,3.54166 4.874998,0 7.45833,-3.54166 2.583332,-3.58333 2.583332,-10.29166 0,-6.70833 -2.583332,-10.25 -2.583332,-3.58333 -7.45833,-3.58333 z m 0,-10.66666 q 12.041661,0 18.791658,6.49999 6.791663,6.5 6.791663,18 0,11.49999 -6.791663,17.99999 -6.749997,6.5 -18.791658,6.5 -12.083329,0 -18.916659,-6.5 -6.791664,-6.5 -6.791664,-17.99999 0,-11.5 6.791664,-18 6.83333,-6.49999 18.916659,-6.49999 z m 82.333311,19.37499 v 28.41665 h -15 v -4.625 -17.12499 q 0,-6.04166 -0.29166,-8.33333 -0.25,-2.29166 -0.91667,-3.375 -0.875,-1.45833 -2.375,-2.25 -1.5,-0.83333 -3.41666,-0.83333 -4.66667,0 -7.33333,3.625 -2.66667,3.58333 -2.66667,9.95833 v 22.95832 h -14.91666 v -46.66664 h 14.91666 v 6.83333 q 3.375,-4.08334 7.16666,-6 3.79167,-1.95833 8.375,-1.95833 8.08333,0 12.24999,4.95833 4.20834,4.95833 4.20834,14.41666 z m 59.416635,4.95833 v 4.25 H 98.083295 q 0.54166,5.25 3.791665,7.87499 3.25,2.625 9.08333,2.625 4.70833,0 9.625,-1.375 4.95832,-1.41666 10.16666,-4.24999 v 11.49999 q -5.29166,2 -10.58333,3 -5.29166,1.04167 -10.58333,1.04167 -12.666665,0 -19.708325,-6.41667 -7,-6.45833 -7,-18.08332 0,-11.41667 6.875,-17.95833 6.91666,-6.54166 18.999995,-6.54166 10.99998,0 17.58333,6.62499 6.62499,6.625 6.62499,17.70833 z m -15.33332,-4.95833 q 0,-4.25 -2.5,-6.83333 -2.45835,-2.625 -6.45834,-2.625 -4.33333,0 -7.04166,2.45833 -2.708335,2.41667 -3.375005,7 z"
- id="text4"
- aria-label="Prone" /></g><rect
+ id="text4" /></g><rect
style="display:none;opacity:0.398;fill:#ffffff;stroke-width:0.177726"
id="rect46"
width="703.54913"
diff --git a/public/index.html b/public/index.html
index c565a71..9c5a027 100644
--- a/public/index.html
+++ b/public/index.html
@@ -221,7 +221,6 @@
</button>
<span style="white-space: nowrap;">
- Prone: <input type="checkbox" id="toggle-prone-counter" />
<button type="button" class="set-firing-arc" data-size="small">
<img src="assets/images/firing_arc_small.png" height="12" /> 2 MP
</button>
diff --git a/src/index.js b/src/index.js
index a951084..fa90d13 100644
--- a/src/index.js
+++ b/src/index.js
@@ -16,7 +16,6 @@ if (window.IS_DEV) {
const mapPlaceholder = document.querySelector('.map-placeholder'),
distanceOutput = document.getElementById('status'),
- proneToggle = document.getElementById('toggle-prone-counter'),
contentVisToggleEl = document.querySelector('#edge-inputs input[type="checkbox"].visible'),
fileName = localStorage.getItem('map') || 'scenario-side_show',
map = scenarios[fileName]?.hashed || `assets/images/${fileName}.svg`,
@@ -85,10 +84,10 @@ async function buildScenario(req) {
// recordSheet.start(svg.querySelector('.start-locations'), gameboard.getUnits());
recordSheet.start(null, scenarioUnits);
- //const [trooper] = gameboard.getUnits();
- //Observable.notify('select', trooper);
- //gameboard.setCounter('prone');
- //gameboard.setCounter('1st-floor');
+ const [trooper] = gameboard.getUnits();
+ Observable.notify('select', trooper);
+ gameboard.setCounter('prone');
+ gameboard.setCounter('1st-floor');
}
function updateTurnCounter() {
@@ -173,11 +172,6 @@ document.querySelectorAll('#toggle-firing-arc-vis input').forEach(el =>
el.addEventListener('input', gameboard.toggleFiringArcVisibility)
);
-document.getElementById('toggle-prone-counter').addEventListener('input', function () {
- const selected = recordSheet.getSelected();
- selected && gameboard.toggleProne();
-});
-
document.querySelectorAll('.end-move').forEach(el =>
el.addEventListener('click', () => Observable.notify('endmove'))
);
@@ -313,4 +307,3 @@ dice.forEach(el => {
});
Observable.subscribe('distance', distance);
-Observable.subscribe('proneflag', checked => proneToggle.checked = checked);
diff --git a/src/modules/game/soldier.js b/src/modules/game/soldier.js
index 8e5774b..a71ceba 100644
--- a/src/modules/game/soldier.js
+++ b/src/modules/game/soldier.js
@@ -152,24 +152,6 @@ export function endMove(svg, counter) {
removeClones(svg, counter);
}
-export function hasProne(counter) {
- return !!counter.querySelector('[href="#counter-prone"]:not(.removed)');
-}
-
-export function toggleProne(counter) {
- let proneCounter = counter.querySelector('[href="#counter-prone"]');
-
- if (!proneCounter) {
- proneCounter = document.createElementNS(svgns, 'use');
- proneCounter.setAttributeNS(null, 'href', '#counter-prone');
- counter.appendChild(proneCounter);
- } else if ('preexisting' in proneCounter.dataset) {
- proneCounter.classList.toggle('removed');
- } else {
- proneCounter.remove();
- }
-}
-
export function getSelectedClass() {
return selectedClass;
}
diff --git a/src/modules/gameboard.js b/src/modules/gameboard.js
index 5851273..44146f2 100644
--- a/src/modules/gameboard.js
+++ b/src/modules/gameboard.js
@@ -79,7 +79,6 @@ function getSelected() {
function deselect() {
const selected = getSelected();
placing = [];
- Observable.notify('proneflag', false);
if (selected) {
selected.classList.remove(soldier.getSelectedClass());
@@ -194,7 +193,6 @@ function select(data) {
counter.classList.add(soldier.getSelectedClass());
firingArc.get(svg, counter).forEach(el => el.removeAttribute('clip-path'));
- Observable.notify('proneflag', soldier.hasProne(counter));
placing.push(counter);
}
@@ -266,7 +264,6 @@ export function start(el) {
}
const selected = getSelected();
- //Observable.notify('proneflag', selected && soldier.hasProne(selected));
}
getCells(svg).forEach(cell => {
@@ -317,7 +314,6 @@ export function start(el) {
}
const selected = getSelected();
- Observable.notify('proneflag', selected && soldier.hasProne(selected));
});
cell.addEventListener('dblclick', e => {
@@ -406,14 +402,14 @@ export function start(el) {
// debug //
// Add a trooper counter
- //const attacker = { dataset: { allegiance: 'attacker', number: 1, squad: 1 }};
+ const attacker = { dataset: { allegiance: 'attacker', number: 1, squad: 1 }};
// const defender = { dataset: { allegiance: 'defender', number: 1, squad: 2 }};
- //const cell = getCell(0, 0, 0, 0);
- //const trooper = soldier.createCounter(attacker, 'blazer');
+ const cell = getCell(0, 0, 0, 0);
+ const trooper = soldier.createCounter(attacker, 'blazer');
//const trooperSack = document.createElementNS(svgns, 'g');
//trooperSack.classList.add('cell-contents');
//trooperSack.append(trooper);
- //soldier.place(svg, trooper, cell);
+ soldier.place(svg, trooper, cell);
// Add some counters in an unoccupied cell
//const countersCell = getCell(-1, 1, 0, 0);
@@ -445,11 +441,6 @@ export function clearFiringArcs(allegiance) {
firingArc.clear(svg, allegiance);
}
-export function toggleProne() {
- const selected = getSelected();
- if (selected) soldier.toggleProne(selected);
-}
-
export function toggleFiringArcVisibility() {
firingArc.toggleVisibility(svg, this.dataset.allegiance);
}