Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

redux-supermodel

Package Overview
Dependencies
Maintainers
1
Versions
27
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

redux-supermodel

A package of action creator functions and reducers that deal with the state management of REST-like APIs for you... all you need is a URL!

  • 0.14.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
decreased by-100%
Maintainers
1
Weekly downloads
 
Created
Source

redux-supermodel

Codacy Badge Build Status dependencies Status devDependencies Status

Streamline the effort it takes for you to communicate between your Redux Store and a REST-like API. This is a package of action creator functions and reducers built with axios and redux-promise-middleware that handle the resource state management for you... all you need is a URL!

Check out the demo

API Reference

Creating the Client

Clients encapsulate the API you are consuming. You can create a new client by providing the base URL for the API.

import { createClient } from 'redux-supermodel'

const client = createClient('https://example.com/api/v1')

Creating Resources

Within your client, you can start defining resources. Each Resource represents an endpoint that you can interact with.

// The full URL will be https://example.com/api/v1/blogs
const blogs = client('blogs')

// https://example.com/api/v1/comments
const comments = client('comments')

Attaching your Resource's props to your Component

Start with your resource definition, let's pretend http://example.com/api/posts/latest will return a JSON object with properties title and body.

// resources.js

import { createClient } from 'redux-supermodel'

const client = createClient('http://example.com/api')

// GET http://example.com/api/posts/latest
//
// { title: 'My latest blog post', body: 'Hello, world!' }
export const post = client('post', { url: 'posts/latest' }) 

The easiest way to use redux-supermodel is with the bindResource higher-order component which will automatically fetch the resource when the component mounts, reset it when the component unmounts, and binds the resource's props and action creators to the component's props.

// MyComponent.js

import React from 'react'
import { bindResource } from 'redux-supermodel'
import { post } from './resources'

function MyComponent ({ready, error, title, body, fetchPost}) {
  if (!ready) return <div className="loading">Loading...</div> 
  if (error) return <div className="error">{error}</div>

  return (
    <div>
      <h1>{title}</h1>
      <div className="body">
        {body}
      </div>
      <button type="button" onClick={() => fetchPost()}>Refresh</button>
    </div>
  )
}

export function mergeProps (stateProps, dispatchProps, ownProps) {
  const { 
    ready, 
    error, 
    payload
  } = stateProps.post

  const err = error && error.response && error.response.data
  const data = payload && payload.data

  // The stateProps parameter can get rather large and have lots of unwieldy data structures,
  // use mergeProps as an opportunity to be a bit selective and only return the stateProps
  // values that you are going to use in your component.
  //
  // The same advice also applies to dispatchProps and ownProps, to a lesser extent, its not as
  // important to do so in those cases because A) you will already be defining ownProps 
  // somewhere else in your app and B) the `bindResource` higher-order component will dispatch
  // some callbacks on your behalf (by default `fetchAll()` on mount and `resetAll()` on unmount)
  return { 
    ...ownProps, 
    ...dispatchProps, 
    ready, 
    error: err && err.message, 
    title: data && data.title, 
    body: data && data.body 
  }
}

const resources = { post }
export default bindResource(resources, { mergeProps })(MyComponent)

The advice offered by this blog post is about mapStateToProps, but it applies to how we are using mergeProps here.

For details on mergeProps, read the react-redux connect() documentation.

For the full list of options, see bindResource.

Installation

npm install --save redux-supermodel redux-promise-middleware

You will need to add the redux-promise-middleware middleware and the redux-supermodel reducer to your Redux Store.

// store.js

import { createStore, applyMiddleware, compose, combineReducers } from 'redux'
import promiseMiddleware from 'redux-promise-middleware'
import { reducer as resource } from 'redux-supermodel'

const rootReducer = combineReducers({ resource })
export default compose(applyMiddleware(promiseMiddleware()))(createStore)(rootReducer)

API Reference

Keywords

FAQs

Package last updated on 09 Aug 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc