diff --git a/README.md b/README.md index 2d3589ac..719bea95 100644 --- a/README.md +++ b/README.md @@ -791,6 +791,21 @@ Convert V2 update format to the V1 update format. ### Relative Positions +When working with collaborative documents, we often need to work with positions. +Positions may represent cursor locations, selection ranges, or even assign a +comment to a range of text. Normal index-positions (expressed as integers) are +not convenient to use because the index-range is invalidated as soon as a remote +change manipulates the document. Relative positions give you a powerful API to +express positions. + +A relative position is fixated to an element in the shared document and is not +affected by remote changes. I.e. given the document `"a|c"`, the relative +position is attached to `c`. When a remote user modifies the document by +inserting a character before the cursor, the cursor will stay attached to the +character `c`. `insert(1, 'x')("a|c") = "ax|c"`. When the relative position is +set to the end of the document, it will stay attached to the end of the +document. + #### Example: Transform to RelativePosition and back ```js @@ -825,14 +840,35 @@ pos.index === 2 // => true ```
Y.createRelativePositionFromTypeIndex(Uint8Array|Y.Type, number)
-
- Y.createAbsolutePositionFromRelativePosition(RelativePosition, Y.Doc)
-
- Y.encodeRelativePosition(RelativePosition):Uint8Array
-
+
+Y.createRelativePositionFromTypeIndex(type:Uint8Array|Y.Type, index: number
+[, assoc=0])
+
+ assoc >= 0
). By default, the position associates
+with the character that comes after the specified index position. If
+assoc < 0
, then the relative position associates with the character
+before the specified index position.
+
+Y.createAbsolutePositionFromRelativePosition(RelativePosition, Y.Doc):
+{ type: Y.AbstractType, index: number, assoc: number } | null
+
+
+Y.encodeRelativePosition(RelativePosition):Uint8Array
+
+ Y.decodeRelativePosition(Uint8Array):RelativePosition
-
+