Skip to content

Latest commit

 

History

History
64 lines (53 loc) · 1.18 KB

README.md

File metadata and controls

64 lines (53 loc) · 1.18 KB

Injectables (DI/IoC) for React


Includes:
  • Injectable - abstract class for injectable creation
  • useInjector - getter hook for an Injectable
  • InjectableProvider - IoC container/provider
  • OnInit - lifecicle onInit hook

Injectable creation
export class TestService extends Injectable<{ counter: number }> {
    getDefaultState(){
        return {
            counter: 0
        }
    }

    increment(){
        this.setState(prev => ({
            counter: prev.counter + 1
        }))
    }
}
Injectable usage
// initialization

render(
    <InjectableProvider inject={[TestService, SecondService]}>
        <App />
    </InjectableProvider>
)

// react flow usage
const App = () => {

    const [state, counter] = useInjector(TestService)

    return (
        <div onClick={() => counter.increment()}>
            {state.counter}
        </div>
    )
}

// usage in an injectable
class SecondService extends Injectable implements OnInit{
    getDefaultState(){}

    onInit(){
        this.getInjection(TestService)
            .asObservable()
            .pipe(
                take(12)
            )
            .subscribe(console.log)
    }

}