CougarCS is the largest student-run Computer Science organization at the University of Houston. At CougarCS, our mission is to smoothly transition our inexperienced members into young professionals by the end of their degree and to provide support and assistance to members who struggle academically or who need career guidance.
This is the official CougarCS Frontend. This project is built with React using create-react-app. Want to get involved? Get in contact with the CougarCS Webmaster(webmaster@cougarcs.com) to get involved.
- Styling : Bootstrap
- Forms : React-hook-form
- Payment : Stripe
- Request : Axios
- Linting: ESLint
- Testing: Cypress
-
- Install dependencies:
yarn
- Start local server:
yarn start
- The local server will start on http://localhost:3000
- Install dependencies:
-
- If you want to test out the payment or the reCAPTCHA, create a
.env
file in the root project folder. You must clone the CougarCS-Backend for full functionality. Reach out to the CougarCS Webmaster(webmaster@cougarcs.com) to setup the backend. - You must have a Stripe account and Google's reCAPTCHA.
- In the
.env
file include these:
REACT_APP_STRIPE_KEY=<STRIPE_TEST_PUBLISHABLE_KEY> REACT_APP_RECAPTCHA_SITE_KEY=<KEY_ID> REACT_APP_API_URL=<BACKEND_URL>
- If you want to test out the payment or the reCAPTCHA, create a
-
- We use ESLint to fix styling and to enforce rules.
- Run
yarn run eslint-check
to check linting issues in the code. - Run
yarn run eslint-fix
to auto-lint the code. - ESLint runs on Github Action. ESLint must pass before pushing or during a pull request.
-
- We use Cypress to do E2E testing
- To run the tests locally:
- Start the application locally using
yarn start
- There are two ways you can run the test:
- Running the test in the command line
yarn test
- Running test using Cypress GUI
yarn test:ui
- Running the test in the command line
- Start the application locally using
- The tests are part of the CI/CD pipeline, if the test fails the CI/CD fails
- Learn more about testing using Cypress
-
- Static data is in
src/data/
- Images and other assets are in
src/assets/
- The routing is found in
src/App.js
- The
src/pages/
directory will have the pages based on the routing. - The
src/components/
will hold the components that make up the page.
- Static data is in
The site is being deployed to a temporary server via an auto-deploy tool that deploys the build/ folder of this build. Static files are being served at this time only.