diff --git a/src/components/Board/Board.tsx b/src/components/Board/Board.tsx
index d8f6387..60fd69c 100644
--- a/src/components/Board/Board.tsx
+++ b/src/components/Board/Board.tsx
@@ -9,7 +9,7 @@ import {
ChevronLeftIcon,
ChevronRightIcon,
} from "@heroicons/react/24/outline";
-import { surfaceOrientations } from "../../constants";
+import { Orientation, surfaceOrientations } from "../../constants";
export const Board = ({ gridArea }: { gridArea: string }) => {
const { grid, surface, clickBoard } = useContext(GameStateContext);
@@ -23,14 +23,14 @@ export const Board = ({ gridArea }: { gridArea: string }) => {
}}
>
- {surfaceOrientations[surface] ? : ""}
+ {surfaceOrientations[surface].w !== Orientation.None ? : ""}
- {surfaceOrientations[surface] ? : ""}
+ {surfaceOrientations[surface].h !== Orientation.None ? : ""}
{surfaceOrientations[surface] ? (
- surfaceOrientations[surface].w === true ? (
+ surfaceOrientations[surface].h === Orientation.Nonorientable ? (
) : (
@@ -41,7 +41,7 @@ export const Board = ({ gridArea }: { gridArea: string }) => {
{surfaceOrientations[surface] ? (
- surfaceOrientations[surface].h === true ? (
+ surfaceOrientations[surface].w === Orientation.Orientable ? (
) : (
diff --git a/src/components/Grid/paintGrid.ts b/src/components/Grid/paintGrid.ts
index 6297cf7..00b1a26 100644
--- a/src/components/Grid/paintGrid.ts
+++ b/src/components/Grid/paintGrid.ts
@@ -1,6 +1,13 @@
import { range } from "lodash";
import { PENTOMINOES } from "../../pentominoes";
-import { EMPTY_PENTOMINO, PaintedCell, PlacedPentomino, Surface } from "../../constants";
+import {
+ EMPTY_PENTOMINO,
+ Orientation,
+ PaintedCell,
+ PlacedPentomino,
+ Surface,
+ surfaceOrientations,
+} from "../../constants";
interface NewCoordinates {
newX: number;
@@ -30,7 +37,9 @@ export function getPaintedBoard(grid: PlacedPentomino[][], surface: Surface): Pa
if (val === 0) return; // the pentomino isn't taking up this square of its grid, return
const rawX = x + px - orientation.center.x;
const rawY = y + py - orientation.center.y;
- const { newX, newY } = getCoordinatesToPaint(surface, grid.length, grid[0].length, rawX, rawY);
+ const height = grid.length;
+ const width = grid[0].length;
+ const { newX, newY } = getCoordinatesToPaint(surface, height, width, rawX, rawY);
if (checkOutOfBounds(grid, paintedGrid, newX, newY)) return;
@@ -40,11 +49,20 @@ export function getPaintedBoard(grid: PlacedPentomino[][], surface: Surface): Pa
cellToPaint.conflict = true;
}
cellToPaint.pentomino = p;
- if (px === 0 || orientation.shape[px - 1][py] === 0) cellToPaint.borderTop = true;
- if (py === 0 || orientation.shape[px][py - 1] === 0) cellToPaint.borderLeft = true;
- if (px === orientation.shape.length - 1 || orientation.shape[px + 1][py] === 0) cellToPaint.borderBot = true;
- if (py === orientation.shape[0].length - 1 || orientation.shape[px][py + 1] === 0)
- cellToPaint.borderRight = true;
+ const flipX = outOfBounds(rawY, width) && surfaceOrientations[surface].h === Orientation.Nonorientable;
+ const flipY = outOfBounds(rawX, height) && surfaceOrientations[surface].w === Orientation.Nonorientable;
+ if (px === 0 || orientation.shape[px - 1][py] === 0) {
+ cellToPaint[flipX ? "borderBot" : "borderTop"] = true;
+ }
+ if (py === 0 || orientation.shape[px][py - 1] === 0) {
+ cellToPaint[flipY ? "borderRight" : "borderLeft"] = true;
+ }
+ if (px === orientation.shape.length - 1 || orientation.shape[px + 1][py] === 0) {
+ cellToPaint[flipX ? "borderTop" : "borderBot"] = true;
+ }
+ if (py === orientation.shape[0].length - 1 || orientation.shape[px][py + 1] === 0) {
+ cellToPaint[flipY ? "borderLeft" : "borderRight"] = true;
+ }
})
);
})
@@ -67,13 +85,13 @@ export function getCoordinatesToPaint(
};
case Surface.KleinBottle:
return {
- newX: outOfBounds(rawY, height) ? orient(wrap(rawX, height), height) : wrap(rawX, height),
+ newX: outOfBounds(rawY, width) ? orient(wrap(rawX, height), height) : wrap(rawX, height),
newY: wrap(rawY, width),
};
case Surface.ProjectivePlane:
return {
- newX: outOfBounds(rawY, height) ? orient(wrap(rawX, height), height) : wrap(rawX, height),
- newY: outOfBounds(rawX, width) ? orient(wrap(rawY, width), width) : wrap(rawY, width),
+ newX: outOfBounds(rawY, width) ? orient(wrap(rawX, height), height) : wrap(rawX, height),
+ newY: outOfBounds(rawX, height) ? orient(wrap(rawY, width), width) : wrap(rawY, width),
};
case Surface.Torus:
return {
diff --git a/src/constants.ts b/src/constants.ts
index 95dc497..a8f8a42 100644
--- a/src/constants.ts
+++ b/src/constants.ts
@@ -75,14 +75,21 @@ export enum Surface {
KleinBottle, // klein bottle
}
+export enum Orientation {
+ Orientable,
+ Nonorientable,
+ None,
+}
+
interface SurfaceOrientations {
- [key: number]: { h: boolean; w: boolean };
+ [key: number]: { h: Orientation; w: Orientation };
}
export const surfaceOrientations: SurfaceOrientations = {
- [Surface.Torus]: { h: false, w: false },
- [Surface.ProjectivePlane]: { h: true, w: true },
- [Surface.KleinBottle]: { h: false, w: true },
+ [Surface.Rectangle]: { w: Orientation.None, h: Orientation.None },
+ [Surface.Torus]: { w: Orientation.Orientable, h: Orientation.Orientable },
+ [Surface.ProjectivePlane]: { w: Orientation.Nonorientable, h: Orientation.Nonorientable },
+ [Surface.KleinBottle]: { w: Orientation.Orientable, h: Orientation.Nonorientable },
};
export type UrlConfig = {