Skip to content

Latest commit

 

History

History
63 lines (40 loc) · 1.38 KB

README.md

File metadata and controls

63 lines (40 loc) · 1.38 KB

peer-crdt-bind-codemirror

Binds a Codemirror editor and peer-crdt.

Install

$ npm install peer-crdt-bind-codemirror

Example

const Codemirror = require('codemirror')
const bind = require('peer-crdt-bind-codemirror')
const crdt = ...
const cursorCrdt = ...
const editor = Codemirror.fromTextArea(document.getElementById('codemirror'))

// bind editor to an array CRDT
const unbind = bind.editor(crdt, editor)

// bind cursors to a register CRDT
const unbindCursors = bind.cursors(cursorCrdt, editor)

// some time later ...

unbind()
unbindCursors()

API

bind (crdt, editor [, options])

Returns an unbind function.

Arguments:

  • crdt: must be a CRDT of type treedoc
  • editor: an instance of Codemirror
  • options: optional object with the following shape:
    • debounceMS: how long (in miliseconds) after the last edit should the CRDT be updated. Default is 2000.

bind.cursors (crdt, editor)

Returns an unbind function.

Arguments:

  • ipfs: IPFS node
  • crdt: must be a CRDT of type mv-register
  • editor: an instance of Codemirror
  • options: optional object with the following shape:
    • debounceMS: how long (in miliseconds) after the cursor position changed should the CRDT be updated. Default is 2000.

See example.

License

MIT