@skokenes/slate-yjs
Version:
Yjs bindings for Slate.
84 lines (54 loc) • 3.09 kB
Markdown
# Slate Yjs - [Live Demo](https://bitphinix.github.io/slate-yjs-example)
[](https://codecov.io/gh/BitPhinix/slate-yjs)
[](https://github.com/BitPhinix/slate-yjs/graphs/commit-activity)
[](http://commitizen.github.io/cz-cli/)
[](https://www.npmjs.com/package/slate-yjs)
[](https://www.npmjs.com/package/slate-yjs)
[](https://github.com/BitPhinix/slate-yjs/actions)
[](https://github.com/BitPhinix/slate-yjs/actions?query=workflow%3Arelease)
Yjs bindings for Slate.
Heavily inspired by [slate-collaborative](https://github.com/cudr/slate-collaborative)

# Installation
Via npm:
```bash
npm install slate-yjs
```
Via yarn:
```bash
yarn add slate-yjs
```
# Why use `slate-yjs` over `slate-collaborative`?
Performance. `slate-collaborative` works well for small documents but can cause 20 seconds + load times on heavier ones which slate-yjs can load in a fraction of a second.
For a more in-depth comparison take a look at these [benchmarks](https://github.com/dmonad/crdt-benchmarks)
You might also want to take a look at ["CRDTs are the future"](https://josephg.com/blog/crdts-are-the-future/) from the creator of [sharedb](https://github.com/share/sharedb)
# API
## YjsEditor
Adding a 2-way binding from the editor to a Yjs document is as easy as:
```ts
import { withYjs, SyncElement } from 'slate-yjs';
import * as Y from 'yjs';
const doc = new Y.Doc();
const sharedType = doc.getArray<SyncElement>('content');
const yjsEditor = withYjs(editor, sharedType);
```
## Cursors
Slate-yjs support syncing collaborative cursors using awareness:
```ts
import { withCursor, useCursors } from 'slate-yjs';
// Adds (and syncs) cursor information (anchor, focus) to the awareness local state.
const cursorEditor = withCursor(yjsEditor, provider.awareness);
// Returns a decorator that annotates text nodes with cursor information and
// a array containing all cursor information.
const { decorate, cursors } = useCursors(cursorEditor);
```
## Example project
Take a look at the example project [here](https://github.com/BitPhinix/slate-yjs-example)
# Contribute
Please refer to each project's style and contribution guidelines for submitting patches and additions. In general, we follow the "fork-and-pull" Git workflow.
1. Fork the repo on GitHub
2. Clone the project to your machine
3. Commit changes to your branch
4. Push your work back up to your fork
5. Submit a Pull request so that we can review your changes
NOTE: Be sure to merge the latest from "upstream" before making a pull request!