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() {
|
2019-10-13 16:37:56 +00:00
|
|
|
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,
|
2019-10-13 16:37:56 +00:00
|
|
|
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() {
|
2019-10-13 16:37:56 +00:00
|
|
|
const { children, renderPreloader } = this.props
|
2019-10-05 08:44:49 +00:00
|
|
|
const { preloading } = this.state
|
|
|
|
|
2019-10-13 16:37:56 +00:00
|
|
|
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
|