Skip to content

A react project that shows a 3d scene instead of text and buttons! (Part of the academy curriculum)

Notifications You must be signed in to change notification settings

WeAreAcademy/react-three-fiber-react-week-1-demo

Repository files navigation

React-three-fiber demo for early React beginners.

Installation

yarn

Running dev server

yarn start

This will start a local server listening for http requests on port 3000.

It will also ask your browser to open a tab to http://localhost:3000/

Any type-check and linting errors will appear in the browser and in the terminal output as you browse.

Relaxing complains from ESLint

If you find lint is too strict, you can edit the rules section of .eslintrc.cjs.

Building and previewing a static version of your app:

This process is normally performed automatically by a build&host service such as Netlify or Vercel.

However, you can run it yourself to observe the outputs.

yarn build

This will bundle your many source files into very few in dist/, ready for deployment on a web server. As part of the process, it will convert your TypeScript files into JavaScript, using the TypeScript compiler, tsc.

If you've run a local build, you can start a local server to host those files, using:

yarn preview

Automatic Deployment with Netlify

See Netlify with Git or more generally, "Deploying a Static Site" in the Vite Guide.

Other scripts

See package.json for other scripts.

Feature summary

  • React app (hot-reloaded when you make changes)
  • TypeScript
  • react-three-fiber and the Drei helpers
  • ESLint and custom config
  • Formatting with prettier
  • Testing with
    • vitest (jest-equivalent) and
    • react-testing-library
  • CI with GitHub Actions
  • vscode debugger launch config
  • Vite
    • Type-checking and linting errors presented into the browser (vite-plugin-checker)
  • As little other junk as possible

Attaching the vscode javascript debugger to your react app (in dev)

(This is meant as an optional alternative to the excellent chrome devtools.)

  • Start the dev server (e.g. yarn start)
  • In vscode, switch to the "Run and debug" tab from the side menu
  • At the top, click the green play button entitled "Launch Chrome against localhost"
    • Browser should also launch, eventually
  • Add breakpoint(s) to your react code in vscode, or add the debugger keyword
  • Interact with the React app so that your breakpoints / debugger keyword are encountered.
  • vscode's debugger should now present you with the local variables, the call stack, etc.
  • Use the transport controls at the top to step through your code or continue execution

Alternative to vite-plugin-checker

If you don't want to use vite-plugin-checker but you do want to get type-checking errors in the terminal, you can run dev and type-check at the same time by adding this script to package.json:

"dev-and-type-check": "npx concurrently 'vite --port 3000' 'tsc --noEmit --watch'"

Misc notes on Vite

About

A react project that shows a 3d scene instead of text and buttons! (Part of the academy curriculum)

Resources

Stars

Watchers

Forks