lib0 0.2.112 → 0.2.115-0

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.
Files changed (331) hide show
  1. package/README.md +1 -1
  2. package/broadcastchannel.js +1 -1
  3. package/buffer.d.ts +3 -3
  4. package/buffer.d.ts.map +1 -1
  5. package/buffer.js +1 -1
  6. package/coverage/tmp/coverage-27667-1761218530660-0.json +1 -0
  7. package/coverage/tmp/{coverage-20055-1752683207886-0.json → coverage-27668-1761218485882-0.json} +1 -1
  8. package/crypto/aes-gcm.d.ts +4 -4
  9. package/crypto/aes-gcm.d.ts.map +1 -1
  10. package/crypto/aes-gcm.js +6 -6
  11. package/crypto/common.d.ts +1 -1
  12. package/crypto/common.d.ts.map +1 -1
  13. package/crypto/common.js +1 -1
  14. package/crypto/ecdsa.d.ts +2 -2
  15. package/crypto/ecdsa.d.ts.map +1 -1
  16. package/crypto/ecdsa.js +4 -4
  17. package/crypto/rsa-oaep.d.ts +2 -2
  18. package/crypto/rsa-oaep.d.ts.map +1 -1
  19. package/crypto/rsa-oaep.js +3 -3
  20. package/decoding.d.ts +27 -14
  21. package/decoding.d.ts.map +1 -1
  22. package/decoding.js +12 -8
  23. package/delta/abstract-array.d.ts +166 -0
  24. package/delta/abstract-array.d.ts.map +1 -0
  25. package/delta/abstract-array.js +421 -0
  26. package/delta/abstract.d.ts +69 -0
  27. package/delta/abstract.d.ts.map +1 -0
  28. package/delta/abstract.js +102 -0
  29. package/delta/array.d.ts +23 -0
  30. package/delta/array.d.ts.map +1 -0
  31. package/delta/array.js +45 -0
  32. package/delta/array.test.d.ts +2 -0
  33. package/delta/array.test.d.ts.map +1 -0
  34. package/delta/binding.d.ts +105 -0
  35. package/delta/binding.d.ts.map +1 -0
  36. package/delta/binding.js +369 -0
  37. package/delta/binding.test.d.ts +5 -0
  38. package/delta/binding.test.d.ts.map +1 -0
  39. package/delta/d2.d.ts +705 -0
  40. package/delta/d2.d.ts.map +1 -0
  41. package/delta/d2.js +1309 -0
  42. package/delta/d2.test.d.ts +15 -0
  43. package/delta/d2.test.d.ts.map +1 -0
  44. package/delta/index.d.ts +14 -0
  45. package/delta/index.d.ts.map +1 -0
  46. package/delta/index.js +79 -0
  47. package/delta/map.d.ts +230 -0
  48. package/delta/map.d.ts.map +1 -0
  49. package/delta/map.js +304 -0
  50. package/delta/node.d.ts +119 -0
  51. package/delta/node.d.ts.map +1 -0
  52. package/delta/node.js +183 -0
  53. package/delta/node.test.d.ts +4 -0
  54. package/delta/node.test.d.ts.map +1 -0
  55. package/delta/ops.d.ts +466 -0
  56. package/delta/ops.d.ts.map +1 -0
  57. package/delta/ops.js +544 -0
  58. package/delta/readme.md +129 -0
  59. package/delta/text.d.ts +43 -0
  60. package/delta/text.d.ts.map +1 -0
  61. package/delta/text.js +54 -0
  62. package/delta/text.test.d.ts +6 -0
  63. package/delta/text.test.d.ts.map +1 -0
  64. package/delta/transformer.d.ts +164 -0
  65. package/delta/transformer.d.ts.map +1 -0
  66. package/delta/transformer.js +888 -0
  67. package/delta/transformer.test.d.ts +13 -0
  68. package/delta/transformer.test.d.ts.map +1 -0
  69. package/delta/value.d.ts +84 -0
  70. package/delta/value.d.ts.map +1 -0
  71. package/delta/value.js +168 -0
  72. package/dist/abstract-array.cjs +433 -0
  73. package/dist/abstract-array.cjs.map +1 -0
  74. package/dist/abstract.cjs +122 -0
  75. package/dist/abstract.cjs.map +1 -0
  76. package/dist/aes-gcm.cjs +12 -12
  77. package/dist/aes-gcm.cjs.map +1 -1
  78. package/dist/array.cjs +60 -17
  79. package/dist/array.cjs.map +1 -1
  80. package/dist/array2.cjs +26 -0
  81. package/dist/array2.cjs.map +1 -0
  82. package/dist/binding.cjs +398 -0
  83. package/dist/binding.cjs.map +1 -0
  84. package/dist/{broadcastchannel-2c4b0a1c.cjs → broadcastchannel-b4eaea6e.cjs} +4 -4
  85. package/dist/broadcastchannel-b4eaea6e.cjs.map +1 -0
  86. package/dist/broadcastchannel.cjs +12 -12
  87. package/dist/{buffer-a74f7330.cjs → buffer-adc4e6ea.cjs} +7 -7
  88. package/dist/buffer-adc4e6ea.cjs.map +1 -0
  89. package/dist/buffer.cjs +11 -11
  90. package/dist/buffer.d.ts +3 -3
  91. package/dist/buffer.d.ts.map +1 -1
  92. package/dist/cache.cjs +6 -6
  93. package/dist/common.cjs +1 -1
  94. package/dist/common.cjs.map +1 -1
  95. package/dist/component.cjs +14 -9
  96. package/dist/component.cjs.map +1 -1
  97. package/dist/crypto/aes-gcm.d.ts +4 -4
  98. package/dist/crypto/aes-gcm.d.ts.map +1 -1
  99. package/dist/crypto/common.d.ts +1 -1
  100. package/dist/crypto/common.d.ts.map +1 -1
  101. package/dist/crypto/ecdsa.d.ts +2 -2
  102. package/dist/crypto/ecdsa.d.ts.map +1 -1
  103. package/dist/crypto/rsa-oaep.d.ts +2 -2
  104. package/dist/crypto/rsa-oaep.d.ts.map +1 -1
  105. package/dist/d2.cjs +1347 -0
  106. package/dist/d2.cjs.map +1 -0
  107. package/dist/{decoding-2b136346.cjs → decoding-50b9ce38.cjs} +18 -14
  108. package/dist/decoding-50b9ce38.cjs.map +1 -0
  109. package/dist/decoding.cjs +6 -6
  110. package/dist/decoding.d.ts +27 -14
  111. package/dist/decoding.d.ts.map +1 -1
  112. package/dist/delta/abstract-array.d.ts +166 -0
  113. package/dist/delta/abstract-array.d.ts.map +1 -0
  114. package/dist/delta/abstract.d.ts +69 -0
  115. package/dist/delta/abstract.d.ts.map +1 -0
  116. package/dist/delta/array.d.ts +23 -0
  117. package/dist/delta/array.d.ts.map +1 -0
  118. package/dist/delta/array.test.d.ts +2 -0
  119. package/dist/delta/array.test.d.ts.map +1 -0
  120. package/dist/delta/binding.d.ts +105 -0
  121. package/dist/delta/binding.d.ts.map +1 -0
  122. package/dist/delta/binding.test.d.ts +5 -0
  123. package/dist/delta/binding.test.d.ts.map +1 -0
  124. package/dist/delta/d2.d.ts +705 -0
  125. package/dist/delta/d2.d.ts.map +1 -0
  126. package/dist/delta/d2.test.d.ts +15 -0
  127. package/dist/delta/d2.test.d.ts.map +1 -0
  128. package/dist/delta/index.d.ts +14 -0
  129. package/dist/delta/index.d.ts.map +1 -0
  130. package/dist/delta/map.d.ts +230 -0
  131. package/dist/delta/map.d.ts.map +1 -0
  132. package/dist/delta/node.d.ts +119 -0
  133. package/dist/delta/node.d.ts.map +1 -0
  134. package/dist/delta/node.test.d.ts +4 -0
  135. package/dist/delta/node.test.d.ts.map +1 -0
  136. package/dist/delta/ops.d.ts +466 -0
  137. package/dist/delta/ops.d.ts.map +1 -0
  138. package/dist/delta/text.d.ts +43 -0
  139. package/dist/delta/text.d.ts.map +1 -0
  140. package/dist/delta/text.test.d.ts +6 -0
  141. package/dist/delta/text.test.d.ts.map +1 -0
  142. package/dist/delta/transformer.d.ts +164 -0
  143. package/dist/delta/transformer.d.ts.map +1 -0
  144. package/dist/delta/transformer.test.d.ts +13 -0
  145. package/dist/delta/transformer.test.d.ts.map +1 -0
  146. package/dist/delta/value.d.ts +84 -0
  147. package/dist/delta/value.d.ts.map +1 -0
  148. package/dist/{diff-77c4cf8e.cjs → diff-f0776c15.cjs} +2 -2
  149. package/dist/{diff-77c4cf8e.cjs.map → diff-f0776c15.cjs.map} +1 -1
  150. package/dist/diff.cjs +3 -3
  151. package/dist/{dom-16daf1a0.cjs → dom-2b123630.cjs} +31 -2
  152. package/dist/dom-2b123630.cjs.map +1 -0
  153. package/dist/dom.cjs +17 -2
  154. package/dist/dom.cjs.map +1 -1
  155. package/dist/dom.d.ts +17 -0
  156. package/dist/dom.d.ts.map +1 -1
  157. package/dist/ecdsa.cjs +4 -4
  158. package/dist/ecdsa.cjs.map +1 -1
  159. package/dist/{encoding-1acb59c4.cjs → encoding-7f85922c.cjs} +5 -5
  160. package/dist/encoding-7f85922c.cjs.map +1 -0
  161. package/dist/encoding.cjs +4 -4
  162. package/dist/encoding.d.ts +6 -6
  163. package/dist/encoding.d.ts.map +1 -1
  164. package/dist/{environment-2de08e0e.cjs → environment-90227ead.cjs} +4 -4
  165. package/dist/{environment-2de08e0e.cjs.map → environment-90227ead.cjs.map} +1 -1
  166. package/dist/environment.cjs +5 -5
  167. package/dist/{error-8582d695.cjs → error-0c1f634f.cjs} +10 -2
  168. package/dist/error-0c1f634f.cjs.map +1 -0
  169. package/dist/error.cjs +2 -1
  170. package/dist/error.cjs.map +1 -1
  171. package/dist/error.d.ts +1 -0
  172. package/dist/error.d.ts.map +1 -1
  173. package/dist/{eventloop-b299a889.cjs → eventloop-a0168106.cjs} +2 -2
  174. package/dist/{eventloop-b299a889.cjs.map → eventloop-a0168106.cjs.map} +1 -1
  175. package/dist/eventloop.cjs +3 -3
  176. package/dist/{function-09b8292c.cjs → function-e7d18feb.cjs} +2 -2
  177. package/dist/{function-09b8292c.cjs.map → function-e7d18feb.cjs.map} +1 -1
  178. package/dist/function.cjs +2 -2
  179. package/dist/index.cjs +23 -22
  180. package/dist/index.cjs.map +1 -1
  181. package/dist/index2.cjs +71 -0
  182. package/dist/index2.cjs.map +1 -0
  183. package/dist/{indexeddb-0cbb4d6f.cjs → indexeddb-46d1e737.cjs} +3 -3
  184. package/dist/{indexeddb-0cbb4d6f.cjs.map → indexeddb-46d1e737.cjs.map} +1 -1
  185. package/dist/indexeddb.cjs +5 -5
  186. package/dist/indexeddbV2.cjs +2 -1
  187. package/dist/indexeddbV2.cjs.map +1 -1
  188. package/dist/jwt.cjs +12 -12
  189. package/dist/list.cjs +39 -12
  190. package/dist/list.cjs.map +1 -1
  191. package/dist/list.d.ts +13 -3
  192. package/dist/list.d.ts.map +1 -1
  193. package/dist/logging.cjs +11 -9
  194. package/dist/logging.cjs.map +1 -1
  195. package/dist/logging.common.cjs +7 -7
  196. package/dist/logging.node.cjs +7 -7
  197. package/dist/{map-0dabcc55.cjs → map-24d263c0.cjs} +7 -1
  198. package/dist/map-24d263c0.cjs.map +1 -0
  199. package/dist/map.cjs +314 -7
  200. package/dist/map.cjs.map +1 -1
  201. package/dist/map.d.ts +1 -0
  202. package/dist/map.d.ts.map +1 -1
  203. package/dist/map2.cjs +15 -0
  204. package/dist/map2.cjs.map +1 -0
  205. package/dist/{math-08e068f9.cjs → math-96d5e8c4.cjs} +4 -2
  206. package/dist/math-96d5e8c4.cjs.map +1 -0
  207. package/dist/math.cjs +1 -1
  208. package/dist/math.d.ts.map +1 -1
  209. package/dist/metric.cjs +1 -1
  210. package/dist/node.cjs +206 -0
  211. package/dist/node.cjs.map +1 -0
  212. package/dist/{number-466d8922.cjs → number-1fb57bba.cjs} +2 -2
  213. package/dist/{number-466d8922.cjs.map → number-1fb57bba.cjs.map} +1 -1
  214. package/dist/number.cjs +2 -2
  215. package/dist/{object-491858d1.cjs → object-18980796.cjs} +12 -2
  216. package/dist/object-18980796.cjs.map +1 -0
  217. package/dist/object.cjs +3 -1
  218. package/dist/object.cjs.map +1 -1
  219. package/dist/object.d.ts +3 -0
  220. package/dist/object.d.ts.map +1 -1
  221. package/dist/observable.cjs +1 -1
  222. package/dist/ops.cjs +575 -0
  223. package/dist/ops.cjs.map +1 -0
  224. package/dist/patience.cjs +2 -2
  225. package/dist/performance.node.cjs +4 -4
  226. package/dist/pledge.cjs +2 -1
  227. package/dist/pledge.cjs.map +1 -1
  228. package/dist/{prng-24dfe0bf.cjs → prng-004c76e8.cjs} +5 -5
  229. package/dist/{prng-24dfe0bf.cjs.map → prng-004c76e8.cjs.map} +1 -1
  230. package/dist/prng.cjs +12 -12
  231. package/dist/prng.d.ts +1 -1
  232. package/dist/prng.d.ts.map +1 -1
  233. package/dist/{promise-7d13a97c.cjs → promise-cda7b9bb.cjs} +2 -2
  234. package/dist/{promise-7d13a97c.cjs.map → promise-cda7b9bb.cjs.map} +1 -1
  235. package/dist/promise.cjs +3 -3
  236. package/dist/rabin-gf2-polynomial.cjs +11 -11
  237. package/dist/rabin-uncached.cjs +11 -11
  238. package/dist/rabin.cjs +11 -11
  239. package/dist/random.cjs +1 -1
  240. package/dist/rsa-oaep.cjs +3 -3
  241. package/dist/rsa-oaep.cjs.map +1 -1
  242. package/dist/schema.cjs +572 -167
  243. package/dist/schema.cjs.map +1 -1
  244. package/dist/schema.d.ts +326 -122
  245. package/dist/schema.d.ts.map +1 -1
  246. package/dist/schema.test.d.ts +5 -0
  247. package/dist/schema.test.d.ts.map +1 -1
  248. package/dist/{sort-b8702761.cjs → sort-812cc211.cjs} +2 -2
  249. package/dist/{sort-b8702761.cjs.map → sort-812cc211.cjs.map} +1 -1
  250. package/dist/sort.cjs +2 -2
  251. package/dist/{statistics-c2316dca.cjs → statistics-65f6114b.cjs} +2 -2
  252. package/dist/{statistics-c2316dca.cjs.map → statistics-65f6114b.cjs.map} +1 -1
  253. package/dist/statistics.cjs +2 -2
  254. package/dist/{string-b2827a90.cjs → string-fddc5f8b.cjs} +3 -3
  255. package/dist/string-fddc5f8b.cjs.map +1 -0
  256. package/dist/string.cjs +1 -1
  257. package/dist/string.d.ts +3 -3
  258. package/dist/string.d.ts.map +1 -1
  259. package/dist/testing.cjs +16 -16
  260. package/dist/text.cjs +79 -0
  261. package/dist/text.cjs.map +1 -0
  262. package/dist/{time-bc2081b9.cjs → time-d8438852.cjs} +2 -2
  263. package/dist/{time-bc2081b9.cjs.map → time-d8438852.cjs.map} +1 -1
  264. package/dist/time.cjs +2 -2
  265. package/dist/traits.cjs +22 -0
  266. package/dist/traits.cjs.map +1 -1
  267. package/dist/traits.d.ts +1 -0
  268. package/dist/traits.d.ts.map +1 -1
  269. package/dist/traits.test.d.ts.map +1 -1
  270. package/dist/transformer.cjs +930 -0
  271. package/dist/transformer.cjs.map +1 -0
  272. package/dist/url.cjs +2 -1
  273. package/dist/url.cjs.map +1 -1
  274. package/dist/value.cjs +187 -0
  275. package/dist/value.cjs.map +1 -0
  276. package/dist/webcrypto.d.ts +1 -1
  277. package/dist/webcrypto.d.ts.map +1 -1
  278. package/dist/{websocket-40a601d4.cjs → websocket-b073d0fc.cjs} +3 -3
  279. package/dist/{websocket-40a601d4.cjs.map → websocket-b073d0fc.cjs.map} +1 -1
  280. package/dist/websocket.cjs +4 -4
  281. package/dom.d.ts +17 -0
  282. package/dom.d.ts.map +1 -1
  283. package/dom.js +21 -0
  284. package/encoding.d.ts +6 -6
  285. package/encoding.d.ts.map +1 -1
  286. package/encoding.js +1 -1
  287. package/error.d.ts +1 -0
  288. package/error.d.ts.map +1 -1
  289. package/error.js +6 -0
  290. package/list.d.ts +13 -3
  291. package/list.d.ts.map +1 -1
  292. package/list.js +36 -8
  293. package/map.d.ts +1 -0
  294. package/map.d.ts.map +1 -1
  295. package/map.js +6 -0
  296. package/math.d.ts.map +1 -1
  297. package/math.js +3 -1
  298. package/object.d.ts +3 -0
  299. package/object.d.ts.map +1 -1
  300. package/object.js +9 -1
  301. package/package.json +9 -3
  302. package/prng.d.ts +1 -1
  303. package/prng.d.ts.map +1 -1
  304. package/prng.js +1 -1
  305. package/schema.d.ts +326 -122
  306. package/schema.d.ts.map +1 -1
  307. package/schema.js +513 -141
  308. package/schema.test.d.ts +5 -0
  309. package/schema.test.d.ts.map +1 -1
  310. package/string.d.ts +3 -3
  311. package/string.d.ts.map +1 -1
  312. package/string.js +2 -2
  313. package/test.html +1 -0
  314. package/test.js +13 -1
  315. package/traits.d.ts +1 -0
  316. package/traits.d.ts.map +1 -1
  317. package/traits.js +21 -0
  318. package/traits.test.d.ts.map +1 -1
  319. package/webcrypto.d.ts +1 -1
  320. package/webcrypto.d.ts.map +1 -1
  321. package/coverage/tmp/coverage-20054-1752683240888-0.json +0 -1
  322. package/dist/broadcastchannel-2c4b0a1c.cjs.map +0 -1
  323. package/dist/buffer-a74f7330.cjs.map +0 -1
  324. package/dist/decoding-2b136346.cjs.map +0 -1
  325. package/dist/dom-16daf1a0.cjs.map +0 -1
  326. package/dist/encoding-1acb59c4.cjs.map +0 -1
  327. package/dist/error-8582d695.cjs.map +0 -1
  328. package/dist/map-0dabcc55.cjs.map +0 -1
  329. package/dist/math-08e068f9.cjs.map +0 -1
  330. package/dist/object-491858d1.cjs.map +0 -1
  331. package/dist/string-b2827a90.cjs.map +0 -1
