feat: handle annotations

This commit is contained in:
cudr 2019-11-10 21:16:53 +03:00
parent 0f98915909
commit ad0aaf2607
3 changed files with 46 additions and 13 deletions

View File

@ -1,19 +1,55 @@
import { Operation, SyncDoc } from '../model/index'
import { SyncDoc } from '../model/index'
import { toSync } from '../utils'
import {
AddAnnotationOperation,
RemoveAnnotationOperation,
SetAnnotationOperation
} from 'slate'
// TODO: handle annotation ops
export const addAnnotation = (
doc: SyncDoc,
op: AddAnnotationOperation
): SyncDoc => {
if (!doc.annotations) {
doc['annotations'] = {}
}
const annotation = op.annotation.toJSON()
doc.annotations[annotation.key] = toSync(annotation)
export const addAnnotation = (doc: SyncDoc, op: Operation): SyncDoc => {
// console.log('addAnnotation!!!', op.toJS())
return doc
}
export const removeAnnotation = (doc: SyncDoc, op: Operation): SyncDoc => {
// console.log('removeAnnotation!!!', op.toJS())
export const removeAnnotation = (
doc: SyncDoc,
op: RemoveAnnotationOperation
): SyncDoc => {
if (doc.annotations) {
delete doc.annotations[op.annotation.key]
}
return doc
}
export const setAnnotation = (doc: SyncDoc, op: Operation): SyncDoc => {
// console.log('setAnnotation!!!', op.toJS())
export const setAnnotation = (
doc: SyncDoc,
op: SetAnnotationOperation
): SyncDoc => {
/**
* Looks like set_annotation option is broken, temporary disabled
*/
// const { newProperties }: any = op.toJSON()
// if (!doc.annotations || !newProperties) return doc
// if (!doc.annotations[newProperties.key]) {
// return addAnnotation(doc, newProperties)
// } else {
// doc.annotations[newProperties.key] = { ...doc.annotations[newProperties.key], ...newProperties }
// }
return doc
}

View File

@ -1,5 +1,4 @@
import { Operation, Selection } from 'slate'
import * as Immutable from 'immutable'
import { Selection } from 'slate'
import merge from 'lodash/merge'
import { toJS } from '../utils'

View File

@ -93,9 +93,7 @@ class Client extends Component<ClienProps> {
)
}
onChange = ({ value }: any) => {
this.setState({ value })
}
onChange = ({ value }: any) => this.setState({ value })
onConnect = () => this.setState({ isOnline: true })