npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

pouchdb-redux-helper

v0.11.0

Published

Helpers for working with PouchDB in React with Redux store.

Downloads

20

Readme

pouchdb-redux-helper

Helpers for working with PouchDB in React with Redux store.

build status npm version

pouchdb-redux-helper consists of:

  • createCRUD function for creating reducers, actionTypes, actions and route paths.

  • helper functions for connecting components with store

pouchdb-redux-helpers uses and depends on:

  • immutablejs for storing data

  • redux-thunk for handling actions

poouchdb-redux-helper is currently considered experimental software.

Installation

$ npm install pouchdb-redux-helper --save

Usage

Create CRUD

createCRUD(db, mountPoint, [prefix=null], [opts={}])

This function return reducer and redux helpers for given resource type in given database.

Options

  • db: PouchDB database

  • mountPoint: unique name of CRUD that defines where it will be mounted in state as well to give action types unique prefix

  • prefix: prefix to use for document id for creating new object and in allDocs. Equal to mountPoint if not specified.

  • opts: options

    • startkey - startkey for this crud, default mountPoint-
    • endkey - endkey for this crud, default mountPoint-\uffff

Returns

It returns object consisting of:

  • actions

    • actions.allDocs(folder='', params, opts)
    • actions.query(fun, folder='', params, opts)
    • actions.get(docId, params, opts)
    • actions.put(doc, params, opts)
    • actions.remove(doc, params, opts)

    Options for actions:

    • fun: query function
    • folder: folder where to save document ids
    • params: params to delegate to pouchdb service method
    • opts: additional options to add to action
    • doc: document
    • docId: document id
  • actionTypes

    action types for actions above (allDocs, query, get, put, remove)

  • reducer

    Reducer for given CRUD. It is immutable.Map object with:

    • documents: currently loaded documents, a map of docId: doc structure
    • folders is a map of document ids for given database query. It has folderName:[doc1Id, doc2Id,...] structure.
  • mountPoint

    mountPoint from option

  • paths

    paths for crud routes (list, detail, edit, create)

  • urlPrefix

    urlPrefix for using in routes

  • db

    PouchDB database

Example Usage

import thunk from 'redux-thunk';
import { createCRUD } from 'pouchdb-redux-helper';
//...
const db = PouchDB('testdb');
// get CRUD 
const projectsCrud = createCRUD(db, 'projects');
// reducers
const reducers = combineReducers({
  [projectsCrud.mountPoint]: projectsCrud.reducer,
});
// create store
const finalCreateStore = compose(
  applyMiddleware(...[thunk]),
)(createStore);
const store = finalCreateStore(reducers);
// allDocs action

Example of calling allDocs action of projectsCrud.

store.dispatch(projectsCrud.actions.allDocs('all'));

When previous example is executed, following will happen:

  1. thunk will dispatch POUCHDB_projects_allDocs_request action and execute PouchDB allDocs as promise.

  2. If promise resolves

2.1. thunk will dispatch POUCHDB_projects_allDocs_success action with result

2.2. store will merge received documents with existing state in state.projects.documents and update document ids in state.projects.folders.all List.

  1. If error occurs POUCHDB_projects_allDocs_failure action will be dispatched with error

Connect containers helper functions

connectList

Decorator connects wrapped Component with documents from the state as property. Query options can be passed to PouchDB, such as query function, startkey, endkey, etc. If state does not already contains folder with documents, they are loaded.

connectList(crud, opts={}, mapStateToProps, mapDispatchToProps)
Options
  • crud: crud obtained from createCRUD
  • opts:
    • opts.options: options to pass to PouchDB. If options.fun is given, query will be executed, otherwise allDocs which starts with mountPoint-
    • opts.folder: folder where to save result. If empty this is serialized from opts.options
    • propName="items": name of property to pass to wrapped component
  • mapStateToProps: custom mapStateToProps to delegate to connect
  • mapDispatchToProps: mapDispatchToProps to delegate to connect
Example usage
const ProjectList = ({isLoading, items}) => {(
  if (isLoading) {
    return <div>loading...</div>
  }
  return (<ul>
    { items.map(item => <li key={item.get('_id')}>item.get('name')</li>) }
  </ul>)
)};

// connected component contains all documents
export const ProjectListContainer = containers.connectList(
  projectsCrud, {folder: 'all'}
)(ProjectList);

// connected component contains only starred projects
// it assumes view named 'starredProjects' exists in design documents
export const StarredProjectListContainer = containers.connectList(
  projectsCrud, {fun: 'starredProjects'}
)(ProjectList);

connectSingleItem

Decorator connects wrapped Component with single document. docId would be resolved from:

  • component own property,
  • mapStateToProps function if it returns detailOpt,
  • opts argument
Example usage
export const ProjectDetail = ({isLoading, item, dispatch, onRemove}) => {
  if (isLoading) {
    return <div>loading...</div>
  }
  return (
    <span>{ item.get('name') }</span>
  )
}

// connected component with own property, ie:
// <ProjectDetailContainer docId="project-1" />
export const ProjectDetailContainer = containers.connectSingleItem(
  projectsCrud, {}
)(ProjectDetail);


// connected component with docId from router
// <ProjectDetailContainer />
export const ProjectDetailContainerFromUrl = containers.connectSingleItem(
  projectsCrud, {}, state => ({
    singleItemOpts: {docId: state.router.params.id},
  })
)(ProjectDetail);
Options
  • crud: crud obtained from createCRUD
  • opts:
    • propName="items": name of property to pass to wrapped component
Properties
  • docId: document id
Example usage
const ProjectDetail = ({items, dispatch}) => (
  <div>{ item.get('name') }</div>
);

// displays project with docId from url id param
const ProjectDetailContainer = connect(state => ({ docId: state.router.params.id }))(
  containers.connectSingleItem(projectsCrud)(ProjectDetail)
)

Routes creating helper

Use crud.paths

const routes = (
  <Route path="/" component={App}>
    <Route path={projectsCrud.paths.list} component={AllProjectListContainer} />
  </Route>
);

Pagination

Decorator connects and paginate wrapped Component.

paginate(paginationOpts, crud, connectListOpts, mapStateToProps, mapDispatchToProps)

Options

  • paginationOpts:
    • paginationOpts.rowsPerPage: rows per page
    • paginationOpts.startkey: startkey

Other options are equal to those in connectList.

Example app

Example app

Example app source code

TODO:

  • upgrade babel to 6.x

Changelog

  • 0.11.0 (unreleased)
    • refactor connectSingleItem to allow setting opts from mapStateToProps
  • 0.10.0
    • refactor loading decorator to always render passed component with isLoading property instead of using custom Loading component
    • loading component triggers load in componentWillReceiveProps
    • loading component expect action as function and actionArgs as function arguments.
    • bugfixes
  • 0.9.0
    • fixes in pagination
  • 0.8.0
    • save extra things received from query/allDocs in folderVars. This includes total_rows, offset, skip.
    • remove queryFunc introduced in 0.7.0
    • pagination suport
    • pass additional opts in query and allDocs actions and save them in folder as folderVars
  • 0.7.0
    • add queryFunc option to containers.connectList options
  • 0.6.0
    • use redux-thunk instead of custom middleware and service
    • remove service, middleware modules
    • remove actions in favor of createPromiseAction

License

MIT