You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
cudr_slate-collaborative/README.md

64 lines
1.7 KiB

5 years ago
# slate-collaborative
slatejs collaborative plugin & microservice
A little experiment for co-editing.
5 years ago
Based on idea of https://github.com/humandx/slate-automerge
5 years ago
Watch the demo
# API
## Client
Use it as a simple slatejs plugin
```
import ColaborativeClient from '@slate-collaborative/client'
const plugins = [ColaborativeClient(options)]
```
### options:
```
{
url?: string // url to open connection
connectOpts?: SocketIOClient.ConnectOpts // socket.io-client options
cursorAnnotationType?: string // type string for cursor annotations
annotationDataMixin?: Data // any data passed to cursor annotation
renderPreloader?: () => ReactNode // optional preloader render
renderCursor?: (data: Data) => ReactNode | any // option custom cursor render
onConnect?: (connection: Connection) => void // connect callback
onDisconnect?: (connection: Connection) => void // disconnect callback
}
```
## Backend
```
const CollaborativeBackend = require('@slate-collaborative/backend')
const connection = new CollaborativeBackend(options)
```
### options:
```
{
5 years ago
port: number // posrt to start io connection
5 years ago
connectOpts?: SocketIO.ServerOptions
5 years ago
defaultValue?: ValueJSON // default value
saveTreshold?: number // theshold of onDocumentSave callback execution
cursorAnnotationType?: string // type string for cursor annotations
onAuthRequest?: ( // auth callback
5 years ago
query: Object,
socket?: SocketIO.Socket
) => Promise<boolean> | boolean
5 years ago
onDocumentLoad?: ( // request slatejs document callback
5 years ago
pathname: string,
query?: Object
) => ValueJSON | null | false | undefined
5 years ago
onDocumentSave?: (pathname: string, json: ValueJSON) => Promise<void> | void // save document callback
5 years ago
}
```