diff --git a/.eslintrc.json b/.eslintrc.json index f73bd931..dd4ccb57 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -11,9 +11,8 @@ "eslint:recommended", "plugin:react/recommended", "plugin:jsx-a11y/recommended", - "plugin:react-hooks/recommended", - "plugin:jest/recommended", - "plugin:testing-library/react" + "plugin:react-hooks/recommended" + // "plugin:testing-library/react" ], "parserOptions": { "ecmaFeatures": { diff --git a/README.md b/README.md index feedbaac..0342455b 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,12 @@ # React Tic-Tac-Toe +## Please Read First! + +The digital campus' version of Tic-Tac-Toe differs from the original in the following ways: +- We will *not* be using `main` branch. Follow step 6 in the **One-Time Project Setup** to change branches. +- Wave 1 has been completed for you; however, it would help you understand the flow of data by reviewing the code written for Wave 1. +- Wave 3's `checkForWinner` function has been created for you; however, read through Wave 3 instructions to figure out how and where to use it. + ## Skills Assessed - Following directions and reading comprehension @@ -81,9 +88,15 @@ We can run `yarn install` multiple times safely, but we only need to do this onc The file `package.json` contains details about our project, the scripts available, and the dependencies needed. We can inspect this file when we are curious about the details of our dependencies. -6. Follow the directions in the "Getting Started" section. +6. We will not being using `main` branch. Make sure you are working from `digital-starter` by running: + +```bash +$ git checkout digital-starter +``` + +7. Follow the directions in the "Getting Started" section. -7. Follow the directions in the "Project Requirements" section. +8. Follow the directions in the "Project Requirements" section. ## Project Development Workflow diff --git a/package.json b/package.json index f203daa6..0fe2eb8b 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,7 @@ "react-dom": "^17.0.1", "react-scripts": "4.0.3" }, - "homepage": "http://adagold.github.io/react-tic-tac-toe", + "homepage": "https://houseofvange.github.io/react-tic-tac-toe/", "scripts": { "start": "react-scripts start", "build": "react-scripts build", @@ -21,8 +21,7 @@ }, "eslintConfig": { "extends": [ - "react-app", - "react-app/jest" + "react-app" ] }, "browserslist": { diff --git a/src/App.js b/src/App.js index 0d4e1dea..7192fbe3 100644 --- a/src/App.js +++ b/src/App.js @@ -3,8 +3,8 @@ import './App.css'; import Board from './components/Board'; -const PLAYER_1 = 'X'; -const PLAYER_2 = 'O'; +const PLAYER_1 = 'x'; +const PLAYER_2 = 'o'; const generateSquares = () => { const squares = []; @@ -30,36 +30,111 @@ const App = () => { // empty value and unique ids. const [squares, setSquares] = useState(generateSquares()); + const [currentPlayer, setCurrentPlayer] = useState(PLAYER_1); + // Wave 2 // You will need to create a method to change the square // When it is clicked on. // Then pass it into the squares as a callback + const onClickCallback = (squareID) => { + if (winner){ + return; + } + + let madeMove = false; + + const newSquares = squares.map(row => row.map(position => { + if (position.id != squareID){ + return position; + } + if (position.value !== ''){ + return position; + } + madeMove = true; + const newSquare = {...position, value: currentPlayer}; + return newSquare; + })); + + if (madeMove) { + //update the board + setSquares(newSquares); + + // change the player with each click + let nextPlayer = (currentPlayer === PLAYER_1) ? PLAYER_2 : PLAYER_1; + setCurrentPlayer(nextPlayer); + } + }; const checkForWinner = () => { - // Complete in Wave 3 - // You will need to: - // 1. Go accross each row to see if - // 3 squares in the same row match - // i.e. same value - // 2. Go down each column to see if - // 3 squares in each column match - // 3. Go across each diagonal to see if - // all three squares have the same value. + let i = 0; + + // Check all the rows and columns for a winner + while (i < 3) { + if ( + squares[i][0].value === squares[i][1].value && + squares[i][2].value === squares[i][1].value && + squares[i][0].value !== '' + ) { + return squares[i][0].value; + } else if ( + squares[0][i].value === squares[1][i].value && + squares[2][i].value === squares[1][i].value && + squares[0][i].value !== '' + ) { + return squares[0][i].value; + } + i += 1; + } + // Check Top-Left to bottom-right diagonal + if ( + squares[0][0].value === squares[1][1].value && + squares[2][2].value === squares[1][1].value && + squares[1][1].value !== '' + ) { + return squares[0][0].value; + } + + // Check Top-right to bottom-left diagonal + if ( + squares[0][2].value === squares[1][1].value && + squares[2][0].value === squares[1][1].value && + squares[1][1].value !== '' + ) { + return squares[0][2].value; + } + + return null; }; const resetGame = () => { // Complete in Wave 4 + setSquares(generateSquares()); + setCurrentPlayer(PLAYER_1); + }; + + const winner = checkForWinner(); + + const showStatus = () => { + if (winner){ + // alert(`You did amazing ${winner}!`) + return `Winner is ${winner}`; + }else{ + return `Your turn ${currentPlayer}`; + } }; return ( -