Newer
Older
import { Plugin, PluginKey } from 'prosemirror-state';
import { Decoration, DecorationSet } from 'prosemirror-view';
const getComment = (state, context) => {
const {
options: { comments },
} = context;
if (!comments?.length) return;
const commentData = comments.filter(comment =>
inRange(state.selection.from, comment.from, comment.to),
);
if (commentData.length > 0) {
if (
state.selection.from !== state.selection.to &&
state.selection.to < last(commentData).to
) {
return {};
}
return last(commentData);
state: {
init: (_, state) => {
},
apply(tr, prev, _, newState) {
let createDecoration;
if (comment) {
createDecoration = DecorationSet.create(newState.doc, [
Decoration.inline(comment.from, comment.to, {
]);
}
return {
comment,
const commentPluginState = state && commentPlugin.getState(state);
return commentPluginState.createDecoration;