Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
redux-form-material-ui
Advanced tools
An adapter between Redux Form and Material UI components
redux-form-material-ui
is a set of
wrappers to facilitate the use of
material-uibeta
components with
redux-form
.
Latest version is supported by only for material-ui beta.
Using npm:
$ npm install --save redux-form-material-ui@next
Using npm:
$ yarn add redux-form-material-ui@next
Rather than import your component class from material-ui
, import it from redux-form-material-ui
and then pass the component class directly to the component
prop of Field
.
import { reduxForm, Field } from 'redux-form'
import MenuItem from '@material-ui/core/MenuItem'
import Radio from '@material-ui/core/RadioButton'
import {
Checkbox,
RadioGroup,
Select,
TextField,
Switch,
FormControlLabel,
} from 'redux-form-material-ui'
class MyForm extends Component {
render() {
return (
<form>
<Field name="username" component={TextField} placeholder="Street"/>
<Field name="plan" component={Select} placeholder="Select a plan">
<MenuItem value="monthly">Monthly</MenuItem>
<MenuItem value="yearly">Yearly</MenuItem>
<MenuItem value="lifetime">Lifetime</MenuItem>
</Field>
<FormControlLabel control={<Field name="agreeToTerms" component={Checkbox} /> } label="Agree to terms?" />
<FormControlLabel control={<Field name="receiveEmails" component={Switch} /> } label="Please spam me!" />
<Field name="bestFramework" component={RadioGroup}>
<Radio value="react" label="React"/>
<Radio value="angular" label="Angular"/>
<Radio value="ember" label="Ember"/>
</Field>
</form>
)
}
}
// Decorate with redux-form
MyForm = reduxForm({
form: 'myForm'
})(MyForm)
export default MyForm
Because of the strict "controlled component" nature of redux-form
,
some of the Material UI functionality related to defaulting of values has been disabled
e.g. defaultValue
, defaultDate
, defaultTime
, defaultToggled
, defaultChecked
, etc.
If you need a field to be initialized to a certain state, you should use the initialValues
API of redux-form
.
getRenderedComponent()
Returns a reference to the Material UI component that has been rendered. This is useful for
calling instance methods on the Material UI components. For example, if you wanted to focus on
the username
element when your form mounts, you could do:
componentWillMount() {
this.refs.firstField // the Field
.getRenderedComponent() // on Field, returns ReduxFormMaterialUITextField
.getRenderedComponent() // on ReduxFormMaterialUITextField, returns TextField
.focus() // on TextField
}
as long as you specified a ref
and withRef
on your Field
component.
render() {
return (
<form>
...
<Field name="username" component={TextField} withRef ref="firstField"/>
...
</form>
)
}
FAQs
An adapter between Redux Form and Material UI components
The npm package redux-form-material-ui receives a total of 6,815 weekly downloads. As such, redux-form-material-ui popularity was classified as popular.
We found that redux-form-material-ui demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 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
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.