React frontend assignment

Fork this repository and commit your implementation.

Description

Your task is to implement a component or a set of components allowing the users to fetch and display change history of users and projects in separate tables according to the designs and requirements below. You can use the provided packages and add new ones if necessary. Please provide unit tests for your code.

Requirements

  • Handle the loading state
  • Handle the error state (every second call to fetch users or projects will result in an error)
  • Make sure the table can be browsed also on smaller screens
  • By default table data should be sorted in reverse chronological order (newest first)
  • Users should be able to sort by the Date column only and be able to toggle between reverse chronological and chronological order
  • After fetching new entries, table should be re-sorted according to currently selected sorting order

Screenshots

Default state

Screen Shot 2020-03-03 at 13 25 01

Loading state

Screen Shot 2020-03-03 at 13 25 16

Error state

Screen Shot 2020-03-03 at 13 25 09

Setup

This project was bootstrapped with Create React App.

Available Scripts

In the project directory, you can run:

yarn start

Runs the app in the development mode.
Open http://localhost:3000 to view it in the browser.

The page will reload if you make edits.
You will also see any lint errors in the console.

yarn test

Launches the test runner in the interactive watch mode.
See the section about running tests for more information.