React hook used to allow component to be controlled and uncontrolled modes, and provide control over it's internal state.
Most Chakra components utilize useControllableState
for seamlessly managing
regardless of whether it's controlled or uncontrolled.
The useControllableState
hook returns the state and function that updates the
state, just like React.useState
does.
Using this hook gives let's you use the initial state by default with an option
to control the state via control props (using value
).
Here's an example of an uncontrolled state.
Here's an example of an controlled state.
This hook provides helpful error or warning messages when you switch between
controlled or uncontrolled modes or when you attempt to update the
defaultValue
passed.
Name | Type | Description |
---|---|---|
value | any | The value to used in controlled mode |
defaultValue | any | The initial value to be used, in uncontrolled mode |
onChange | (nextValue: any) => void | The callback fired when the value changes |
shouldUpdate | (prev: any, next: any) => boolean | The condition to update the state |
name | string | The component name this hook is used in |
propsMap | object | A mapping for the props to give more contextual warning messages. |