Web Dev Solutions

Catalin Mititiuc

aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCatalin Mititiuc <webdevcat@proton.me>2024-04-24 13:14:32 -0700
committerCatalin Mititiuc <webdevcat@proton.me>2024-04-24 13:14:32 -0700
commitf3a5999142f3444d2fc661c5f0747ddaaaaf5e59 (patch)
treedf8e9767e928d07369c5898c1072b848ecb5da79 /src/modules
parentb73217c5c45e2c23ac14e70346036cf4477a6ebe (diff)
Retain preexisting counters in move history
Diffstat (limited to 'src/modules')
-rw-r--r--src/modules/counter.js31
1 files changed, 21 insertions, 10 deletions
diff --git a/src/modules/counter.js b/src/modules/counter.js
index a4bd4b4..6a1da45 100644
--- a/src/modules/counter.js
+++ b/src/modules/counter.js
@@ -255,6 +255,14 @@ export default class Counter {
selected.parentElement.appendChild(clone);
point.parentElement.appendChild(selected);
+ selected.childNodes.forEach(n => {
+ if (n.classList.contains('removed')) {
+ n.remove();
+ } else if ('preexisting' in n.dataset) {
+ delete n.dataset.preexisting;
+ }
+ });
+
let previous = this.getCellPosition(clone.parentElement),
current = this.getCellPosition(selected.parentElement);
@@ -288,24 +296,23 @@ export default class Counter {
removeClones({ dataset: { allegiance, number }}) {
this.getClones(allegiance, number).forEach(el => {
- const proneCounter = el.parentElement.querySelector('[href="#counter-prone"]');
-
- if (proneCounter) {
- proneCounter.remove();
- }
-
el.remove()
});
}
endMove(el) {
- let { number: troopNumber, allegiance: troopAllegiance } = el.dataset;
- let trace = this.svg.querySelector(this.traceSelector(troopNumber, troopAllegiance));
+ const { number, allegiance } = el.dataset,
+ trace = this.svg.querySelector(this.traceSelector(number, allegiance)),
+ proneCounter = el.querySelector('[href="#counter-prone"]');
if (trace) {
trace.remove();
}
+ if (proneCounter) {
+ proneCounter.dataset.preexisting = '';
+ }
+
this.removeClones(el);
this.unSelect();
}
@@ -314,7 +321,7 @@ export default class Counter {
const isOnBoard = counter.parentElement.hasAttribute('data-x');
if (isOnBoard) {
- return !!counter.parentElement.querySelector('[href="#counter-prone"]');
+ return !!counter.querySelector('[href="#counter-prone"]');
}
return false;
@@ -328,7 +335,11 @@ export default class Counter {
const proneCounter = selected.querySelector('[href="#counter-prone"]');
if (proneCounter) {
- proneCounter.remove();
+ if ('preexisting' in proneCounter.dataset) {
+ proneCounter.classList.toggle('removed');
+ } else {
+ proneCounter.remove();
+ }
} else {
const counter = document.createElementNS(svgns, 'use');
counter.setAttributeNS(null, 'href', '#counter-prone');