UNPKG

@vnetwork/richtext-editor

Version:

react richtext editor, only using for internal purpose

73 lines (64 loc) 6.41 kB
import _JSXStyle from "styled-jsx/style"; import React from "react"; import pipe from "lodash/fp/pipe"; // import debounce from "lodash/debounce"; import { createEditor } from "slate"; import { Editable, withReact, Slate } from "slate-react"; import { withHistory } from "slate-history"; import { AppProvider } from "./context/app"; import { QueryClient, QueryClientProvider } from "react-query"; // added custom plugins import withLinks from "./plugins/withLinks"; import withTables from "./plugins/withTables"; import withMentions from "./plugins/withMentions"; import withChecklists from "./plugins/withChecklists"; import Toolbar from "./Toolbar"; import Elements from "./Elements"; import Leafs from "./Leafs"; import { MentionModal } from "./Elements/Mention"; // import custom shortcut keyboards // eslint-disable-next-line no-unused-vars import { HandleShortcutKeyboard } from "./Toolbar/MarkButton"; import { resolveSlateMentionMatch } from "./utils/resolveMatchOnChange"; const createEditorWithPlugins = pipe(withHistory, withTables, withLinks, withMentions, withChecklists, withReact); const RichtextEditor = ({ ...props }) => { const [value, setValue] = React.useState(props.value || []); const [mention, setMentionTarget] = React.useState(undefined); const [search, setMentionSearch] = React.useState(""); const [queryClient] = React.useState(() => new QueryClient()); const editor = React.useMemo(() => createEditorWithPlugins(createEditor()), []); const SlateElements = React.useCallback(props => /*#__PURE__*/React.createElement(Elements, props), []); const SlateLeafs = React.useCallback(props => /*#__PURE__*/React.createElement(Leafs, props), []); // eslint-disable-next-line react-hooks/exhaustive-deps // const debounced = React.useCallback( // debounce((range) => setMentionTarget(range), 200), // [] // ); const handleOnChange = value => { setValue(value); const [before, range, after] = resolveSlateMentionMatch(editor); if (before && after) { return [setMentionTarget(range), setMentionSearch(before[1])]; } return [setMentionTarget(undefined)]; }; return /*#__PURE__*/React.createElement(QueryClientProvider, { client: queryClient }, /*#__PURE__*/React.createElement(AppProvider, null, /*#__PURE__*/React.createElement(Slate, { editor: editor, value: value, onChange: handleOnChange }, /*#__PURE__*/React.createElement("div", { className: "jsx-3687908838" + " " + "richtext" }, /*#__PURE__*/React.createElement(Toolbar, null), /*#__PURE__*/React.createElement(Editable, { renderElement: SlateElements, renderLeaf: SlateLeafs, autoFocus: true, onKeyDown: event => HandleShortcutKeyboard(editor, event) })), typeof mention !== "undefined" && /*#__PURE__*/React.createElement(MentionModal, { editor: editor, target: mention, search: search, callback: () => setMentionTarget(undefined) })), /*#__PURE__*/React.createElement(_JSXStyle, { id: "3687908838" }, "input{outline:none;}.hr{height:1.5rem;display:inline-block;margin:0 0.25rem;}.border-bottom{border-bottom:1px solid #dddddd;}i{min-width:1.5rem;height:1.5rem;display:inline-block;background-size:80%;background-position:center;background-repeat:no-repeat;}i.text{background-image:url();}i.linked{background-image:url();}i.bulleted-list{background-image:url();}i.italic{background-image:url();}i.bold{background-image:url();}i.underline{background-image:url();}i.border-all{background-image:url();}i.format-color{background-image:url();}"))); }; export default RichtextEditor;