This repo is meant to act as a proof-of-concept. As a result, it may have bugs, incomplete features, styling issues, and other problems.
This is a proof-of-concept for an offline-first React app that interacts with a server.
It features:
- A React app that only needs to fetch data once a day
- Eager loading of data when the app is online
- A server that uses a simple JSON file as a database
- A list view of people that are in the "database"
- A detail view of a person that doesn't require a network request
- A "diff" view that encourages the user to select the new data when the server updates while the app is offline
To get started, run the following commands:
yarn install
yarn dev
This will start the server and the client. The client will be available at http://localhost:3000.
The app is designed to be used in the following way:
- Open the app in a browser
- Disable the network connection
- Open a person's detail view
- Change the person's name
- Enable the network connection
- Watch the data be updated to the server
To see the diff view, follow these steps:
- Open the app in a browser
- Disable the network connection
- Open a person's detail view
- Change the person's name
- Open
localhost:3000/updatedates
in a new tab - Press the "Update" button
- Enable the network connection on the first tab
This app uses the following technologies:
- Astro to easily consolidate the client and server into a single
- React to build the UI
- React Query to handle data fetching
- HouseForm to build forms
- React Router to handle routing
- Redux to manage diffing of state data
- Redux Toolkit to simplify Redux usage
- Redux Persist to persist Redux state to local storage