Skip to content

Commit

Permalink
Add toggle to view pawn structure without pieces
Browse files Browse the repository at this point in the history
  • Loading branch information
zackschuster committed Jul 3, 2024
1 parent 2bba1c7 commit 41d44e4
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 12 deletions.
7 changes: 7 additions & 0 deletions public/pieces/view-pawn-structure.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
.bishop,
.knight,
.rook,
.queen,
.king {
display: none;
}
2 changes: 1 addition & 1 deletion src/chessground/Chessground.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ export function Chessground(
useEffect(() => {
if (ref?.current == null) return;
if (api) {
api?.set({
api.set({
...props,
events: {
change: () => {
Expand Down
49 changes: 38 additions & 11 deletions src/components/boards/Board.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,8 @@ import {
IconEdit,
IconEditOff,
IconEraser,
IconEye,
IconEyeOff,
IconPlus,
IconSwitchVertical,
IconTarget,
Expand All @@ -65,6 +67,7 @@ import { chessgroundDests, chessgroundMove } from "chessops/compat";
import { makeSan } from "chessops/san";
import { useAtom, useAtomValue } from "jotai";
import { memo, useContext, useMemo, useState } from "react";
import { Helmet } from "react-helmet";
import { useHotkeys } from "react-hotkeys-hook";
import { useTranslation } from "react-i18next";
import { match } from "ts-pattern";
Expand Down Expand Up @@ -167,8 +170,11 @@ function Board({
if (forcedEP && pos) {
dests = forceEnPassant(dests, pos);
}
const turn = pos?.turn || "white";

const [viewPawnStructure, setViewPawnStructure] = useState(false);
const [pendingMove, setPendingMove] = useState<NormalMove | null>(null);

const turn = pos?.turn || "white";
const orientation =
movable === "white" || movable === "black"
? movable
Expand Down Expand Up @@ -354,6 +360,21 @@ function Board({
</ActionIcon>
</Tooltip>
)}

<Tooltip label="Toggle Pawn Structure View">
<ActionIcon
variant={editingMode ? "filled" : "default"}
size="lg"
onClick={() => setViewPawnStructure(!viewPawnStructure)}
>
{viewPawnStructure ? (
<IconEyeOff size="1.3rem" />
) : (
<IconEye size="1.3rem" />
)}
</ActionIcon>
</Tooltip>

{saveFile && (
<Tooltip label={`Save PGN (${keyMap.SAVE_FILE.keys})`}>
<ActionIcon
Expand Down Expand Up @@ -406,12 +427,12 @@ function Board({
: editingMode
? "both"
: match(movable)
.with("white", () => "white" as const)
.with("black", () => "black" as const)
.with("turn", () => turn)
.with("both", () => "both" as const)
.with("none", () => undefined)
.exhaustive();
.with("white", () => "white" as const)
.with("black", () => "black" as const)
.with("turn", () => turn)
.with("both", () => "both" as const)
.with("none", () => undefined)
.exhaustive();
}, [practiceLock, editingMode, movable, turn]);

const theme = useMantineTheme();
Expand Down Expand Up @@ -518,6 +539,11 @@ function Board({

return (
<>
{viewPawnStructure && (
<Helmet>
<link rel="stylesheet" href="/pieces/view-pawn-structure.css" />
</Helmet>
)}
<Box w="100%" h="100%">
<Box
style={{
Expand Down Expand Up @@ -596,9 +622,9 @@ function Board({
style={
isBasicAnnotation(currentNode.annotations[0])
? {
"--light-color": lightColor,
"--dark-color": darkColor,
}
"--light-color": lightColor,
"--dark-color": darkColor,
}
: undefined
}
className={chessboard}
Expand Down Expand Up @@ -649,7 +675,7 @@ function Board({
: dests,
showDests,
events: {
after: (orig, dest, metadata) => {
after(orig, dest, metadata) {
if (!editingMode) {
const from = parseSquare(orig)!;
const to = parseSquare(dest)!;
Expand Down Expand Up @@ -690,6 +716,7 @@ function Board({
enabled: false,
}}
draggable={{
enabled: !viewPawnStructure,
deleteOnDropOff: editingMode,
}}
drawable={{
Expand Down

0 comments on commit 41d44e4

Please sign in to comment.