E39: React Tic-Tac-Toe Tutorial

In this experience, you will build a GitHub repo containing the code to implement the React Tic Tac Toe Tutorial.

The tutorial indicates that there are two ways to do the tutorial: writing the code in a browser using CodeSandbox, or settings up a local development environment on your machine.

For this experience, you’ll do the latter, but in a slightly different way than suggested, because we’ll take advantage of our knowledge of GitHub and IntelliJ.

Note that to get credit for this experience, you need to commit your code at the completion of each part with the specified message. That will allow the TA to easily “retrace your steps” and see that you worked your way through the tutorial.

Task 1: Set up your development environment.

For this task, you’ll set up a private GitHub repo.

When you have this working, commit and push your code to GitHub with the message “Task 1”. The TA will be checking for the presence of this commit with this message. There should be only two files in your repo: .gitignore and README.md.

If you’ve made a mistake, fix it and recommit using the same message (“Task 1”). If the TA sees a sequence of commits, all with the label Task 1, the TA will check the last one only. You are not penalized for multiple commits of Task 1, only if the final one does not conform to these instructions.

Task 2: How to Follow Along

Now you are finally ready to follow the tutorial. Read through until you get to the Note about following the tutorial using your local development environment. Here’s a summary of the five steps (consult the React tutorial for the precise instructions):

  1. Make sure you have Node.js installed. (You should already have done this!)
  2. Download the source code as a Zip file (We are also providing a zip in case downloading from CodeSandbox doesn’t work for you).
  3. Extract the Zip file.
  4. Copy the contents of the extracted zip file into your react-tic-tac-toe directory.
  5. Run npm install to install the libraries in package.json. Note that npm will likely inform you that some vulnerabilities exist in these libraries. You do not have to worry about these for now.
  6. Run npm start.

Then invoke npm start and check to see that http://localhost:3000 shows a single box with an “X” in it.

Now you are ready to commit and push your repo to GitHub with the message “Task 2”. There should only be about a half dozen files to commit. If there are hundreds, then it’s probably because your .gitignore is set up incorrectly and you are committing the node_modules directory. Please be sure to fix that.

Task 3: In Overview, all the way to “React Developer Tools”

Keep following the Overview section of the tutorial, trying to understand the code, until you get to the end of the Developer Tools section. Note that your browser window should automatically refresh with the changed code base as you move along.

At this point, you should install React Chrome Developer Tools, which provides a high quality interface to the state of your React application. (After installing, restart Chrome to see the React tabs in your Developer Tools window.) For example, here’s what my React pane looks like:

picture

Once you’ve gotten to this point, commit and push your code to GitHub with the message “Task 3”.

Task 4: “Completing the Game” section

For this task, go through the section Completing the Game.

Once you’ve completed the “Declaring a Winner” section, commit and push your code to GitHub with the message “Task 4”.

Task 5: “Adding Time Travel” section

Now go through the section Adding Time Travel.

You should now have a working tic-tac-toe game, but more importantly, have an initial understanding of basic React principles.

Once you’ve completed this section, commit and push your code to GitHub with the message “Task 5”.

When you’ve finished, your commit history on GitHub should look something like this:

picture

Task 6: Get more experience!

The Wrapping Up section contains six ideas for improvements.

If you want, you can implement one or more of these improvements to gain more experience, but it’s not required for this assignment.

Submission instructions

By the time and date indicated in Laulima, submit this assignment via Laulima.

Your submission should contain a link to the GitHub repository you created. Make sure you include the complete URL so that I can click on it in my mailer. Note: the final commit to this repo must have been made before the submission time and date, otherwise you will not receive credit for this assignment.

You must now grant read access to this repo to the TA for your section. To do this: