diff --git a/lib/models/documents/document.dart b/lib/models/documents/document.dart index 235fc8da..7e02313d 100644 --- a/lib/models/documents/document.dart +++ b/lib/models/documents/document.dart @@ -28,11 +28,12 @@ class Document { final Rules _rules = Rules.getInstance(); final StreamController> _observer = - StreamController.broadcast(); + StreamController.broadcast(); Stream get changes => _observer.stream; - Document() : _delta = Delta()..insert('\n') { + Document() : _delta = Delta() + ..insert('\n') { _loadDocument(_delta); } @@ -124,7 +125,7 @@ class Document { Delta originalDelta = toDelta(); for (Operation op in delta.toList()) { Style style = - op.attributes != null ? Style.fromJson(op.attributes) : null; + op.attributes != null ? Style.fromJson(op.attributes) : null; if (op.isInsert) { _root.insert(offset, _normalize(op.data), style); @@ -138,7 +139,11 @@ class Document { offset += op.length; } } - _delta = _delta.compose(delta); + try { + _delta = _delta.compose(delta); + } catch (e) { + throw ('_delta compose failed'); + } if (_delta != _root.toDelta()) { throw ('Compose failed'); @@ -158,8 +163,8 @@ class Document { return data is String ? data : data is Embeddable - ? data - : Embeddable.fromJson(data); + ? data + : Embeddable.fromJson(data); } close() { @@ -173,13 +178,14 @@ class Document { int offset = 0; for (final op in doc.toList()) { final style = - op.attributes != null ? Style.fromJson(op.attributes) : null; + op.attributes != null ? Style.fromJson(op.attributes) : null; if (op.isInsert) { final data = _normalize(op.data); _root.insert(offset, data, style); } else { throw ArgumentError.value(doc, - 'Document Delta can only contain insert operations but ${op.key} found.'); + 'Document Delta can only contain insert operations but ${op + .key} found.'); } offset += op.length; } diff --git a/lib/models/documents/nodes/container.dart b/lib/models/documents/nodes/container.dart index 41c48859..08db8670 100644 --- a/lib/models/documents/nodes/container.dart +++ b/lib/models/documents/nodes/container.dart @@ -84,6 +84,7 @@ abstract class Container extends Node { if (isNotEmpty) { ChildQuery child = queryChild(index, false); child.node.insert(child.offset, data, style); + return; } // empty