react-rxjs-provider

0.1.3 • Public • Published

react-rxjs-provider

NPM

Examples:

Example based on create-react-app

API:

react-rxjs-provider providers <Provider />, which makes observables available to the rest of your app:

import React from 'react';
import ReactDOM from 'react-dom';
 
import { Provider } from 'react-rxjs-provider';
import { todos$, TODOS_OBSERVABLE_KEY } from '../observables/todos';
 
import App from './App';
 
const observables = {
    [TODOS_OBSERVABLE_KEY]: todos$
};
 
ReactDOM.render(
  <Provider {...observables}>
    <App />
  </Provider>,
  document.getElementById('root')
);

react-rxjs-provider providers @subscribe() HOC to subscribe your component to observables:

import React from 'react';
import { subscribe } from 'react-rxjs-provider';
 
import { TODOS_OBSERVABLE_KEY } from '../observables/todos';
 
const Todos = props => (
    <ul>
        {props.values[TODOS_OBSERVABLE_KEY].map((todo, key) => <li key={key}>{todo}</li>)}
    </ul>
);
 
export default subscribe(TODOS_OBSERVABLE_KEY)(Todos);

react-rxjs-provider providers @inject() HOC to inject observables in your component:

import React from 'react';
import { inject } from 'react-rxjs-provider';
 
import { TODOS_OBSERVABLE_KEY } from '../observables/todos';
 
class AddTodo extends React.Component {
    addTodo = () => {
        // ...
        this.props.observables[TODOS_OBSERVABLE_KEY].next(
            // ...
        );
        // ...
    };
 
    render() {
        return (
            <form onSubmit={this.addTodo}>
                <input type="text"/>
                <button type="submit">Add Todo</button>
            </form>
        )
    }
}
 
export default inject(TODOS_OBSERVABLE_KEY)(AddTodo);

Readme

Keywords

Package Sidebar

Install

npm i react-rxjs-provider

Weekly Downloads

1

Version

0.1.3

License

MIT

Unpacked Size

228 kB

Total Files

11

Last publish

Collaborators

  • a.zahorovskyi