diff --git a/README.md b/README.md index 3708301b..aa5ed2f6 100644 --- a/README.md +++ b/README.md @@ -4,21 +4,36 @@ [![Netlify Status](https://api.netlify.com/api/v1/badges/15895bed-2a7e-4a27-aa63-633a0cd645f1/deploy-status)](https://app.netlify.com/sites/sleepy-franklin-7a3e4c/deploys) [![Coverage Status](https://coveralls.io/repos/github/uclaacm/TeachLAFrontend/badge.svg?branch=master)](https://coveralls.io/github/uclaacm/TeachLAFrontend?branch=master) -This repository holds the frontend code for the ACM Teach LA online editor! Teach LA uses the editor to help teach LA students about Python, Web Development, and expose them to computer science! +This repository holds the frontend code for the ACM Teach LA online editor! +Teach LA uses the editor to help teach LA students about Python, Web +Development, and expose them to computer science! -Our editor is primarily developed with [React](https://reactjs.org/) + [Redux](https://redux.js.org/), and uses a smattering of other Node packages. The project is actively developed and maintained by the [ACM Teach LA](https://teachla.uclaacm.com) Dev Team (part of [ACM @ UCLA](https://uclaacm.com)). +Our editor is primarily developed with [React](https://reactjs.org/) + +[Redux](https://redux.js.org/), and uses a smattering of other Node packages. +The project is actively developed and maintained by the [ACM Teach +LA](https://teachla.uclaacm.com) Dev Team (part of [ACM @ +UCLA](https://uclaacm.com)). -Want to find out more about ACM Teach LA, or join the developer team? Check out [our website](https://teachla.uclaacm.com) or shoot us an email at [acmteachla@gmail.com](mailto:acmteachla@gmail.com). +Want to find out more about ACM Teach LA, or join the developer team? Check out +[our website](https://teachla.uclaacm.com) or shoot us an email at +[acmteachla@gmail.com](mailto:acmteachla@gmail.com). ## Developer Setup You'll need: -- [Node](https://nodejs.org/en/) (we develop this with Node v14.15.5 LTS) +- [Node](https://nodejs.org/en/) (we develop this with Node v20.11.0 LTS) +- `npm` (which comes with Node) - [git](https://git-scm.com/) -- either `npm` (which comes default with Node) or [yarn](https://yarnpkg.com/en/) -There are actually two different ways to run the app locally on your machine - one that uses our staging backend server, and one where you'll run it locally. Usually, the staging server is totally fine to use, but having the backend makes more sense if you're working on a new feature or are editing the backend. +Then install `pnpm` ([instructions](https://pnpm.io/installation)). `pnpm` +does what `npm` does but is much more efficient. Also, it can manage different +`node` versions for you. + +There are actually two different ways to run the app locally on your machine - +one that uses our staging backend server, and one where you'll run it locally. +Usually, the staging server is totally fine to use, but having the backend +makes more sense if you're working on a new feature or are editing the backend. ### Connecting to a backend @@ -29,41 +44,38 @@ We'll follow the standard node project workflow. Type the following lines into y ```bash $ git clone https://github.com/uclaacm/TeachLAFrontend.git $ cd TeachLAFrontend -$ npm install -$ npm run staging_start # not npm run start! +$ pnpm install +$ pnpm staging_start ``` -And voila! `create-react-app` should automatically open a new browser window with the editor; give it a few seconds to start up and you should be good to go. You can also manually visit it on `localhost:8080`. +And voila! `vite` should automatically open a new browser window with the +editor; give it a few seconds to start up and you should be good to go. You can +also manually visit it on `localhost:5173` -#### Using a Local Server (More Flexible) +#### Using a Local Server (Advanced) -Here, you'll run our backend on your local machine - you can find more information on that [here](https://github.com/uclaacm/teach-la-go-backend). +Here, you'll run our backend on your local machine, which offers more +flexibility; you can find more information on that +[here](https://github.com/uclaacm/teach-la-go-backend). And in another terminal window: +**TODO** Find equivalent of `react-scripts start`. + ```bash $ git clone https://github.com/uclaacm/TeachLAFrontend.git $ cd TeachLAFrontend -$ npm install -$ npm start +$ pnpm install +$ pnpm start # this doesn't work right now ``` -The client should now be automatically opened in your browser; however, you can also manually visit it on `localhost:8080`. Note that we've also opened a copy of the go backend on `localhost:8081`. - -### Running Into This Weird Error? - -If you have followed these steps and are running into Node.js errors like the -following: `error:0308010C:digital envelope routines::unsupported`, it may be -because you are running an newer version of Node that we currently do not target. - -To fix this issue, revert to Node v16 (we develop with Node v16.20.0). To do so without interfering with any existing -Node installation (and as a proper future-proofing measure), install a version manager for Node: Windows -users should follow directions to install [nvm for Windows](https://github.com/coreybutler/nvm-windows), and -Mac/Linux users should follow directions to install [nvm for POSIX systems](https://github.com/nvm-sh/nvm). +The client should now be automatically opened in your browser; however, you can +also manually visit it on `localhost:5173`. Note that we've also opened a copy +of the go backend on `localhost:8081`. ## Notes for Developers: -- every time you pull from master, make sure to run `npm install` - it's likely that some dependency has changed! +- every time you pull from master, make sure to run `pnpm install` - it's likely that some dependency has changed! - `lint-staged` and `husky` auto-prettify some JS code on save - don't be spooked! - GitHub Actions auto-builds branches and PRs - make sure that `npm run test` `npm run prod_build` pass, or your changes for-sure won't work! - Netlify auto-deploys PRs, branches, and production deploys using the contents of `npm run prod_build`!