
Security News
TypeScript is Porting Its Compiler to Go for 10x Faster Builds
TypeScript is porting its compiler to Go, delivering 10x faster builds, lower memory usage, and improved editor performance for a smoother developer experience.
@cerebral/react
Advanced tools
React view for Cerebral.
npm install @cerebral/react react react-dom @babel/preset-react
import React from 'react'
import { render } from 'react-dom'
import App from 'cerebral'
import { Container } from '@cerebral/react'
import AppComponent from './components/App'
import main from './main'
const app = App(main)
render(
<Container app={app}>
<AppComponent />
</Container>,
document.querySelector('#app')
)
Typically you add a stateless component:
import React from 'react'
import { state, sequences } from 'cerebral'
import { connect } from '@cerebral/react'
export default connect(
{
foo: state`foo`,
onClick: sequences`onClick`
},
function MyComponent({ foo, onClick }) {
return <div onClick={() => onClick()}>{foo}</div>
}
)
But you can also use stateful components:
import React from 'react'
import { state, sequences } from 'cerebral'
import { connect } from '@cerebral/react'
export default connect(
{
foo: state`foo`,
onClick: sequences`onClick`
},
class MyComponent extends React.Component {
render() {
return <div onClick={() => this.props.onClick()}>{this.props.foo}</div>
}
}
)
You do not have to define dependencies right away, you can rather dynamically grab them from inside the component. This is a preference thing:
import React from 'react'
import { state, sequences } from 'cerebral'
import { connect } from '@cerebral/react'
export default connect(
function MyComponent({ get }) {
const foo = get(state`foo`)
const onClick = get(sequences`onClick`)
return <div onClick={() => onClick()}>{foo}</div>
}
)
You can add an additional function to connect that gives you full control of properties of the component and dependencies. The returned object from this function will be the exact props passed into the component.
import React from 'react'
import { sequences, state } from 'cerebral'
import { connect } from '@cerebral/react'
export default connect(
{
foo: state`app.foo`,
onClick: sequences`app.onClick`
},
({ foo, onClick }, ownProps, get) => {
return {
// values from state could be transformed here
foo: `Label: ${foo}`,
// sequence calls could be bound here, so component uses it as general callback
onClick: (e) => onClick({ id: ownProps.id })
}
},
function App({ foo, onClick }) {
return <div onClick={onClick}>{foo}</div>
}
)
dependencyProps are the props you connected.
ownProps are the props passed into the component by the parent.
get allows you to resolve computed etc., just like get in actions.
If you use TypeScript, you can type your component props with connect. Read the advanced section on how to do this.
FAQs
React view for Cerebral
The npm package @cerebral/react receives a total of 1,551 weekly downloads. As such, @cerebral/react popularity was classified as popular.
We found that @cerebral/react demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
TypeScript is porting its compiler to Go, delivering 10x faster builds, lower memory usage, and improved editor performance for a smoother developer experience.
Research
Security News
The Socket Research Team has discovered six new malicious npm packages linked to North Korea’s Lazarus Group, designed to steal credentials and deploy backdoors.
Security News
Socket CEO Feross Aboukhadijeh discusses the open web, open source security, and how Socket tackles software supply chain attacks on The Pair Program podcast.