Skip to content

YouSee/lightning-jsx-redux

Repository files navigation

Lightning-jsx-redux

This library enables use of jsx syntax with redux connect when developing lightning apps Lightning framework documentation.

Setup

npm install lightning-jsx-redux --save-dev

Add the following to your babelrc config:

{
  "plugins": [
    "lightning-jsx-redux/babel"
  ]
}

Before your lightning app is initiated you will need to provide lightning-jsx-redux library with your redux store.

import { createStore } from "redux";
import { provide } from "lightning-jsx-redux";

export const store = createStore(myReducer);
provide(store);

Here's an example of a connected jsx component:

import { connect } from "lightning-jsx-redux";

const myComponent = (state, actions) => (
  <text
    x={110}
    y={110}
    text={{
      fontSize: 24,
      text: state.myState,
      fontStyle: "bold",
      textColor: 0xff636efb
    }}
    updated={(newState, oldState, self) => {
      // My update logic
      self.patch({
        text: {
          text: newState.myState
        }
      });

      // Dispatch my redux action
      actions.myFunc("someValue");
    }}
    firstActive={(currentState, currentProps, self) =>
      console.log("First time visible")
    }
    active={(currentState, currentProps, self) =>
      console.log("Visible on screen")
    }
    inactive={(currentState, currentProps, self) =>
      console.log("Not visible on screen")
    }
  />
);

export default connect(
  state => ({ myState: state.myState }),
  { myFunc: value => ({ type: "SOME_ACTION", input: value }) }
)(myComponent);

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published