This package provides an ActionCable context provider and consumer to allow you to subscribe to ActionCable channels in your React components.
As this package uses React's new Context API, React 16.3+ is required.
Run npx browserslist
to see default option in .browserslistrc
compatibility. This is so you don't have to transpile this package for IE 11.
npm install --save @thrash-industries/react-actioncable-provider
# OR
yarn add @thrash-industries/react-actioncable-provider
The public API exports two components that you'll use: <ActionCableProvider />
and <ActionCableConsumer />
.
The provider is used in an outer container and wraps all of the components that may or may not consume the context. It accepts one of two props: url
and cable
. Passing url
will result in the provider instantiating its own ActionCable.Consumer
with that URL. Passing cable
allows you to manually instantiate an ActionCable.Consumer
on your own and pass it to the provider to be used by all descendent consumers.
<ActionCableProvider url="ws://test.example.com/cable">...</ActionCableProvider>
import ActionCable from "actioncable";
const cable = ActionCable.createConsumer("ws://test.example.com/cable");
<ActionCableProvider cable={cable}>...</ActionCableProvider>;
The consumer will wrap an individual component. It accepts several props:
channel
[String] Name of the channel to which you want to subscribe.channel
[Object] An object with achannel
key which denotes the channel to which you want to subscribe. All other keys are passed to the channel as params.onConnected
[Function] A handler function that is called when the channel connects.onDisconnected
[Function] A handler function that is called when the channel disconnects.onInitialized
[Function] A handler function that is called when theActionCable
.Consumer
is initialized.onRejected
[Function] A handler function that is called when the requested subscription is rejected.onReceived
[Function] A handler function that is called when the channel transmits a message to the client.
import React from "react";
import PropTypes from "prop-types";
import { ActionCableConsumer } from "@thrash-industries/react-actioncable-provider";
export default class Widget extends React.Component {
static propTypes = {
message: PropTypes.string
};
constructor(...props) {
super(...props);
this.handleReceived = this.handleReceived.bind(this);
this.state = {
message: ""
};
}
handleReceived(message) {
this.setState(state => {
return {
message
};
});
}
render() {
return (
<ActionCableConsumer
channel="WidgetChannel"
onReceived={this.handleReceived}
>
<h1>{this.state.message}</h1>
</ActionCableConsumer>
);
}
}
See https://github.com/cpunion/react-native-actioncable
See cpunion#8
Example: https://github.com/cpunion/react-actioncable-ssr-example