0.1.3 • Published 5 years ago

react-rxjs-provider v0.1.3

Weekly downloads
2
License
MIT
Repository
github
Last release
5 years ago

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);
0.1.3

5 years ago

0.1.2

6 years ago

0.1.1

6 years ago

0.1.0

6 years ago