Skip to content

Commit

Permalink
feat: undo (#11)
Browse files Browse the repository at this point in the history
* feat: basic undo

selection undo/redo is not implemented yet

* chore: update lockfile

* test: update api

* feat: restore selections when undo/redo
  • Loading branch information
zxch3n authored May 23, 2024
1 parent 56a7625 commit aa4785b
Show file tree
Hide file tree
Showing 15 changed files with 837 additions and 51 deletions.
5 changes: 4 additions & 1 deletion examples/stories/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,12 @@
"build-storybook": "storybook build"
},
"dependencies": {
"loro-crdt": "^0.15.0",
"loro-crdt": "^0.16.2",
"loro-prosemirror": "link:../..",
"prosemirror-commands": "^1.5.2",
"prosemirror-example-setup": "^1.2.2",
"prosemirror-keymap": "^1.2.2",
"prosemirror-menu": "^1.2.4",
"prosemirror-model": "^1.20.0",
"prosemirror-schema-basic": "^1.2.2",
"prosemirror-schema-list": "^1.3.0",
Expand Down
23 changes: 16 additions & 7 deletions examples/stories/pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 10 additions & 3 deletions examples/stories/src/stories/Editor.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@

import type { Meta, StoryObj } from '@storybook/react';
import type { Meta } from '@storybook/react';

import { Editor } from './Editor';
import { Loro } from 'loro-crdt';
Expand All @@ -16,9 +16,16 @@ const meta = {
} satisfies Meta<typeof Editor>;

export default meta;
type Story = StoryObj<typeof meta>;

export const Basic: Story = {};
export const Basic = () => {
const loroARef = useRef<Loro>(createLoro());
const idA = loroARef.current.peerIdStr;
const awarenessA = useRef<CursorAwareness>(new CursorAwareness(idA));
return <div>
<Editor loro={loroARef.current} awareness={awarenessA.current} />
</div>

};

function createLoro() {
const doc = new Loro();
Expand Down
23 changes: 20 additions & 3 deletions examples/stories/src/stories/Editor.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { EditorState } from "prosemirror-state";
import { EditorView } from "prosemirror-view";
import { keymap } from "prosemirror-keymap";
import { DOMParser, Schema } from "prosemirror-model";
import { schema } from "prosemirror-schema-basic";
import { addListNodes } from "prosemirror-schema-list";
Expand All @@ -9,9 +10,13 @@ import {
CursorAwareness,
LoroCursorPlugin,
LoroSyncPlugin,
LoroUndoPlugin,
undo,
redo,
} from "loro-prosemirror";
import "./Editor.css";
import { Loro } from "loro-crdt";
import { buildMenuItems } from "./menu";

const mySchema = new Schema({
nodes: addListNodes(schema.spec.nodes, "paragraph block*", "block"),
Expand All @@ -20,7 +25,8 @@ const mySchema = new Schema({

const doc = DOMParser.fromSchema(mySchema).parse(document.createElement("div"));

const plugins = exampleSetup({ schema: mySchema });
/* eslint-disable */
const plugins = exampleSetup({ schema: mySchema, history: false, menuContent: buildMenuItems(mySchema).fullMenu as any });

export function Editor({
loro,
Expand All @@ -47,7 +53,16 @@ export function Editor({
onCreateLoro?.(loroRef.current);
}

const all = [...plugins, LoroSyncPlugin({ doc: loroRef.current! })];
const all = [
...plugins,
LoroSyncPlugin({ doc: loroRef.current! }),
LoroUndoPlugin({ doc: loroRef.current! }),
keymap({
"Mod-z": state => undo(state, () => {}),
"Mod-y": state => redo(state, () => {}),
"Mod-Shift-z": state => redo(state, () => {}),
}),
];
if (awareness) {
all.push(LoroCursorPlugin(awareness, {}));
}
Expand All @@ -56,5 +71,7 @@ export function Editor({
});
}, [awareness, onCreateLoro]);

return <div id="editor" style={{ minHeight: 200, margin: 16 }} ref={editorDom} />;
return (
<div id="editor" style={{ minHeight: 200, margin: 16 }} ref={editorDom} />
);
}
Loading

0 comments on commit aa4785b

Please sign in to comment.