@vnetwork/richtext-editor
Version: 
react richtext editor, only using for internal purpose
73 lines (64 loc) • 6.41 kB
JavaScript
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;