Based on the frontend steps for building the moments fullstack app in this repo.
npm start # port 3000 is used
npm test
npm run lint
npm run build
This project uses React v17.0.2 which was released March 2021. I relies on a deployed Django (Python) backend project by default. This can be changed by editing the axios.defaults.baseURL
value in src\api\axiosDefaults.js file to point to a locally running backend.
It uses the Bootstrap v4.6 CSS framework which was released January 2021.
It also use:
The package.json for the app after its complete uses these version settings:
"dependencies": {
"@testing-library/jest-dom": "^5.16.5",
"@testing-library/react": "^11.2.7",
"@testing-library/user-event": "^12.8.3",
"axios": "^0.21.4",
"bootstrap": "^4.6.0",
"jwt-decode": "^3.1.2",
"react": "^17.0.2",
"react-bootstrap": "^1.6.3",
"react-dom": "^17.0.2",
"react-infinite-scroll-component": "^6.1.0",
"react-router-dom": "^5.3.0",
"react-scripts": "^4.0.3",
"web-vitals": "^1.1.2"
},
The documentation below follow the Code Institute advanced frontend moments project walkthrough.
As of this writing, mid-2024, the stack is getting quite dated. As it was designed for a full-stack web development boot camp student project, it has served its purpose well. Be aware that information online about the libraries used might point to newer versions. A good example is the routing section below.
Clone the repo on your local computer in the usual way, install the dependencies and start the app with commands such as:
git clone https://github.com/timofeysie/dot-one.git
npm install
npm start
If you experience any of these errors when trying to start the app,
Cannot find module 'C:\Users\Gia\repos\dot-one\node_modules\isexe\index.js'. Please verify that the package.json has a valid "main" entry
'react-scripts' is not recognized as an internal or external command, operable program or batch file.
Error: error:0308010C:digital envelope routines::unsupported
opensslErrorStack: [ 'error:03000086:digital envelope routines::initialization error' ],
library: 'digital envelope routines',
reason: 'unsupported',
code: 'ERR_OSSL_EVP_UNSUPPORTED'
Node.js v20.10.0
Change the 'start' to "start": "react-scripts --openssl-legacy-provider start" and it works
The issue and solutions are described in this StackOverflow link.
> [email protected] start
> react-scripts --openssl-legacy-provider start
C:\Program Files\nodejs\node.exe: bad option: --openssl-legacy-provider
In this case I needed to remove the --openssl-legacy-provider
from the package.json scripts section:
"scripts": {
"heroku-prebuild": "npm install -g serve",
"start": "react-scripts --openssl-legacy-provider start",
Create a branch from the develop branch. Don't work on the main branch directly. Pull requests will be made by requesting to merge work from your issue branch into the develop branch. When we want to do a deployment to prod, there will be a merge of the develop branch into the main branch which will then automatically trigger a deployment to production.
Please see the full how the app was made document in the docs directory for details about how feature creation, issues faced and deployment steps.
Here are some things that will make the app better for growing bigger.
- use an enum for strings such as
useRedirect("loggedIn");
to avoid typos