Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/giannif/react-storage-context

React - Get and set local and session storage easily using the Context API
https://github.com/giannif/react-storage-context

Last synced: about 2 months ago
JSON representation

React - Get and set local and session storage easily using the Context API

Awesome Lists containing this project

README

        

# react-storage-context

[![NPM](https://img.shields.io/npm/v/react-storage-context.svg)](https://www.npmjs.com/package/react-storage-context) [![JavaScript Style Guide](https://img.shields.io/badge/code_style-standard-brightgreen.svg)](https://standardjs.com)
[![Coverage Status](https://coveralls.io/repos/github/giannif/react-storage-context/badge.svg?branch=master)](https://coveralls.io/github/giannif/react-storage-context?branch=master)

> Get and set local and session storage using the React Context API

## Install

```bash
yarn add react-storage-context
```

## Usage

`StorageContext`

Initializes and manages storage, setting the values of the `StorageContext.Provider`

```jsx
import StorageContext from "react-storage-context"

@StorageContext("your-storage-id")
class App extends PureComponent {
render() {
// children that will read and write storage
}
}
```

`withStorageContext`

Will provide the api as props:

* `local` local storage object
* `session` session storage object
* `setLocal` update local storage object
* `setSession` update session storage object

```jsx
import { withStorageContext } from "react-storage-context"

@withStorageContext
class App extends PureComponent {
render() {
// props to read
const {
local: { someLocalVal },
session
} = this.props
// props to invoke save methods
const { saveLocal, saveSession } = this.props
return

{someLocalVal}

}
}
```

`Consumer`

```jsx
import { Consumer } from "react-storage-context"

class App extends PureComponent {
render() {
// render props
return (
{({ session }) =>

Session storage values: {JSON.stringify(session, undefined, 4)}
}
)
}
}
```

## License

MIT © [giannif](https://github.com/giannif)