mirror of
https://github.com/ianstormtaylor/slate.git
synced 2025-08-28 09:29:49 +02:00
* Adds clarification & examples to demystify Transforms. * Fleshes out documentation of NodeOptions for Transforms * Update docs/concepts/04-transforms.md Co-authored-by: Dylan Schiemann <dylan@dojotoolkit.org> * Uses 'API' in the title of all API documents Co-authored-by: Dylan Schiemann <dylan@dojotoolkit.org>
50 lines
1.4 KiB
Markdown
50 lines
1.4 KiB
Markdown
# Point API
|
|
|
|
`Point` objects refer to a specific location in a text node in a Slate document. Its `path` refers to the location of the node in the tree, and its `offset` refers to distance into the node's string of text. Points may only refer to `Text` nodes.
|
|
|
|
```typescript
|
|
interface Point {
|
|
path: Path
|
|
offset: number
|
|
}
|
|
```
|
|
|
|
- [Static methods](point.md#static-methods)
|
|
- [Retrieval methods](point.md#retrieval-methods)
|
|
- [Check methods](point.md#check-methods)
|
|
- [Transform methods](point.md#transform-methods)
|
|
|
|
## Static methods
|
|
|
|
### Retrieval methods
|
|
|
|
#### `Point.compare(point: Point, another: Point) => -1 | 0 | 1`
|
|
|
|
Compare a `point` to `another`, returning an integer indicating whether the point was before, at or after the other.
|
|
|
|
### Check methods
|
|
|
|
#### `Point.isAfter(point: Point, another: Point) => boolean`
|
|
|
|
Check if a `point` is after `another`.
|
|
|
|
#### `Point.isBefore(point: Point, another: Point) => boolean`
|
|
|
|
Check if a `point` is before `another`.
|
|
|
|
#### `Point.equals(point: Point, another: Point) => boolean`
|
|
|
|
Check if a `point` is exactly equal to `another`.
|
|
|
|
#### `Point.isPoint(value: any) => value is Point`
|
|
|
|
Check if a `value` implements the `Point` interface.
|
|
|
|
### Transform methods
|
|
|
|
#### `Point.transform(point: Point, op: Operation, options?) => Point | null`
|
|
|
|
Transform a `point` by an `op`.
|
|
|
|
Options: `{affinity?: 'forward' | 'backward' | null}`
|