@@ -0,0 +1,105 @@
1
+ /**
2
+ * @template T
3
+ * @typedef {import('../schema.js').Schema<T>} Schema
4
+ */
5
+ /**
6
+ * @template {delta.AbstractDelta} DeltaA
7
+ * @template {delta.AbstractDelta} DeltaB
8
+ */
9
+ export class Binding<DeltaA extends delta.AbstractDelta, DeltaB extends delta.AbstractDelta> {
10
+ /**
11
+ * @param {RDT<DeltaA>} a
12
+ * @param {RDT<DeltaB>} b
13
+ * @param {dt.Template<any,DeltaA,DeltaB>} template
14
+ */
15
+ constructor(a: RDT<DeltaA>, b: RDT<DeltaB>, template: dt.Template<any, DeltaA, DeltaB>);
16
+ /**
17
+ * @type {dt.Transformer<any,DeltaA,DeltaB>}
18
+ */
19
+ t: dt.Transformer<any, DeltaA, DeltaB>;
20
+ a: RDT<DeltaA>;
21
+ b: RDT<DeltaB>;
22
+ _mux: mux.mutex;
23
+ _achanged: (delta: DeltaA) => void;
24
+ _bchanged: (delta: DeltaB) => void;
25
+ destroy: () => void;
26
+ }
27
+ export function bind<DeltaA extends delta.AbstractDelta, Transformer extends dt.Template<any, DeltaA, any>>(a: RDT<DeltaA>, b: RDT<Transformer extends dt.Template<any, DeltaA, infer DeltaB> ? DeltaB : never>, template: dt.Template<any, DeltaA, any>): Binding<DeltaA, Transformer extends dt.Template<any, DeltaA, infer DeltaB extends delta.AbstractDelta> ? DeltaB : never>;
28
+ export function deltaRDT<Delta extends delta.AbstractDelta>($delta: Schema<Delta>): DeltaRDT<Delta>;
29
+ export const $domDelta: s.Schema<import("./node.js").RecursiveDeltaNode<string, Partial<{
30
+ [x: string]: string;
31
+ }>, never, true>>;
32
+ export function domRDT(dom: Element): DomRDT<DomDelta>;
33
+ export type Schema<T> = import("../schema.js").Schema<T>;
34
+ /**
35
+ * Abstract Interface for a delta-based Replicated Data Type.
36
+ */
37
+ export type RDT<Delta extends delta.AbstractDelta> = ObservableV2<{
38
+ "change": (delta: Delta) => void;
39
+ "destroy": (rdt: RDT<Delta>) => void;
40
+ }> & {
41
+ update: (delta: Delta) => any;
42
+ destroy: () => void;
43
+ };
44
+ export type DomDelta = delta.RecursiveNode<string, {
45
+ [key: string]: string;
46
+ }, never, true>;
47
+ import * as delta from './index.js';
48
+ import * as dt from './transformer.js';
49
+ import * as mux from '../mutex.js';
50
+ /**
51
+ * @template {delta.AbstractDelta} Delta
52
+ * @implements RDT<Delta>
53
+ * @extends {ObservableV2<{ change: (delta: Delta) => void, 'destroy': (rdt:DeltaRDT<Delta>)=>void }>}
54
+ */
55
+ declare class DeltaRDT<Delta extends delta.AbstractDelta> extends ObservableV2<{
56
+ change: (delta: Delta) => void;
57
+ destroy: (rdt: DeltaRDT<Delta>) => void;
58
+ }> implements RDT<Delta> {
59
+ /**
60
+ * @param {Schema<Delta>} $delta
61
+ */
62
+ constructor($delta: Schema<Delta>);
63
+ $delta: s.Schema<Delta>;
64
+ /**
65
+ * @type {Delta?}
66
+ */
67
+ state: Delta | null;
68
+ _mux: mux.mutex;
69
+ /**
70
+ * @param {Delta} delta
71
+ */
72
+ update: (delta: Delta) => any;
73
+ }
74
+ import * as s from '../schema.js';
75
+ /**
76
+ * @typedef {delta.RecursiveNode<string, { [key:string]: string }, never, true>} DomDelta
77
+ */
78
+ /**
79
+ * @template {DomDelta} [D=DomDelta]
80
+ * @implements RDT<D>
81
+ * @extends {ObservableV2<{ change: (delta: D)=>void, destroy: (rdt:DomRDT<D>)=>void }>}>}
82
+ */
83
+ declare class DomRDT<D extends DomDelta = DomDelta> extends ObservableV2<{
84
+ change: (delta: D) => void;
85
+ destroy: (rdt: DomRDT<D>) => void;
86
+ }> implements RDT<D> {
87
+ /**
88
+ * @param {Element} observedNode
89
+ */
90
+ constructor(observedNode: Element);
91
+ observedNode: Element;
92
+ _mux: mux.mutex;
93
+ observer: MutationObserver;
94
+ /**
95
+ * @param {MutationRecord[]} mutations
96
+ */
97
+ _mutationHandler: (mutations: MutationRecord[]) => any;
98
+ /**
99
+ * @param {D} delta
100
+ */
101
+ update: (delta: D) => void;
102
+ }
103
+ import { ObservableV2 } from '../observable.js';
104
+ export {};
105
+ //# sourceMappingURL=binding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"binding.d.ts","sourceRoot":"","sources":["binding.js"],"names":[],"mappings":"AAYA;;;GAGG;AAEH;;;GAGG;AACH,qBAHmC,MAAM,SAA3B,KAAK,CAAC,aAAc,EACC,MAAM,SAA3B,KAAK,CAAC,aAAc;IAGhC;;;;OAIG;IACH,eAJW,GAAG,CAAC,MAAM,CAAC,KACX,GAAG,CAAC,MAAM,CAAC,YACX,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAC,MAAM,EAAC,MAAM,CAAC,EA4BxC;IAzBC;;OAEG;IACH,GAFU,EAAE,CAAC,WAAW,CAAC,GAAG,EAAC,MAAM,EAAC,MAAM,CAAC,CAEnB;IACxB,eAAU;IACV,eAAU;IACV,gBAA6B;IAC7B,8BAgCoD,IAAI,CAxBrD;IACH,8BAuBoD,IAAI,CAfrD;IAGL,oBAKC;CACF;AAgBM,qBAN4B,MAAM,SAA3B,KAAK,CAAC,aAAc,EACS,WAAW,SAAxC,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAC,MAAM,EAAC,GAAG,CAAE,KAC/B,GAAG,CAAC,MAAM,CAAC,KACX,GAAG,CAAC,WAAW,SAAS,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAC,MAAM,EAAC,MAAM,MAAM,CAAC,GAAG,MAAM,GAAG,KAAK,CAAC,YAC9E,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAC,MAAM,EAAC,GAAG,CAAC,sEAD0B,MAAM,gDAGH;AA2C5D,yBAH4B,KAAK,SAA1B,KAAK,CAAC,aAAc,UACvB,MAAM,CAAC,KAAK,CAAC,mBAE8B;AAkGtD;;kBAA+H;AAsJxH,4BAFI,OAAO,oBAE0B;mBAnW/B,CAAC,IACD,OAAO,cAAc,EAAE,MAAM,CAAC,CAAC,CAAC;;;;gBAoDV,KAAK,SAA1B,KAAK,CAAC,aAAc,IACrB,YAAY,CAAC;IAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IAAC,SAAS,EAAE,CAAC,GAAG,EAAC,GAAG,CAAC,KAAK,CAAC,KAAG,IAAI,CAAA;CAAE,CAAC,GAAG;IAAE,MAAM,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,GAAG,CAAC;IAAC,OAAO,EAAE,MAAM,IAAI,CAAA;CAAE;uBAkP9I,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE;IAAE,CAAC,GAAG,EAAC,MAAM,GAAG,MAAM,CAAA;CAAE,EAAE,KAAK,EAAE,IAAI,CAAC;uBAnTxD,YAAY;oBACf,kBAAkB;qBAMjB,aAAa;AAsElC;;;;GAIG;AACH,uBAJmC,KAAK,SAA1B,KAAK,CAAC,aAAc;YAEE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI;aAAa,CAAC,GAAG,EAAC,QAAQ,CAAC,KAAK,CAAC,KAAG,IAAI;cADnF,GAAG,CAAC,KAAK;IAItB;;OAEG;IACH,oBAFW,MAAM,CAAC,KAAK,CAAC,EAUvB;IANC,wBAAoB;IACpB;;OAEG;IACH,OAFU,KAAK,OAAC,CAEC;IACjB,gBAA6B;IAG/B;;OAEG;IACH,SAAS,OAFE,KAEG,SAOZ;CAMH;mBAxGkB,cAAc;AA0SjC;;GAEG;AAEH;;;;GAIG;AACH,qBAJyB,CAAC,SAAZ,QAAS;YAEa,CAAC,KAAK,EAAE,CAAC,KAAG,IAAI;aAAW,CAAC,GAAG,EAAC,MAAM,CAAC,CAAC,CAAC,KAAG,IAAI;cADrE,GAAG,CAAC,CAAC;IAIlB;;OAEG;IACH,0BAFW,OAAO,EAajB;IATC,sBAAgC;IAChC,gBAA6B;IAC7B,2BAA2D;IAS7D;;OAEG;IACH,mBAAmB,WAFR,cAAc,EAEG,SAGxB;IAEJ;;OAEG;IACH,SAAS,OAFE,CAEG,UAWb;CAOF;6BA1W4B,kBAAkB"}
@@ -0,0 +1,369 @@
1
+ /* global MutationObserver */
2
+ import { ObservableV2 } from '../observable.js'
3
+ import * as delta from './index.js'
4
+ import * as dt from './transformer.js' // eslint-disable-line
5
+ import * as dom from '../dom.js'
6
+ import * as set from '../set.js'
7
+ import * as map from '../map.js'
8
+ import * as error from '../error.js'
9
+ import * as math from '../math.js'
10
+ import * as mux from '../mutex.js'
11
+ import * as s from '../schema.js'
12
+
13
+ /**
14
+ * @template T
15
+ * @typedef {import('../schema.js').Schema<T>} Schema
16
+ */
17
+
18
+ /**
19
+ * @template {delta.AbstractDelta} DeltaA
20
+ * @template {delta.AbstractDelta} DeltaB
21
+ */
22
+ export class Binding {
23
+ /**
24
+ * @param {RDT<DeltaA>} a
25
+ * @param {RDT<DeltaB>} b
26
+ * @param {dt.Template<any,DeltaA,DeltaB>} template
27
+ */
28
+ constructor (a, b, template) {
29
+ /**
30
+ * @type {dt.Transformer<any,DeltaA,DeltaB>}
31
+ */
32
+ this.t = template.init()
33
+ this.a = a
34
+ this.b = b
35
+ this._mux = mux.createMutex()
36
+ this._achanged = this.a.on('change', d => this._mux(() => {
37
+ const tres = this.t.applyA(d)
38
+ if (tres.a) {
39
+ a.update(tres.a)
40
+ }
41
+ if (tres.b) {
42
+ b.update(tres.b)
43
+ }
44
+ }))
45
+ this._bchanged = this.b.on('change', d => this._mux(() => {
46
+ const tres = this.t.applyB(d)
47
+ if (tres.b) {
48
+ this.b.update(tres.b)
49
+ }
50
+ if (tres.a) {
51
+ a.update(tres.a)
52
+ }
53
+ }))
54
+ }
55
+
56
+ destroy = () => {
57
+ this.a.off('destroy', this.destroy)
58
+ this.b.off('destroy', this.destroy)
59
+ this.a.off('change', this._achanged)
60
+ this.b.off('change', this._bchanged)
61
+ }
62
+ }
63
+
64
+ /**
65
+ * Abstract Interface for a delta-based Replicated Data Type.
66
+ *
67
+ * @template {delta.AbstractDelta} Delta
68
+ * @typedef {ObservableV2<{ 'change': (delta: Delta) => void, 'destroy': (rdt:RDT<Delta>)=>void }> & { update: (delta: Delta) => any, destroy: () => void }} RDT
69
+ */
70
+
71
+ /**
72
+ * @template {delta.AbstractDelta} DeltaA
73
+ * @template {dt.Template<any,DeltaA,any>} Transformer
74
+ * @param {RDT<DeltaA>} a
75
+ * @param {RDT<Transformer extends dt.Template<any,DeltaA,infer DeltaB> ? DeltaB : never>} b
76
+ * @param {dt.Template<any,DeltaA,any>} template
77
+ */
78
+ export const bind = (a, b, template) => new Binding(a, b, template)
79
+
80
+ /**
81
+ * @template {delta.AbstractDelta} Delta
82
+ * @implements RDT<Delta>
83
+ * @extends {ObservableV2<{ change: (delta: Delta) => void, 'destroy': (rdt:DeltaRDT<Delta>)=>void }>}
84
+ */
85
+ class DeltaRDT extends ObservableV2 {
86
+ /**
87
+ * @param {Schema<Delta>} $delta
88
+ */
89
+ constructor ($delta) {
90
+ super()
91
+ this.$delta = $delta
92
+ /**
93
+ * @type {Delta?}
94
+ */
95
+ this.state = null
96
+ this._mux = mux.createMutex()
97
+ }
98
+
99
+ /**
100
+ * @param {Delta} delta
101
+ */
102
+ update = delta => delta.isEmpty() || this._mux(() => {
103
+ if (this.state != null) {
104
+ this.state.apply(delta)
105
+ } else {
106
+ this.state = delta
107
+ }
108
+ this.emit('change', [delta])
109
+ })
110
+
111
+ destroy () {
112
+ this.emit('destroy', [this])
113
+ super.destroy()
114
+ }
115
+ }
116
+
117
+ /**
118
+ * @template {delta.AbstractDelta} Delta
119
+ * @param {Schema<Delta>} $delta
120
+ */
121
+ export const deltaRDT = $delta => new DeltaRDT($delta)
122
+
123
+ /**
124
+ * @param {Node} domNode
125
+ */
126
+ const domToDelta = domNode => {
127
+ if (dom.$element.check(domNode)) {
128
+ const d = delta.node(domNode.nodeName.toLowerCase())
129
+ for (let i = 0; i < domNode.attributes.length; i++) {
130
+ const attr = /** @type {Attr} */ (domNode.attributes.item(i))
131
+ d.attributes.set(attr.nodeName, attr.value)
132
+ }
133
+ domNode.childNodes.forEach(child => {
134
+ d.children.insert(dom.$text.check(child) ? child.textContent : [domToDelta(child)])
135
+ })
136
+ return d
137
+ }
138
+ error.unexpectedCase()
139
+ }
140
+
141
+ /**
142
+ * @param {DomDelta} d
143
+ */
144
+ const deltaToDom = d => {
145
+ if (delta.$nodeAny.check(d)) {
146
+ const n = dom.element(d.name)
147
+ d.attributes.forEach(change => {
148
+ if (delta.$insertOp.check(change)) {
149
+ n.setAttribute(change.key, change.value)
150
+ }
151
+ })
152
+ d.children.forEach(child => {
153
+ if (delta.$insertOp.check(child)) {
154
+ n.append(...child.insert.map(deltaToDom))
155
+ } else if (delta.$textOp.check(child)) {
156
+ n.append(dom.text(child.insert))
157
+ }
158
+ })
159
+ return n
160
+ }
161
+ error.unexpectedCase()
162
+ }
163
+
164
+ /**
165
+ * @param {Element} el
166
+ * @param {delta.Node<string,any,any,any>} d
167
+ */
168
+ const applyDeltaToDom = (el, d) => {
169
+ d.attributes.forEach(change => {
170
+ if (delta.$deleteOp.check(change)) {
171
+ el.removeAttribute(change.key)
172
+ } else {
173
+ el.setAttribute(change.key, change.value)
174
+ }
175
+ })
176
+ let childIndex = 0
177
+ let childOffset = 0
178
+ d.children.forEach(change => {
179
+ let child = el.childNodes[childIndex] || null
180
+ if (delta.$deleteOp.check(change)) {
181
+ let len = change.length
182
+ while (len > 0) {
183
+ if (dom.$element.check(child)) {
184
+ child.remove()
185
+ len--
186
+ } else if (dom.$text.check(child)) {
187
+ const childLen = child.length
188
+ if (childOffset === 0 && childLen <= len) {
189
+ child.remove()
190
+ len -= childLen
191
+ } else {
192
+ const spliceLen = math.min(len, childLen - childOffset)
193
+ child.deleteData(childOffset, spliceLen)
194
+ if (child.length <= childOffset) {
195
+ childOffset = 0
196
+ childIndex++
197
+ }
198
+ }
199
+ }
200
+ }
201
+ } else if (delta.$insertOp.check(change)) {
202
+ if (childOffset > 0) {
203
+ const tchild = dom.$text.cast(child)
204
+ child = tchild.splitText(childOffset)
205
+ childIndex++
206
+ childOffset = 0
207
+ }
208
+ el.insertBefore(dom.fragment(change.insert.map(deltaToDom)), child)
209
+ } else if (delta.$modifyOp.check(change)) {
210
+ applyDeltaToDom(dom.$element.cast(child), change.modify)
211
+ } else if (delta.$textOp.check(change)) {
212
+ el.insertBefore(dom.text(change.insert), child)
213
+ } else {
214
+ error.unexpectedCase()
215
+ }
216
+ })
217
+ }
218
+
219
+ export const $domDelta = delta.$node(s.$string, s.$record(s.$string, s.$string), s.$never, { recursive: true, withText: true })
220
+
221
+ /**
222
+ * @param {Element} observedNode
223
+ * @param {MutationRecord[]} mutations
224
+ * @param {any} origin assign this origin to the generated delta
225
+ */
226
+ const _mutationsToDelta = (observedNode, mutations, origin) => {
227
+ /**
228
+ * @typedef {{ removedBefore: Map<Node?,number>, added: Set<Node>, modified: number, d: delta.Node }} ChangedNodeInfo
229
+ */
230
+ /**
231
+ * Compute all deltas without recursion.
232
+ *
233
+ * 1. mark all changed parents in parentsChanged
234
+ * 2. fill out necessary information for each changed parent ()
235
+ */
236
+ //
237
+ /**
238
+ * @type {Map<Node,ChangedNodeInfo>}
239
+ */
240
+ const changedNodes = map.create()
241
+ /**
242
+ * @param {Node} node
243
+ * @return {ChangedNodeInfo}
244
+ */
245
+ const getChangedNodeInfo = node => map.setIfUndefined(changedNodes, node, () => ({ removedBefore: map.create(), added: set.create(), modified: 0, d: delta.node(node.nodeName.toLowerCase()) }))
246
+ const observedNodeInfo = getChangedNodeInfo(observedNode)
247
+ mutations.forEach(mutation => {
248
+ const target = /** @type {HTMLElement} */ (mutation.target)
249
+ const parent = target.parentNode
250
+ const attrName = /** @type {string} */ (mutation.attributeName)
251
+ const newVal = target.getAttribute(attrName)
252
+ const info = getChangedNodeInfo(target)
253
+ const d = info.d
254
+ // go up the tree and mark that a child has been modified
255
+ for (let changedParent = parent; changedParent != null && getChangedNodeInfo(changedParent).modified++ > 1 && changedParent !== observedNode; changedParent = changedParent.parentNode) {
256
+ // nop
257
+ }
258
+ switch (mutation.type) {
259
+ case 'attributes': {
260
+ const attrs = /** @type {delta.Node<any,any,any>} */ (d).attributes
261
+ if (newVal == null) {
262
+ attrs.delete(attrName)
263
+ } else {
264
+ attrs.set(/** @type {string} */ (attrName), newVal)
265
+ }
266
+ break
267
+ }
268
+ case 'characterData': {
269
+ error.methodUnimplemented()
270
+ break
271
+ }
272
+ case 'childList': {
273
+ const targetInfo = getChangedNodeInfo(target)
274
+ mutation.addedNodes.forEach(node => {
275
+ targetInfo.added.add(node)
276
+ })
277
+ const removed = mutation.removedNodes.length
278
+ if (removed > 0) {
279
+ // @todo this can't work because next can be null
280
+ targetInfo.removedBefore.set(mutation.nextSibling, removed)
281
+ }
282
+ break
283
+ }
284
+ }
285
+ })
286
+ changedNodes.forEach((info, node) => {
287
+ const numOfChildChanges = info.modified + info.removedBefore.size + info.added.size
288
+ const d = /** @type {delta.Node<any,any,any>} */ (info.d)
289
+ if (numOfChildChanges > 0) {
290
+ node.childNodes.forEach(nchild => {
291
+ if (info.removedBefore.has(nchild)) { // can happen separately
292
+ d.children.delete(/** @type {number} */ (info.removedBefore.get(nchild)))
293
+ }
294
+ if (info.added.has(nchild)) {
295
+ d.children.insert(dom.$text.check(nchild) ? nchild.textContent : [domToDelta(nchild)])
296
+ } else if (changedNodes.has(nchild)) {
297
+ d.children.modify(getChangedNodeInfo(nchild).d)
298
+ }
299
+ })
300
+ // remove items to the end, if necessary
301
+ d.children.delete(info.removedBefore.get(null) ?? 0)
302
+ }
303
+ d.done()
304
+ })
305
+ observedNodeInfo.d.origin = origin
306
+ return observedNodeInfo.d
307
+ }
308
+
309
+ /**
310
+ * @typedef {delta.RecursiveNode<string, { [key:string]: string }, never, true>} DomDelta
311
+ */
312
+
313
+ /**
314
+ * @template {DomDelta} [D=DomDelta]
315
+ * @implements RDT<D>
316
+ * @extends {ObservableV2<{ change: (delta: D)=>void, destroy: (rdt:DomRDT<D>)=>void }>}>}
317
+ */
318
+ class DomRDT extends ObservableV2 {
319
+ /**
320
+ * @param {Element} observedNode
321
+ */
322
+ constructor (observedNode) {
323
+ super()
324
+ this.observedNode = observedNode
325
+ this._mux = mux.createMutex()
326
+ this.observer = new MutationObserver(this._mutationHandler)
327
+ this.observer.observe(observedNode, {
328
+ subtree: true,
329
+ childList: true,
330
+ attributes: true,
331
+ characterDataOldValue: true
332
+ })
333
+ }
334
+
335
+ /**
336
+ * @param {MutationRecord[]} mutations
337
+ */
338
+ _mutationHandler = mutations =>
339
+ mutations.length > 0 && this._mux(() => {
340
+ this.emit('change', [/** @type {D} */(_mutationsToDelta(this.observedNode, mutations, this))])
341
+ })
342
+
343
+ /**
344
+ * @param {D} delta
345
+ */
346
+ update = delta => {
347
+ if (delta.origin !== this) {
348
+ // @todo the retrieved changes must be transformed agains the updated changes. need a proper
349
+ // transaction system
350
+ this._mutationHandler(this.observer.takeRecords())
351
+ this._mux(() => {
352
+ applyDeltaToDom(this.observedNode, delta)
353
+ const mutations = this.observer.takeRecords()
354
+ this.emit('change', [/** @type {D} */(_mutationsToDelta(this.observedNode, mutations, delta.origin))])
355
+ })
356
+ }
357
+ }
358
+
359
+ destroy () {
360
+ this.emit('destroy', [this])
361
+ super.destroy()
362
+ this.observer.disconnect()
363
+ }
364
+ }
365
+
366
+ /**
367
+ * @param {Element} dom
368
+ */
369
+ export const domRDT = dom => new DomRDT(dom)
@@ -0,0 +1,5 @@
1
+ export function testBinding(): void;
2
+ export function testDomBindingBasics(): void;
3
+ export function testDomBindingBackAndForth(): void;
4
+ export function testDataToDom(): void;
5
+ //# sourceMappingURL=binding.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"binding.test.d.ts","sourceRoot":"","sources":["binding.test.js"],"names":[],"mappings":"AAQO,oCAcN;AAEM,6CAcN;AAEM,mDAkCN;AAEM,sCAiBN"}