mirror of
				https://github.com/cudr/slate-collaborative.git
				synced 2025-06-13 12:54:04 +00:00 
			
		
		
		
	| src | ||
| .babelrc | ||
| .gitignore | ||
| .prettierrc | ||
| .travis.yml | ||
| changelog-template.hbs | ||
| CHANGELOG.md | ||
| commitlint.config.js | ||
| License.md | ||
| package.json | ||
| README.md | ||
| tsconfig.json | ||
| tslint.json | ||
slate-collaborative. Check demo
slatejs collaborative plugin & microservice
A little experiment for co-editing.
Based on idea of https://github.com/humandx/slate-automerge
API
Client
Use it as a simple slatejs plugin
import { withIOCollaboration } from '@hiveteams/collab-client'
const collaborationEditor = withIOCollaboration(editor, options)
Check detailed example
Options:
{
  docId?: // document id
  url?: string // url to open connection
  connectOpts?: SocketIOClient.ConnectOpts // socket.io-client options
  cursorData?: any // any data passed to cursor
  onConnect?: () => void // connect callback
  onDisconnect?: () => void // disconnect callback
  onError?: (reason: string) => void // error callback
  preserveExternalHistory?: boolean // preserve slate-history operations form other clients
}
You need to attach the useCursor decorator to provide custom cursor data in renderLeaf function
import { useCursor } from '@hiveteams/collab-client'
const decorator = useCursor(editor)
Backend
const { AutomergeCollaboration } = require('backend/index')
const collabBackend = new AutomergeCollaboration(options)
options:
{
  entry: Server // or specify port to start io server
  defaultValue: Node[] // default value
  saveFrequency: number // frequency of onDocumentSave callback execution in ms
  onAuthRequest: ( // auth callback
    query: Object,
    socket?: SocketIO.Socket
  ) => Promise<boolean> | boolean
  onDocumentLoad: ( // request slate document callback
    pathname: string,
    query?: Object
  ) => Promise<Node[]> | Node[]
  onDocumentSave: (pathname: string, doc: Node[]) => Promise<void> | void // save document callback
}
Contribute
You welcome to contribute!
start it ease:
yarn
yarn dev
