The initial value of the Editable in both edit & preview mode
Editable
EditableText is used for inline renaming of some text. It appears as normal UI text but transforms into a text input field when the user clicks or focuses on it.
Import#
Chakra UI exports 3 components to handle this functionality.
Editable
: The wrapper component that provides context value.EditableInput
: The edit view of the component. It shows when you click or focus on the text.EditableTextarea
: Use the textarea element to handle multi line text input in an editable context.EditablePreview
: The read-only view of the component.
import {Editable,EditableInput,EditableTextarea,EditablePreview,} from '@chakra-ui/react'
Usage#
The editable's text input and preview inherits all font styling from the root
Editable
container in order to make the edit and read view transition
seamless.
// Click the text to edit<Editable defaultValue='Take some chakra'><EditablePreview /><EditableInput /></Editable>
Usage with textarea#
// Click the text to edit<Editable defaultValue='Take some chakra'><EditablePreview /><EditableTextarea /></Editable>
With custom input and controls#
In some cases, you might need to use custom controls to toggle the edit and read
mode. We use the render prop pattern to provide access to the internal state of
the component. You may want to customize the EditableInput
as well. This can
be achieved by using a custom Input
component in the as
prop.
function CustomControlsExample() {/* Here's a custom control */function EditableControls() {const {isEditing,getSubmitButtonProps,getCancelButtonProps,getEditButtonProps,} = useEditableControls()return isEditing ? (<ButtonGroup justifyContent='center' size='sm'><IconButton icon={<CheckIcon />} {...getSubmitButtonProps()} /><IconButton icon={<CloseIcon />} {...getCancelButtonProps()} /></ButtonGroup>) : (<Flex justifyContent='center'><IconButton size='sm' icon={<EditIcon />} {...getEditButtonProps()} /></Flex>)}return (<EditabletextAlign='center'defaultValue='Rasengan ⚡️'fontSize='2xl'isPreviewFocusable={false}><EditablePreview />{/* Here is the custom input */}<Input as={EditableInput} /><EditableControls /></Editable>)}
Styling the editable#
Please see the recipe for a styled example.
Props#
Editable Props#
defaultValue
defaultValue
string
finalFocusRef
finalFocusRef
The ref
of element to receive focus when the modal closes.
RefObject<FocusableElement>
isDisabled
isDisabled
If true
, the Editable will be disabled.
boolean
isPreviewFocusable
isPreviewFocusable
If true
, the read only view, has a tabIndex
set to 0
so it can receive focus via the keyboard or click.
boolean
true
onBlur
onBlur
Callback invoked when the user either submits or cancels. It provides the last confirmed value as argument.
(nextValue: string) => void
onCancel
onCancel
Callback invoked when user cancels input with the Esc
key.
It provides the last confirmed value as argument.
(previousValue: string) => void
onChange
onChange
Callback invoked when user changes input.
(nextValue: string) => void
onEdit
onEdit
Callback invoked once the user enters edit mode.
() => void
onSubmit
onSubmit
Callback invoked when user confirms value with enter
key or by blurring input.
(nextValue: string) => void
placeholder
placeholder
The placeholder text when the value is empty.
string
selectAllOnFocus
selectAllOnFocus
If true
, the input's text will be highlighted on focus.
boolean
true
startWithEditView
startWithEditView
If true
, the Editable will start with edit mode by default.
boolean
submitOnBlur
submitOnBlur
If true
, it'll update the value onBlur and turn off the edit mode.
boolean
true
value
value
The value of the Editable in both edit & preview mode
string