Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/itsdouges/react-peer

Send data to someone else's browser as easy as setting state
https://github.com/itsdouges/react-peer

javascript p2p peer-to-peer peerjs react react-hooks reactjs typescript web-rtc

Last synced: about 1 month ago
JSON representation

Send data to someone else's browser as easy as setting state

Awesome Lists containing this project

README

        

# react-peer

[![Build Status](https://travis-ci.org/madou/react-peer.svg?branch=master)](https://travis-ci.org/madou/react-peer)
[![npm](https://img.shields.io/npm/v/react-peer.svg)](https://www.npmjs.com/package/react-peer)
[![npm bundle size (minified + gzip)](https://img.shields.io/bundlephobia/minzip/react-peer.svg)](https://bundlephobia.com/result?p=react-peer)
[![Dev Dependencies](https://david-dm.org/madou/react-peer/status.svg)](https://david-dm.org/madou/react-peer)
[![Dev Dependencies](https://david-dm.org/madou/react-peer/peer-status.svg)](https://david-dm.org/madou/react-peer?type=peer)
[![Dev Dependencies](https://david-dm.org/madou/react-peer/dev-status.svg)](https://david-dm.org/madou/react-peer?type=dev)

Using the power of [WebRTC](https://webrtc.org/faq/#what-is-webrtc) and [peerjs](https://peerjs.com/) you can send data to someone else's browser as easy as using setState() ⚛🍐

## Installation

Uses [peerjs](https://peerjs.com/) under the hood.
Requires at least `react@^16.3.0` and `react-dom@^16.3.0`.
Comes with TypeScript types out-of-the-box.

```bash
npm install react-peer react react-dom --save
```

```bash
yarn add react-peer react react-dom
```

## Usage

### `usePeerState(initialState?: TState, opts?: { brokerId?: string }): [TState, Function, string, Peer.DataConnection[], PeerError | undefined];`

**⚠️ Make sure to use `react@^16.8.0` and `react-dom@^16.8.0` if wanting to use hooks. Unsure what hooks are? [Check out their introduction!](https://reactjs.org/docs/hooks-intro.html) ⚠️**

Behaves as your regular [`useState()`](https://reactjs.org/docs/hooks-state.html) hook,
but will **eventually** send data to any connected peers.
Peers can connect to you using the `brokerId` that is **eventually** returned.

`opts.brokerId` is optionally used when you already have a broker id generated.

```js
import { usePeerState } from 'react-peer';

const App = () => {
const [state, setState, brokerId, connections, error] = usePeerState();

setState({ message: 'hello' });
};
```

### `useReceivePeerState(peerBrokerId: string, opts?: { brokerId?: string }): [TState | undefined, boolean, PeerError | undefined];`

**⚠️ Make sure to use `react@^16.8.0` and `react-dom@^16.8.0` if wanting to use hooks. Unsure what hooks are? [Check out their introduction!](https://reactjs.org/docs/hooks-intro.html) ⚠️**

Will receive peer state **eventually** from a peer identified using `peerBrokerId`.

`opts.brokerId` is optionally used when you already have a broker id generated.

```js
import { useReceivePeerState } from 'react-peer';

const App = () => {
const [state, isConnected, error] = useReceivePeerState('swjg3ls4bq000000');
};
```

### ``

Useful if not yet using react hooks.
When setting the value prop it will propagate it to all connected peers.

`brokerId` prop is optionally used when you already have a broker id generated.

```js
import { PeerStateProvider } from 'react-peer';

{({ brokerId, connections, error }) =>

}
;
```

### ``

Useful if not yet using react hooks.
Will receive data from the peer broker.

`brokerId` prop is optionally used when you already have a broker id generated.

```js
import { ReceivePeerState } from 'react-peer';

{({ data, isConnected, error }) =>

}
;
```