Skip to content

chungchi300/redux-api-middleware-addon

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Features

  1. Predictable and Ready-to-go api reducer to handle common network result for Rest API ,E.g Domain,Network,Api Reducer
  2. Support swagger.json,documentation as code
  3. Support file upload

Installation

npm install redux-api-middleware-addon --save

Example

Swagger definitions

https://github.com/chungchi300/redux-api-middleware-addon/blob/master/src/common/swagger.js

Code Usage

import SWAGGER from 'swagger.js';

store.dispatch(Action.setProtocol('https'));

store.dispatch(Action.setSwagger(SWAGGER));
store.dispatch(
  Action.setHeaders({
    // 'X-Token': 'base64TokenForApiCall',
    Accept: 'application/json',
    ['Content-Type']: 'application/json',
  })
);
store
  .dispatch(
    Action.request(
      '/pet/findByStatus',
      {
        method: 'get',
        data: { status: 'available' },
        subst: null,
      },
      BASIC
    )
  )
  .then(res => console.log(res));
store
  .dispatch(
    Action.request(
      '/pet',
      {
        method: 'post',
        data: {
          name: 'ronald',
          id: 3,
          photoUrls: [
            'https://upload.wikimedia.org/wikipedia/commons/thumb/2/26/Letter_d.svg/1200px-Letter_d.svg.png',
          ],
        },
      },
      BASIC
    )
  )
  .then(res => console.log(res));
store
  .dispatch(
    Action.request(
      '/pet/findByStatus',
      {
        method: 'get',
        data: { status: 'available' },
        subst: null,
      },
      entity('PETS_BY_ID')
    )
  )
  .then(res => console.log(res));

Result

Result

Components

Action

  1. SET_SWAGGER
  2. Request
  3. SET_HEADER(default empty)
  4. SET_PROTOCOL(default http)

helpers

  1. Generate Basic types
  2. Generate Get Entity types

//TODO Generate update,delete,create which help network reducer record which api has api result that failed

Reducer

  1. network (reducer,where is network result located)
  2. domain (reducer,where is CRUD resource result located)
  3. api (reducer,where is the api located)

About

No description or website provided.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published