/sof21-frontend

Do not merge to master

Primary LanguageJavaScript

StudentOrkesterFestivalen's front end website.

This is the new front-end developed by SOF21 for SOF, written in React. The page is heavily influenced by Material Design with focus on animations to both give clear intentions of the webpage, as well as giving it some visual flair.

Frameworks

  • React
  • Redux - State management used in conjunction with react to keep track of the state and information in the application
  • Redux Thunk - Redux middleware to handle asynchronous requests
  • Redux Token Auth - Used for handling login with tokens
  • RMWC - Material Design React components
  • SASS - More programmer friendly CSS.
  • Pose - Fluid and easy to create animations.
  • React-intl - Language localization.

Src file structure

Redux/Api

  • /actions contains all Redux actions that are used in the application
  • /reducers contains all Redux reducers that are used in the application
  • /api contains the functions that calls the back-end API.

Page components

  • /pages contains the different pageTypes and pagelayouts with their respective page texts
  • /components contains all smaller react components that are used within the different pages.
  • /locale contains all text strings for the web-page in English and Swedish.

Stylesheets

Payment

The way purchases and payments work in the application is as follows (more about the API calls):

  1. A user adds things to their cart from the store page.
  2. When a user presses the checkout button, the cart is pushed to the backend and they are redirected to the checkout page. This page, and the Card form uses stripes React components to handle payments.
  3. When the payment information has been inputted, a request is sent to stripes API, which return a payment token.
  4. The token is sent to the backend, which charges the card and adds the purchased items to the users account.

.env file

In case the file disappears, it should contain: SASS_PATH=./node_modules REACT_APP_API_ENDPOINT="http://localhost:3000/api/v1/"