@b9g/revise 0.1.0 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,5 +1,70 @@
1
1
  # Revise.js
2
2
 
3
- Little helpers for writing contenteditable-based text editors.
3
+ Revise is a JavaScript library for creating
4
+ [`contenteditable`-based](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/contenteditable)
5
+ rich-text editors in the browser. It provides a low-level, web-component based
6
+ API for translating the DOM into string documents. The library also ships with
7
+ a compact data structure for representing edits to strings. Revise is intended
8
+ to be framework-agnostic, though currently it is only being tested with
9
+ [Crank](crank.js.org).
4
10
 
5
- If you’re reading this, you’re here early.
11
+ ## Status
12
+
13
+ At present, this library is in an early beta. It is recommended for developers
14
+ who aren’t afraid of stepping through DOM code in a debugger.
15
+
16
+ ## Usage
17
+
18
+ TKTKTKT
19
+
20
+ ## API
21
+
22
+ ### `ContentAreaElement`
23
+
24
+ A custom element class with an API similar to that of the JavaScript API for
25
+ the [`<textarea>`
26
+ element](https://developer.mozilla.org/en-US/docs/Web/API/HTMLTextAreaElement).
27
+ This class provides special properties and methods for reading the current
28
+ value of the element’s contents and manipulating its selection.
29
+
30
+ - `value`
31
+
32
+ - `selectionStart`
33
+
34
+ - `selectionEnd`
35
+
36
+ - `selectionDirection`
37
+
38
+ - `setSelectionRange(selectionStart: number, selectionEnd: number, selectionDirection?: SelectionDirection): void;`
39
+
40
+ - `indexAt(node: Node | null, offset: number): number`
41
+
42
+ - `nodeOffsetAt(index: number): [Node | null, number]
43
+
44
+ - `source(name: string): boolean`
45
+
46
+ - `ContentEvent`
47
+
48
+ ### `Edit`
49
+
50
+ - `operations(): Array<Operation>`
51
+
52
+ - `apply(text: string): string`
53
+
54
+ - `compose(that: Edit): Edit`
55
+
56
+ - `invert(): Edit`
57
+
58
+ - `normalize(): Edit`
59
+
60
+ - `hasChangesBetween(start: number, end: number): boolean`
61
+
62
+ - `Edit.createBuilder(value: string): EditBuilder`
63
+
64
+ - `Edit.diff(text1: string, text2: string, hint?: number): Edit`
65
+
66
+ ### `EditBuilder`
67
+
68
+ ### `EditHistory`
69
+
70
+ ### `Keyer`
package/_subseq.d.ts ADDED
@@ -0,0 +1,18 @@
1
+ export type Subseq = Array<number>;
2
+ export declare function measure(subseq: Subseq): {
3
+ length: number;
4
+ includedLength: number;
5
+ excludedLength: number;
6
+ };
7
+ export declare function pushSegment(subseq: Subseq, length: number, included: boolean): void;
8
+ export declare function contains(subseq: Subseq, index: number): boolean;
9
+ export declare function clear(subseq: Subseq): Subseq;
10
+ export declare function fill(subseq: Subseq): Subseq;
11
+ export declare function complement(subseq: Subseq): Subseq;
12
+ export declare function align(subseq1: Subseq, subseq2: Subseq): Array<[number, boolean, boolean]>;
13
+ export declare function union(subseq1: Subseq, subseq2: Subseq): Subseq;
14
+ export declare function intersection(subseq1: Subseq, subseq2: Subseq): Subseq;
15
+ export declare function difference(subseq1: Subseq, subseq2: Subseq): Subseq;
16
+ export declare function shrink(subseq1: Subseq, subseq2: Subseq): Subseq;
17
+ export declare function expand(subseq1: Subseq, subseq2: Subseq): Subseq;
18
+ export declare function interleave(subseq1: Subseq, subseq2: Subseq): [Subseq, Subseq];