mirror of
https://github.com/ianstormtaylor/slate.git
synced 2025-02-23 16:55:23 +01:00
34 lines
841 B
JavaScript
34 lines
841 B
JavaScript
import React, { useState, useMemo } from 'react'
|
|
import { createEditor } from 'slate'
|
|
import { Slate, Editable, withReact } from 'slate-react'
|
|
import { withHistory } from 'slate-history'
|
|
|
|
const PlainTextExample = () => {
|
|
const [value, setValue] = useState(initialValue)
|
|
const [selection, setSelection] = useState(null)
|
|
const editor = useMemo(() => withHistory(withReact(createEditor())), [])
|
|
return (
|
|
<Slate
|
|
editor={editor}
|
|
value={value}
|
|
selection={selection}
|
|
onChange={(value, selection) => {
|
|
setValue(value)
|
|
setSelection(selection)
|
|
}}
|
|
>
|
|
<Editable placeholder="Enter some plain text..." />
|
|
</Slate>
|
|
)
|
|
}
|
|
|
|
const initialValue = [
|
|
{
|
|
children: [
|
|
{ text: 'This is editable plain text, just like a <textarea>!' },
|
|
],
|
|
},
|
|
]
|
|
|
|
export default PlainTextExample
|