Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/simplelegal/react-fetch-flow
A framework for fetching initial data on page load
https://github.com/simplelegal/react-fetch-flow
fetching-data-from-server hoc middleware opinionated-framework react react-router redux
Last synced: 3 months ago
JSON representation
A framework for fetching initial data on page load
- Host: GitHub
- URL: https://github.com/simplelegal/react-fetch-flow
- Owner: SimpleLegal
- License: apache-2.0
- Created: 2017-12-28T23:39:21.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2018-07-16T18:22:46.000Z (over 6 years ago)
- Last Synced: 2024-04-30T15:40:33.271Z (9 months ago)
- Topics: fetching-data-from-server, hoc, middleware, opinionated-framework, react, react-router, redux
- Language: JavaScript
- Homepage:
- Size: 595 KB
- Stars: 4
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# react-fetch-flow
A framework for fetching initial data on page load[Sandbox Demo](https://codesandbox.io/s/5v89j55yj4)
### Why
Fetching data on page load in React Single Page Applications is not straightforward.
You must set loading states, use component lifecycle methods to fetch, while making sure you dont fetch data too often (or not enough) when the user navigates around your application.
The result is a bug prone implementation that you have to think through a lot to get right (and you shouldn't have to)!
This library solves this problem.
### What
React Fetch Flow is a higher order component (HOC), middleware, and a simple reducer that takes care or setting loading states, client side routing behavior (as it relates to loading), and data fetching.
It follows a philosophy to make the implementation simple and intuitive for the user. This philosophy is that the user wants the most up to date data as they navigate throughout the application without having to refresh the page, unless they explicitly say so (for instance, the user presses back). So, react-fetch-flow will fetch data and set loading states whenever they push to browser history, and no other time.
This philosophy leads to a straightforward implementation that is intuitive for the user.
The redux version has more features than the simple react version. Because you can navigate across the application and keep state in the store, the user can update state on one route, then navigate, then if user presses 'back' they will get the previous state.
Use npm or yarn to add:
```yarn add react-fetch-flow```
```npm install react-fetch-flow --save```
### How to integrate with only React
```javascript
import React from 'react'
import { withFetchFlow } from 'react-fetch-flow'
import Loading from './Loading'
import { onRequest } from "./api";
@withFetchFlow({
component: ,
flag: "todos",
onRequest //expects function that returns promise
})
class Todo extends React.Component {
render(){
return (
{this.props.todos.map(todo =>todo.name
)}
)
}
}```
### How to integrate with Redux
There are 3 steps in order to get started:
#### 1. Import Middleware
This manages when to set loading states. You will need to set up your request actions to have ```_REQUESTED``` and ```_SUCCESS``` in order for this to work properly.
```javascript
import { fetchFlowMiddleware } from 'react-fetch-flow'
const middleware = [fetchFlowMiddleware] //add more if needed=
const store = createStore(
rootReducer, // new root reducer with router state
{}, // initialState
applyMiddleware(...middleware)
)```
#### 2. Import Reducer
These will contain the loading states used by the HOC
```javascript
import { combineReducers } from 'redux'
import {loadingReducer} from 'react-fetch-flow'const rootReducer = combineReducers({
//...other reducers
loading: loadingReducer
})```
#### 3. Import Higher Order Component
Apply the HOC to your container components that you want to have fetching responsibility, generally the component that your react-router `````` component renders.
```javascript
import React from 'react'
import { withReduxFlow } from 'react-fetch-flow'
import * as ACT from 'actions/actionTypes'
import Loading from './Loading'
@withReduxFlow({
component: , // loading component
flag: "todo", // loading and loaded flag identifiers
getFetchAction: props => ({ // put action that will be dispatched - follows _REQUESTED / _SUCCESS
type: ACT.INIT_TODOS_LIST_REQUESTED,
payload: {
todoId: props.match.params.todoId
}
})
})
@connect(({todos}) => {
return {
todo: todos.currentTodo
}
})
class Todo extends React.Component {
render(){
return (
{this.props.todo.name}
)
}
}
```