Skip to content

Astroner/react-injectable

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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)
    }

}

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published