Skip to content

Latest commit

 

History

History
110 lines (79 loc) · 3.12 KB

README.md

File metadata and controls

110 lines (79 loc) · 3.12 KB

react-io

React bindings for url-io Request and mutate data using a standard interface passed through React context.

Note

As far as I know, this is only used at Sharecare. SWR is a better alternative.

Passing IO through context

Adds IO to context. Use once at the root of your app.

import React from 'react'
import {IOProvider} from 'react-io'
import io from './io'

export default function App() {
  return <IOProvider io={io}>...</IOProvider>
}

Consuming io

useIO([path, params])

When called without any args, it returns the io function that can be used in callbacks.

import {useIO} from 'react-io'

export default function Widget() {
  const io = useIO()

  return <button onClick={() => io('/path', 'SAVE', {value: 'x'})}>Save</button>
}

When called with path and params, it will subscribe to and return values from io. By default, it suspends until the observable resolves. Note that suspense does not officially support this use case. Errors will be thrown to React and should be caught using error boundaries.

import {useIO} from 'react-io'

export default function Widget() {
  const auth = useIO('/auth')

  return auth ? <div>{auth.username}</div> : <div>Not authorized</div>
}

Add startWith to params to provide a starting value and avoid suspense. This param is omitted from other params passed to io.

import {useIO} from 'react-io'

export default function Widget() {
  const auth = useIO('/auth', {startWith: undefined})

  return auth === undefined ? (
    <div>...loading...</div>
  ) : auth ? (
    <div>{auth.username}</div>
  ) : (
    <div>Not authorized</div>
  )
}

Add returnStateWrapper: true to params to return a state wrapper containing {loading, value, error}, avoiding suspense and throwing errors. This param is omitted from other params passed to io.

import {useIO} from 'react-io'

export default function Widget() {
  const auth = useIO('/auth', {returnStateWrapper: true})

  return auth.loading ? (
    <div>...loading...</div>
  ) : auth.error ? (
    <div>Error: {error.toString()}</div>
  ) : auth.value ? (
    <div>{auth.value.username}</div>
  ) : (
    <div>Not authorized</div>
  )
}

Hooks require that observables are subscribed to optimistically and cached outside of React state. This means there may be cached subscriptions in an orphaned or errored state. The cache (io._cache) can be deleted if needed.

withIO([urls])(WrappedComponent)

Returns a higher-order-component (HOC) that pulls io from context and passes it to the wrapped component as a prop.

Pass it a map of urls or a mapper to turn props into a map of urls and it will add the resolved values to the prop stream.

import {withIO} from 'react-io'

export default withIO({
  auth: '/auth',
})(function Widget({io, auth}) {
  return auth ? <div>{auth.username}</div> : <div>Not authorized</div>
})