}
updateReserve(color, piece, count) {
- if (this.options["cannibal"] && C.CannibalKing[piece])
+ if (this.options["cannibal"] && C.CannibalKings[piece])
piece = "k"; //capturing cannibal king: back to king form
const oldCount = this.reserve[color][piece];
this.reserve[color][piece] = count;
startPiece, curPiece = null,
sqSize;
const mousedown = (e) => {
+ // Disable zoom on smartphones:
+ if (e.touches && e.touches.length > 1) e.preventDefault();
r = container.getBoundingClientRect();
sqSize = this.getSquareWidth(r.width);
const square = this.idToCoords(e.target.id);
document.addEventListener("mouseup", mouseup);
}
if ('ontouchstart' in window) {
- document.addEventListener("touchstart", mousedown);
- document.addEventListener("touchmove", mousemove);
- document.addEventListener("touchend", mouseup);
+ // https://stackoverflow.com/a/42509310/12660887
+ document.addEventListener("touchstart", mousedown, {passive: false});
+ document.addEventListener("touchmove", mousemove, {passive: false});
+ document.addEventListener("touchend", mouseup, {passive: false});
}
}
addPawnMoves([x1, y1], [x2, y2], moves, promotions) {
let finalPieces = ["p"];
const color = this.getColor(x1, y1);
+ const oppCol = C.GetOppCol(color);
const lastRank = (color == "w" ? 0 : this.size.x - 1);
if (x2 == lastRank && (!this.options["rifle"] || this.board[x2][y2] == ""))
{
// promotions arg: special override for Hiddenqueen variant
- if (promotions) finalPieces = promotions;
+ if (
+ this.options["cannibal"] &&
+ this.board[x2][y2] != "" &&
+ this.getColor(x2, y2) == oppCol
+ ) {
+ finalPieces = [this.getPieceType(x2, y2)];
+ }
+ else if (promotions) finalPieces = promotions;
else if (this.pawnSpecs.promotions)
finalPieces = this.pawnSpecs.promotions;
}
};
animateRec(0);
};
- const checkDisplayThenAnimate = () => {
+ // Delay if user wasn't focused:
+ const checkDisplayThenAnimate = (delay) => {
if (boardContainer.style.display == "none") {
alert("New move! Let's go back to game...");
document.getElementById("gameInfos").style.display = "none";
boardContainer.style.display = "block";
setTimeout(launchAnimation, 700);
}
- else launchAnimation(); //focused user!
+ else setTimeout(launchAnimation, delay || 0);
};
let boardContainer = document.getElementById("boardContainer");
if (document.hidden) {
document.onvisibilitychange = () => {
document.onvisibilitychange = undefined;
- checkDisplayThenAnimate();
+ checkDisplayThenAnimate(700);
};
}
else checkDisplayThenAnimate();