1
0
mirror of https://github.com/ianstormtaylor/slate.git synced 2025-02-24 17:23:07 +01:00
2016-07-26 12:15:21 -07:00

78 lines
1.6 KiB
JavaScript

import { Editor, Plain } from '../..'
import React from 'react'
import AutoReplaceText from 'slate-auto-replace-text'
import CollapseOnEscape from 'slate-collapse-on-escape'
import SoftBreak from 'slate-soft-break'
/**
* Plugins.
*/
const plugins = [
AutoReplaceText('(c)', '©'),
AutoReplaceText('(r)', '®'),
AutoReplaceText('(tm)', '™'),
CollapseOnEscape(),
SoftBreak()
]
/**
* The plugins example.
*
* @type {Component}
*/
class Plugins extends React.Component {
/**
* Deserialize the initial editor state.
*
* @type {Object}
*/
state = {
state: Plain.deserialize(`This example shows how you can extend Slate with plugins! It uses three fairly simple plugins, but you can use any plugins you want, or write your own!
The first is an "auto replacer". Try typing "(c)" and you'll see it turn into a copyright symbol automatically!
The second is a simple plugin to collapse the selection whenever the escape key is pressed. Try selecting some text and pressing escape.
And the third is another simple plugin that inserts a "soft" break when enter is pressed instead of creating a new block. Try pressing enter!`)
};
/**
* On change.
*
* @param {State} state
*/
onChange = (state) => {
this.setState({ state })
}
/**
* Render the editor.
*
* @return {Component} component
*/
render = () => {
return (
<Editor
placeholder={'Enter some text...'}
plugins={plugins}
state={this.state.state}
onChange={this.onChange}
/>
)
}
}
/**
* Export.
*/
export default Plugins