react-hook-data

1.8.5 • Public • Published
react-hook-data logo

A lib for fetching normalized data in components via react hooks.

See the full documentation for further complex use cases with several collections of data.

CircleCI npm version

Basic Usage

Define your components as children of the DataContext.Provider:

import { DataContext } from 'react-hook-data'
 
import Foos from './foos'
 
const Root = () => (
  <DataContext.Provider config={{ rootUrl: "https://momarx.com" }}>
    <Foos />
  </DataContext.Provider>
)
 
export default Root

Where Foos will access to the data elements:

import React, { Fragment, useState } from 'react'
import { DataContext } from 'react-hook-data'
 
const Foos = () => {
  const { data, dispatch } = useContext(DataContext)
  const { foos } = data || {}
  const [error, setError] = useState(null)
 
  dispatch(requestData({
    apiPath: '/foos',
    handleFail: (state, action) => setError(action.error)
  }))
 
  if (error) {
    return error
  }
 
  return (
    <Fragment>
      {(foos || []).map(foo => (
        <div className="foo" key={foo.id}>
          {foo.text}
        </div>
      ))}
    </Fragment>
  )
}

Usage with withData

Just rewrite your foos component as a container-like one:

  const Foos = ({ foos }) => {
    const { dispatch } = useContext(DataContext)
    ...
  }

And use the withData hoc in order to make it more react-redux-like:

import { withData } from 'react-hook-data'
 
import Foos from './foos'
 
const mapDataToProps(data, ownProps) {
  return {
    foos: (data.foos || []).filter(foo => foo.type === ownProps.type)
  }
}
 
const FoosContainer = withData(mapDataToProps)(Foos)

/react-hook-data/

    Package Sidebar

    Install

    npm i react-hook-data

    Weekly Downloads

    27

    Version

    1.8.5

    License

    MPL-2.0

    Unpacked Size

    55.1 kB

    Total Files

    11

    Last publish

    Collaborators

    • ledoux