5.0.7-pre.91 • Published 4 years ago

@jetbrains/kotlin-react-redux v5.0.7-pre.91

Weekly downloads
-
License
Apache-2-0
Repository
github
Last release
4 years ago

kotlin-react-redux

Kotlin wrapper for React Redux library. Major version number of this wrapper matches that of React Redux itself.

Installation

  1. npm i @jetbrains/kotlin-react-redux

  2. npm run gen-idea-libs

See the Bintray page for Maven and Gradle installation instructions.

Usage

Using the provider is just like in JavaScript:

provider(store) {
    app()
}

However, you may want to use rConnect to connect your components, because it allows you to use type-safe builders instead of returning props objects. If you would like to just use connect as usual, you can do that too:

val connectedComponent: RClass<ConnectedComponentProps> =
    rConnect<State, RAction, WrapperAction, ConnectedComponentProps, StateProps, DispatchProps, WrappedComponentProps>(
        { state, props ->
            prop1 = state.prop1
            // ...
        }, { dispatch, props ->
        eventHandler1 = { dispatch(SomeAction()) }
        // ...
    }
    )(WrappedComponent::class.rClass)

// ...

class ParentComponent : RComponent {
    override fun RBuilder.render() {
        connectedComponent {}
    }
}

rConnect Type Parameters

interface WrappedComponentProps : RProps {
    var prop1: Int?
    var eventHandler1: (someValue: Int?) -> Unit
}

internal interface StateProps : RProps {
    var prop1: Int?
}

internal interface DispatchProps : RProps {
    var eventHandler1: (someValue: Int?) -> Unit
}

class WrappedComponent(props: WrappedComponentProps) : RComponent<WrappedComponentProps, RState>(props) {
    // ...
}

private val mapStateToProps: StateProps.(AppState, WrappedComponentProps) -> Unit = { state, props ->
    prop1 = state.prop1
}

private val mapDispatchToProps: DispatchProps.((RAction) -> WrapperAction, WrappedComponentProps) -> Unit = { dispatch, props ->
    eventHandler1 = { dispatch(SomeAction()) }
}

Tutorial

See lawik123/kotlin-poc-frontend-react-redux. This project is an implementation/translation of the react-redux Todo List example project in Kotlin (with the addition of react-router).

5.0.7-pre.91

4 years ago

5.0.7-pre.89

4 years ago

5.0.7-pre.83

5 years ago

5.0.7-pre.82

5 years ago

5.0.7-pre.80

5 years ago

5.0.7-pre.67

5 years ago

5.0.7-pre.61

5 years ago

5.0.7-pre.60

5 years ago

5.0.7-pre.58

6 years ago

5.0.7-pre.56

6 years ago

5.0.7-pre.55

6 years ago

5.0.7-pre.54

6 years ago

5.0.7-pre.53

6 years ago

5.0.7-pre.52

6 years ago

5.0.7-pre.49

6 years ago

5.0.7-pre.48

6 years ago