Skip to content

Latest commit

 

History

History
91 lines (76 loc) · 3.74 KB

README.md

File metadata and controls

91 lines (76 loc) · 3.74 KB

React Template

This TypeScript based template is designed to get you up and running with a bunch of awesome front-end technologies.

The primary goal of this project is to provide a stable foundation upon which to build modern web applications. Its purpose is not to dictate your project structure or to demonstrate a complete real-world application, but to provide a set of tools intended to make front-end development robust, easy, and, most importantly, fun.

Tips & Tricks

Features

  • support for .css & .js files
  • TypeScript
  • linaria
  • Normalize.css
  • browserslist
  • ESLint
  • Prettier
  • stylelint
  • Babel
  • web-vitals
  • webpack
    • code splitting (css & js)
    • tree shaking
    • terser
  • Jest & React Testing Library
  • optional libraries
    • styled-media-query
    • @reduxjs/toolkit
    • polished
    • js-cookie
    • axios
    • @loadable/component (enable code splitting)

Installation

Install the project dependencies.

$ npm i

We recommend using the Redux DevTools Chrome Extension. Using the chrome extension allows your monitors to run on a separate thread and affords better performance and functionality. It comes with several of the most popular monitors, is easy to configure, filters actions, and doesn't require installing any packages in your project.

Running the Project

After completing the installation step, you're ready to start the project!

$ npm run start  # Start the development server

While developing, you will probably rely mostly on npm run start however, there are additional scripts at your disposal:

npm run <script> Description
build Build prod app to ./build
lint:css Lint the project for potential errors
lint:css:fix Lint the project and fixes all correctable errors
lint:js Lint the project for potential errors
lint:js:fix Lint the project and fixes all correctable errors
start Serve your dev app at localhost:3000
start:prod Serve your prod app at localhost:8080
test Run unit tests with Jest
test:watch Run test in watch mode to re-run tests when changed
test:coverage Generate information about coverage to ./coverage

Testing

To add a unit test, create a .spec.tsx or .test.tsx file anywhere inside of ./src. Jest and webpack will automatically find these files.