cudr_slate-collaborative/packages/client/src/Controller.tsx

77 lines
1.4 KiB
TypeScript
Raw Normal View History

2019-10-06 20:56:27 +00:00
import React, { Component } from 'react'
import { KeyUtils } from 'slate'
import { hexGen } from '@slate-collaborative/bridge'
2019-10-05 08:44:49 +00:00
import Connection from './Connection'
import { ControllerProps } from './model'
2019-10-06 10:30:35 +00:00
class Controller extends Component<ControllerProps> {
2019-10-05 08:44:49 +00:00
connection?: Connection
state = {
preloading: true
}
componentDidMount() {
const {
editor,
url,
cursorAnnotationType,
annotationDataMixin,
connectOpts
} = this.props
2019-10-05 08:44:49 +00:00
2019-10-06 20:56:27 +00:00
KeyUtils.setGenerator(() => hexGen())
2019-10-05 08:44:49 +00:00
editor.connection = new Connection({
editor,
url,
connectOpts,
cursorAnnotationType,
annotationDataMixin,
2019-10-05 08:44:49 +00:00
onConnect: this.onConnect,
onDisconnect: this.onDisconnect
})
}
componentWillUnmount() {
const { editor } = this.props
if (editor.connection) editor.connection.close()
delete editor.connection
}
render() {
const { children, renderPreloader } = this.props
2019-10-05 08:44:49 +00:00
const { preloading } = this.state
if (renderPreloader && preloading) return renderPreloader()
2019-10-05 08:44:49 +00:00
return children
}
onConnect = () => {
const { onConnect, editor } = this.props
this.setState({
preloading: false
})
onConnect && onConnect(editor.connection)
}
onDisconnect = () => {
const { onDisconnect, editor } = this.props
this.setState({
preloading: true
})
onDisconnect && onDisconnect(editor.connection)
}
}
export default Controller