rlcube / src /components /rubiks-cube.tsx
imwithye's picture
add context to record all cubes
ec43676
raw
history blame
934 Bytes
import { CubePiece } from "./cube-piece";
import { FacingDirection } from "./consts";
import { Rotator } from "./rotator";
import { CubesProvider } from "@/contexts/cubes-context";
const CUBE_POSITIONS: Array<[number, number, number]> = [];
for (let x = -0.5; x <= 0.5; x += 1) {
for (let y = -0.5; y <= 0.5; y += 1) {
for (let z = -0.5; z <= 0.5; z += 1) {
CUBE_POSITIONS.push([x, y, z]);
}
}
}
type RubiksCubeProps = {
roughness: number;
};
export const RubiksCube = ({ roughness }: RubiksCubeProps) => {
return (
<CubesProvider>
{CUBE_POSITIONS.map((position) => (
<CubePiece
key={position.join(",")}
initialPosition={position}
roughness={roughness}
/>
))}
{["front", "back", "left", "right", "top", "bottom"].map((face) => (
<Rotator key={face} facingDirection={face as FacingDirection} />
))}
</CubesProvider>
);
};