@voidhash/mimic 1.0.0-beta.14 → 1.0.0-beta.16

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.
@@ -1,5 +1,5 @@
1
1
 
2
- > @voidhash/mimic@1.0.0-beta.14 build /home/runner/work/mimic/mimic/packages/mimic
2
+ > @voidhash/mimic@1.0.0-beta.16 build /home/runner/work/mimic/mimic/packages/mimic
3
3
  > tsdown
4
4
 
5
5
  ℹ tsdown v0.18.2 powered by rolldown v1.0.0-beta.55
@@ -12,18 +12,19 @@
12
12
  ℹ [CJS] dist/client/index.cjs  1.92 kB │ gzip: 0.42 kB
13
13
  ℹ [CJS] dist/server/index.cjs  0.67 kB │ gzip: 0.26 kB
14
14
  ℹ [CJS] dist/primitives/Tree.cjs 30.01 kB │ gzip: 4.99 kB
15
- ℹ [CJS] dist/client/ClientDocument.cjs 23.42 kB │ gzip: 5.12 kB
15
+ ℹ [CJS] dist/client/ClientDocument.cjs 24.61 kB │ gzip: 5.36 kB
16
16
  ℹ [CJS] dist/FractionalIndex.cjs 16.98 kB │ gzip: 3.39 kB
17
+ ℹ [CJS] dist/primitives/Struct.cjs 13.67 kB │ gzip: 2.98 kB
17
18
  ℹ [CJS] dist/utils/tree-helpers.cjs 13.42 kB │ gzip: 3.18 kB
18
19
  ℹ [CJS] dist/primitives/Array.cjs 12.23 kB │ gzip: 2.67 kB
19
20
  ℹ [CJS] dist/client/WebSocketTransport.cjs 10.98 kB │ gzip: 2.71 kB
20
- ℹ [CJS] dist/primitives/Struct.cjs 10.26 kB │ gzip: 2.34 kB
21
21
  ℹ [CJS] dist/primitives/Either.cjs  8.08 kB │ gzip: 2.06 kB
22
22
  ℹ [CJS] dist/client/Rebase.cjs  7.85 kB │ gzip: 1.76 kB
23
23
  ℹ [CJS] dist/primitives/Union.cjs  7.49 kB │ gzip: 1.78 kB
24
24
  ℹ [CJS] dist/EffectSchema.cjs  6.75 kB │ gzip: 1.63 kB
25
- ℹ [CJS] dist/Document.cjs  5.30 kB │ gzip: 1.77 kB
25
+ ℹ [CJS] dist/Document.cjs  5.22 kB │ gzip: 1.73 kB
26
26
  ℹ [CJS] dist/primitives/String.cjs  5.05 kB │ gzip: 1.37 kB
27
+ ℹ [CJS] dist/primitives/shared.cjs  5.05 kB │ gzip: 1.62 kB
27
28
  ℹ [CJS] dist/client/errors.cjs  4.80 kB │ gzip: 0.97 kB
28
29
  ℹ [CJS] dist/primitives/Number.cjs  4.63 kB │ gzip: 1.23 kB
29
30
  ℹ [CJS] dist/OperationPath.cjs  4.24 kB │ gzip: 1.19 kB
@@ -31,11 +32,10 @@
31
32
  ℹ [CJS] dist/primitives/Literal.cjs  3.91 kB │ gzip: 1.07 kB
32
33
  ℹ [CJS] dist/server/ServerDocument.cjs  3.74 kB │ gzip: 1.16 kB
33
34
  ℹ [CJS] dist/client/StateMonitor.cjs  3.71 kB │ gzip: 1.27 kB
34
- ℹ [CJS] dist/primitives/shared.cjs  3.69 kB │ gzip: 1.25 kB
35
35
  ℹ [CJS] dist/server/errors.cjs  3.29 kB │ gzip: 0.70 kB
36
36
  ℹ [CJS] dist/primitives/TreeNode.cjs  2.67 kB │ gzip: 0.92 kB
37
+ ℹ [CJS] dist/Primitive.cjs  2.41 kB │ gzip: 0.61 kB
37
38
  ℹ [CJS] dist/Presence.cjs  2.36 kB │ gzip: 0.87 kB
38
- ℹ [CJS] dist/Primitive.cjs  2.34 kB │ gzip: 0.59 kB
39
39
  ℹ [CJS] dist/primitives/Lazy.cjs  1.81 kB │ gzip: 0.57 kB
40
40
  ℹ [CJS] dist/Operation.cjs  1.75 kB │ gzip: 0.68 kB
41
41
  ℹ [CJS] dist/Transaction.cjs  1.66 kB │ gzip: 0.68 kB
@@ -52,14 +52,14 @@
52
52
  ℹ [CJS] dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/objectWithoutPropertiesLoose.cjs  0.37 kB │ gzip: 0.24 kB
53
53
  ℹ [CJS] dist/client/Transport.cjs  0.21 kB │ gzip: 0.16 kB
54
54
  ℹ [CJS] dist/Transform.cjs  0.20 kB │ gzip: 0.16 kB
55
- ℹ [CJS] 44 files, total: 219.61 kB
55
+ ℹ [CJS] 44 files, total: 225.56 kB
56
56
  ℹ [CJS] dist/primitives/Tree.d.cts.map  6.90 kB │ gzip: 2.60 kB
57
- ℹ [CJS] dist/primitives/Struct.d.cts.map  4.62 kB │ gzip: 1.94 kB
57
+ ℹ [CJS] dist/primitives/Struct.d.cts.map  5.26 kB │ gzip: 2.17 kB
58
58
  ℹ [CJS] dist/utils/tree-helpers.d.cts.map  3.61 kB │ gzip: 1.31 kB
59
59
  ℹ [CJS] dist/primitives/Array.d.cts.map  3.27 kB │ gzip: 1.36 kB
60
60
  ℹ [CJS] dist/primitives/Union.d.cts.map  3.16 kB │ gzip: 1.38 kB
61
61
  ℹ [CJS] dist/primitives/Either.d.cts.map  3.12 kB │ gzip: 1.26 kB
62
- ℹ [CJS] dist/primitives/shared.d.cts.map  2.28 kB │ gzip: 0.91 kB
62
+ ℹ [CJS] dist/primitives/shared.d.cts.map  2.31 kB │ gzip: 0.92 kB
63
63
  ℹ [CJS] dist/primitives/TreeNode.d.cts.map  2.27 kB │ gzip: 1.01 kB
64
64
  ℹ [CJS] dist/primitives/String.d.cts.map  2.26 kB │ gzip: 1.00 kB
65
65
  ℹ [CJS] dist/primitives/Literal.d.cts.map  2.16 kB │ gzip: 0.99 kB
@@ -90,17 +90,17 @@
90
90
  ℹ [CJS] dist/server/index.d.cts  0.68 kB │ gzip: 0.24 kB
91
91
  ℹ [CJS] dist/primitives/Tree.d.cts 13.50 kB │ gzip: 3.50 kB
92
92
  ℹ [CJS] dist/utils/tree-helpers.d.cts 12.18 kB │ gzip: 2.52 kB
93
+ ℹ [CJS] dist/primitives/Struct.d.cts  8.04 kB │ gzip: 2.06 kB
93
94
  ℹ [CJS] dist/client/Transport.d.cts  7.30 kB │ gzip: 1.84 kB
95
+ ℹ [CJS] dist/primitives/shared.d.cts  6.99 kB │ gzip: 2.12 kB
94
96
  ℹ [CJS] dist/client/ClientDocument.d.cts  6.99 kB │ gzip: 2.01 kB
95
- ℹ [CJS] dist/primitives/Struct.d.cts  6.93 kB │ gzip: 1.84 kB
96
- ℹ [CJS] dist/primitives/shared.d.cts  6.89 kB │ gzip: 2.09 kB
97
97
  ℹ [CJS] dist/server/ServerDocument.d.cts  5.48 kB │ gzip: 1.76 kB
98
98
  ℹ [CJS] dist/primitives/Either.d.cts  5.44 kB │ gzip: 1.54 kB
99
99
  ℹ [CJS] dist/primitives/Array.d.cts  5.01 kB │ gzip: 1.44 kB
100
100
  ℹ [CJS] dist/client/Rebase.d.cts  4.88 kB │ gzip: 1.14 kB
101
101
  ℹ [CJS] dist/primitives/Union.d.cts  4.58 kB │ gzip: 1.26 kB
102
102
  ℹ [CJS] dist/primitives/TreeNode.d.cts  4.28 kB │ gzip: 1.29 kB
103
- ℹ [CJS] dist/Primitive.d.cts  3.79 kB │ gzip: 0.82 kB
103
+ ℹ [CJS] dist/Primitive.d.cts  3.94 kB │ gzip: 0.84 kB
104
104
  ℹ [CJS] dist/client/StateMonitor.d.cts  3.33 kB │ gzip: 1.07 kB
105
105
  ℹ [CJS] dist/EffectSchema.d.cts  3.20 kB │ gzip: 0.92 kB
106
106
  ℹ [CJS] dist/primitives/String.d.cts  3.08 kB │ gzip: 0.85 kB
@@ -120,34 +120,34 @@
120
120
  ℹ [CJS] dist/client/WebSocketTransport.d.cts  1.22 kB │ gzip: 0.55 kB
121
121
  ℹ [CJS] dist/OperationDefinition.d.cts  1.21 kB │ gzip: 0.40 kB
122
122
  ℹ [CJS] dist/Transform.d.cts  0.48 kB │ gzip: 0.26 kB
123
- ℹ [CJS] 67 files, total: 185.94 kB
124
- ✔ Build complete in 6156ms
123
+ ℹ [CJS] 67 files, total: 187.98 kB
124
+ ✔ Build complete in 6056ms
125
125
  ℹ [ESM] dist/index.mjs  1.13 kB │ gzip: 0.29 kB
126
126
  ℹ [ESM] dist/client/index.mjs  0.99 kB │ gzip: 0.28 kB
127
127
  ℹ [ESM] dist/server/index.mjs  0.41 kB │ gzip: 0.17 kB
128
128
  ℹ [ESM] dist/primitives/Tree.mjs.map 68.20 kB │ gzip: 12.85 kB
129
- ℹ [ESM] dist/client/ClientDocument.mjs.map 54.81 kB │ gzip: 12.64 kB
129
+ ℹ [ESM] dist/client/ClientDocument.mjs.map 56.58 kB │ gzip: 12.99 kB
130
130
  ℹ [ESM] dist/FractionalIndex.mjs.map 52.10 kB │ gzip: 10.05 kB
131
+ ℹ [ESM] dist/primitives/Struct.mjs.map 32.95 kB │ gzip: 7.96 kB
131
132
  ℹ [ESM] dist/primitives/Tree.mjs 28.14 kB │ gzip: 4.95 kB
132
133
  ℹ [ESM] dist/primitives/Array.mjs.map 26.06 kB │ gzip: 6.49 kB
133
- ℹ [ESM] dist/primitives/Struct.mjs.map 25.49 kB │ gzip: 6.51 kB
134
134
  ℹ [ESM] dist/utils/tree-helpers.mjs.map 24.70 kB │ gzip: 5.20 kB
135
+ ℹ [ESM] dist/client/ClientDocument.mjs 24.17 kB │ gzip: 5.32 kB
135
136
  ℹ [ESM] dist/client/WebSocketTransport.mjs.map 23.44 kB │ gzip: 5.75 kB
136
- ℹ [ESM] dist/client/ClientDocument.mjs 22.98 kB │ gzip: 5.08 kB
137
137
  ℹ [ESM] dist/primitives/Union.mjs.map 18.59 kB │ gzip: 4.65 kB
138
138
  ℹ [ESM] dist/primitives/Either.mjs.map 16.82 kB │ gzip: 4.14 kB
139
139
  ℹ [ESM] dist/EffectSchema.mjs.map 16.73 kB │ gzip: 3.54 kB
140
140
  ℹ [ESM] dist/FractionalIndex.mjs 16.49 kB │ gzip: 3.36 kB
141
+ ℹ [ESM] dist/primitives/shared.mjs.map 15.92 kB │ gzip: 4.54 kB
141
142
  ℹ [ESM] dist/client/Rebase.mjs.map 14.15 kB │ gzip: 3.21 kB
142
143
  ℹ [ESM] dist/server/ServerDocument.mjs.map 14.09 kB │ gzip: 3.86 kB
144
+ ℹ [ESM] dist/Document.mjs.map 13.50 kB │ gzip: 4.16 kB
143
145
  ℹ [ESM] dist/utils/tree-helpers.mjs 13.31 kB │ gzip: 3.15 kB
144
- ℹ [ESM] dist/Document.mjs.map 13.29 kB │ gzip: 4.11 kB
145
- ℹ [ESM] dist/primitives/shared.mjs.map 13.14 kB │ gzip: 3.69 kB
146
+ ℹ [ESM] dist/primitives/Struct.mjs 12.60 kB │ gzip: 2.95 kB
146
147
  ℹ [ESM] dist/primitives/Array.mjs 11.09 kB │ gzip: 2.65 kB
147
148
  ℹ [ESM] dist/client/WebSocketTransport.mjs 10.81 kB │ gzip: 2.68 kB
148
149
  ℹ [ESM] dist/client/StateMonitor.mjs.map 10.39 kB │ gzip: 3.04 kB
149
150
  ℹ [ESM] dist/primitives/String.mjs.map  9.73 kB │ gzip: 2.71 kB
150
- ℹ [ESM] dist/primitives/Struct.mjs  9.32 kB │ gzip: 2.32 kB
151
151
  ℹ [ESM] dist/client/Transport.mjs.map  9.09 kB │ gzip: 1.86 kB
152
152
  ℹ [ESM] dist/primitives/Number.mjs.map  8.75 kB │ gzip: 2.43 kB
153
153
  ℹ [ESM] dist/client/Rebase.mjs  7.61 kB │ gzip: 1.73 kB
@@ -160,8 +160,9 @@
160
160
  ℹ [ESM] dist/EffectSchema.mjs  6.47 kB │ gzip: 1.59 kB
161
161
  ℹ [ESM] dist/primitives/TreeNode.mjs.map  6.47 kB │ gzip: 2.05 kB
162
162
  ℹ [ESM] dist/client/errors.mjs.map  5.68 kB │ gzip: 1.37 kB
163
- ℹ [ESM] dist/Document.mjs  5.03 kB │ gzip: 1.74 kB
164
- ℹ [ESM] dist/primitives/Struct.d.mts.map  4.63 kB │ gzip: 1.96 kB
163
+ ℹ [ESM] dist/primitives/Struct.d.mts.map  5.30 kB │ gzip: 2.21 kB
164
+ ℹ [ESM] dist/Document.mjs  4.94 kB │ gzip: 1.69 kB
165
+ ℹ [ESM] dist/primitives/shared.mjs  4.88 kB │ gzip: 1.62 kB
165
166
  ℹ [ESM] dist/primitives/Lazy.mjs.map  4.59 kB │ gzip: 1.40 kB
166
167
  ℹ [ESM] dist/Presence.mjs.map  4.56 kB │ gzip: 1.30 kB
167
168
  ℹ [ESM] dist/primitives/String.mjs  4.44 kB │ gzip: 1.35 kB
@@ -173,7 +174,6 @@
173
174
  ℹ [ESM] dist/utils/tree-helpers.d.mts.map  3.61 kB │ gzip: 1.31 kB
174
175
  ℹ [ESM] dist/client/StateMonitor.mjs  3.60 kB │ gzip: 1.23 kB
175
176
  ℹ [ESM] dist/server/ServerDocument.mjs  3.56 kB │ gzip: 1.13 kB
176
- ℹ [ESM] dist/primitives/shared.mjs  3.55 kB │ gzip: 1.25 kB
177
177
  ℹ [ESM] dist/primitives/Boolean.mjs  3.43 kB │ gzip: 1.05 kB
178
178
  ℹ [ESM] dist/primitives/Literal.mjs  3.33 kB │ gzip: 1.05 kB
179
179
  ℹ [ESM] dist/primitives/Array.d.mts.map  3.26 kB │ gzip: 1.35 kB
@@ -185,12 +185,12 @@
185
185
  ℹ [ESM] dist/primitives/TreeNode.d.mts.map  2.45 kB │ gzip: 1.07 kB
186
186
  ℹ [ESM] dist/ProxyEnvironment.mjs.map  2.42 kB │ gzip: 0.93 kB
187
187
  ℹ [ESM] dist/primitives/TreeNode.mjs  2.42 kB │ gzip: 0.93 kB
188
- ℹ [ESM] dist/primitives/shared.d.mts.map  2.28 kB │ gzip: 0.91 kB
188
+ ℹ [ESM] dist/primitives/shared.d.mts.map  2.31 kB │ gzip: 0.92 kB
189
189
  ℹ [ESM] dist/primitives/String.d.mts.map  2.26 kB │ gzip: 1.00 kB
190
190
  ℹ [ESM] dist/primitives/Literal.d.mts.map  2.16 kB │ gzip: 0.99 kB
191
191
  ℹ [ESM] dist/Presence.mjs  2.15 kB │ gzip: 0.80 kB
192
192
  ℹ [ESM] dist/primitives/Number.d.mts.map  2.13 kB │ gzip: 0.95 kB
193
- ℹ [ESM] dist/Primitive.mjs  1.98 kB │ gzip: 0.57 kB
193
+ ℹ [ESM] dist/Primitive.mjs  2.06 kB │ gzip: 0.59 kB
194
194
  ℹ [ESM] dist/client/ClientDocument.d.mts.map  1.85 kB │ gzip: 0.79 kB
195
195
  ℹ [ESM] dist/primitives/Boolean.d.mts.map  1.76 kB │ gzip: 0.81 kB
196
196
  ℹ [ESM] dist/primitives/Lazy.mjs  1.57 kB │ gzip: 0.58 kB
@@ -236,17 +236,17 @@
236
236
  ℹ [ESM] dist/server/index.d.mts  0.68 kB │ gzip: 0.24 kB
237
237
  ℹ [ESM] dist/primitives/Tree.d.mts 13.50 kB │ gzip: 3.50 kB
238
238
  ℹ [ESM] dist/utils/tree-helpers.d.mts 12.18 kB │ gzip: 2.52 kB
239
+ ℹ [ESM] dist/primitives/Struct.d.mts  8.07 kB │ gzip: 2.07 kB
239
240
  ℹ [ESM] dist/client/Transport.d.mts  7.30 kB │ gzip: 1.84 kB
240
241
  ℹ [ESM] dist/client/ClientDocument.d.mts  7.02 kB │ gzip: 2.02 kB
241
- ℹ [ESM] dist/primitives/Struct.d.mts  6.96 kB │ gzip: 1.85 kB
242
- ℹ [ESM] dist/primitives/shared.d.mts  6.89 kB │ gzip: 2.09 kB
242
+ ℹ [ESM] dist/primitives/shared.d.mts  6.99 kB │ gzip: 2.12 kB
243
243
  ℹ [ESM] dist/server/ServerDocument.d.mts  5.50 kB │ gzip: 1.76 kB
244
244
  ℹ [ESM] dist/primitives/Either.d.mts  5.44 kB │ gzip: 1.54 kB
245
245
  ℹ [ESM] dist/primitives/Array.d.mts  5.04 kB │ gzip: 1.45 kB
246
246
  ℹ [ESM] dist/client/Rebase.d.mts  4.91 kB │ gzip: 1.15 kB
247
247
  ℹ [ESM] dist/primitives/Union.d.mts  4.61 kB │ gzip: 1.27 kB
248
248
  ℹ [ESM] dist/primitives/TreeNode.d.mts  4.31 kB │ gzip: 1.29 kB
249
- ℹ [ESM] dist/Primitive.d.mts  3.79 kB │ gzip: 0.82 kB
249
+ ℹ [ESM] dist/Primitive.d.mts  3.94 kB │ gzip: 0.84 kB
250
250
  ℹ [ESM] dist/client/StateMonitor.d.mts  3.33 kB │ gzip: 1.07 kB
251
251
  ℹ [ESM] dist/EffectSchema.d.mts  3.20 kB │ gzip: 0.92 kB
252
252
  ℹ [ESM] dist/primitives/String.d.mts  3.08 kB │ gzip: 0.85 kB
@@ -266,5 +266,5 @@
266
266
  ℹ [ESM] dist/client/WebSocketTransport.d.mts  1.22 kB │ gzip: 0.55 kB
267
267
  ℹ [ESM] dist/OperationDefinition.d.mts  1.21 kB │ gzip: 0.40 kB
268
268
  ℹ [ESM] dist/Transform.d.mts  0.48 kB │ gzip: 0.26 kB
269
- ℹ [ESM] 144 files, total: 870.36 kB
270
- ✔ Build complete in 6213ms
269
+ ℹ [ESM] 144 files, total: 890.45 kB
270
+ ✔ Build complete in 6139ms
package/dist/Document.cjs CHANGED
@@ -35,9 +35,6 @@ var OperationError = class extends Error {
35
35
  */
36
36
  const make = (schema, options) => {
37
37
  let _state = (options === null || options === void 0 ? void 0 : options.initialState) !== void 0 ? options.initialState : (options === null || options === void 0 ? void 0 : options.initial) !== void 0 ? schema._internal.convertSetInputToState ? schema._internal.convertSetInputToState(options.initial) : options.initial : schema._internal.getInitialState();
38
- /**
39
- * An ops buffer that maintains a dedup index for O(1) lookups by path:kind.
40
- */
41
38
  const makeOpsBuffer = () => {
42
39
  let ops = [];
43
40
  let index = /* @__PURE__ */ new Map();
@@ -1 +1 @@
1
- {"version":3,"file":"Document.d.mts","names":[],"sources":["../src/Document.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;cAaa,sBAAA,SAA+B,KAAA;;;;;;;cAW/B,cAAA,SAAuB,KAAA;EAXvB,SAAA,IAAA,GAAA,gBAAuB;EAWvB,WAAA,CAAA,OAAe,EAAA,MAAA;AAe5B;;;;AAKiB,UALA,QAKA,CAAA,gBALyB,YAKzB,CAAA,CAAA;EAGa;EAArB,SAAA,MAAA,EANU,OAMV;EAQ+B;EAAxB,SAAA,IAAA,EAXC,UAWD,CAXsB,OAWtB,CAAA;EAQiC;EAArB,GAAA,EAAA,EAhBnB,UAgBmB,CAhBE,OAgBF,CAAA,GAAA,SAAA;EAAkC;;;;;;EAkB7C,UAAA,EAAA,EA1BD,aA0BgB,CA1BQ,OA0BR,CAAA;EAAiB;;;;;;EAkBpC,WA8NZ,CAAA,CAAA,CAAA,CAAA,EAAA,EAAA,CAAA,IAAA,EAlQ2B,UAkQ3B,CAlQgD,OAkQhD,CAAA,EAAA,GAlQ6D,CAkQ7D,CAAA,EAlQiE,CAkQjE;EA9NoC;;;;EAGzB,KAAA,CAAA,GAAA,EAjCC,aAiCD,CAjCe,SAiCf,CAAA,GAAA,EAAA,GAAA,EAAA,GAAA,CAAA,CAAA,CAAA,EAAA,IAAA;EAAT;;;WA5BQ;;UAOM,gCAAgC;;qBAE5B,cAAwB;;;;;;0BAMnB,WAAqB;;;;;cAUlC,uBAAwB,sBAC3B,mBACE,gBAAgB,aACzB,SAAS"}
1
+ {"version":3,"file":"Document.d.mts","names":[],"sources":["../src/Document.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;cAaa,sBAAA,SAA+B,KAAA;;;;;;;cAW/B,cAAA,SAAuB,KAAA;EAXvB,SAAA,IAAA,GAAA,gBAAuB;EAWvB,WAAA,CAAA,OAAe,EAAA,MAAA;AAe5B;;;;AAKiB,UALA,QAKA,CAAA,gBALyB,YAKzB,CAAA,CAAA;EAGa;EAArB,SAAA,MAAA,EANU,OAMV;EAQ+B;EAAxB,SAAA,IAAA,EAXC,UAWD,CAXsB,OAWtB,CAAA;EAQiC;EAArB,GAAA,EAAA,EAhBnB,UAgBmB,CAhBE,OAgBF,CAAA,GAAA,SAAA;EAAkC;;;;;;EAkB7C,UAAA,EAAA,EA1BD,aA0BgB,CA1BQ,OA0BR,CAAA;EAAiB;;;;;;EAkBpC,WAuOZ,CAAA,CAAA,CAAA,CAAA,EAAA,EAAA,CAAA,IAAA,EA3Q2B,UA2Q3B,CA3QgD,OA2QhD,CAAA,EAAA,GA3Q6D,CA2Q7D,CAAA,EA3QiE,CA2QjE;EAvOoC;;;;EAGzB,KAAA,CAAA,GAAA,EAjCC,aAiCD,CAjCe,SAiCf,CAAA,GAAA,EAAA,GAAA,EAAA,GAAA,CAAA,CAAA,CAAA,EAAA,IAAA;EAAT;;;WA5BQ;;UAOM,gCAAgC;;qBAE5B,cAAwB;;;;;;0BAMnB,WAAqB;;;;;cAUlC,uBAAwB,sBAC3B,mBACE,gBAAgB,aACzB,SAAS"}
package/dist/Document.mjs CHANGED
@@ -35,9 +35,6 @@ var OperationError = class extends Error {
35
35
  */
36
36
  const make = (schema, options) => {
37
37
  let _state = (options === null || options === void 0 ? void 0 : options.initialState) !== void 0 ? options.initialState : (options === null || options === void 0 ? void 0 : options.initial) !== void 0 ? schema._internal.convertSetInputToState ? schema._internal.convertSetInputToState(options.initial) : options.initial : schema._internal.getInitialState();
38
- /**
39
- * An ops buffer that maintains a dedup index for O(1) lookups by path:kind.
40
- */
41
38
  const makeOpsBuffer = () => {
42
39
  let ops = [];
43
40
  let index = /* @__PURE__ */ new Map();
@@ -1 +1 @@
1
- {"version":3,"file":"Document.mjs","names":["_state: Primitive.InferState<TSchema> | undefined","ops: Operation.Operation<any, any, any>[]","OperationPath.encode","_txBaseState: Primitive.InferState<TSchema> | undefined","current: unknown","ProxyEnvironment.make","OperationPath.make","Transaction.make"],"sources":["../src/Document.ts"],"sourcesContent":["import * as Operation from \"./Operation\";\nimport * as OperationPath from \"./OperationPath\";\nimport * as ProxyEnvironment from \"./ProxyEnvironment\";\nimport * as Transaction from \"./Transaction\";\nimport type * as Primitive from \"./Primitive\";\n\n// =============================================================================\n// Document Errors\n// =============================================================================\n\n/**\n * Error thrown when attempting to start a nested transaction.\n */\nexport class NestedTransactionError extends Error {\n readonly _tag = \"NestedTransactionError\";\n constructor() {\n super(\"Nested transactions are not supported\");\n this.name = \"NestedTransactionError\";\n }\n}\n\n/**\n * Error thrown when an operation fails to apply.\n */\nexport class OperationError extends Error {\n readonly _tag = \"OperationError\";\n constructor(message: string) {\n super(message);\n this.name = \"OperationError\";\n }\n}\n\n// =============================================================================\n// Document Interface\n// =============================================================================\n\n/**\n * A Document manages state for a primitive-based schema with transaction support.\n */\nexport interface Document<TSchema extends Primitive.AnyPrimitive> {\n /** The schema defining this document's structure */\n readonly schema: TSchema;\n \n /** Root proxy for accessing and modifying document data */\n readonly root: Primitive.InferProxy<TSchema>;\n \n /** Returns the current document state */\n get(): Primitive.InferState<TSchema> | undefined;\n \n /**\n * Returns a readonly snapshot of the entire document state for rendering.\n * The snapshot is a type-safe, readonly structure where:\n * - Required fields and fields with defaults are guaranteed to be defined\n * - Optional fields may be undefined\n */\n toSnapshot(): Primitive.InferSnapshot<TSchema>;\n \n /**\n * Runs a function within a transaction.\n * All operations are collected and applied atomically.\n * If the function throws, all changes are rolled back.\n * @returns The return value of the function\n */\n transaction<R>(fn: (root: Primitive.InferProxy<TSchema>) => R): R;\n \n /**\n * Applies external operations (e.g., from server/peers) to the document.\n * These operations are NOT added to pending operations.\n */\n apply(ops: ReadonlyArray<Operation.Operation<any, any, any>>): void;\n \n /**\n * Returns pending local operations as a Transaction and clears the buffer.\n */\n flush(): Transaction.Transaction;\n}\n\n// =============================================================================\n// Document Options\n// =============================================================================\n\nexport interface DocumentOptions<TSchema extends Primitive.AnyPrimitive> {\n /** Initial value for the document (using set input format) */\n readonly initial?: Primitive.InferSetInput<TSchema>;\n /**\n * Raw initial state for the document (already in internal state format).\n * Use this when loading state from the server or storage.\n * Takes precedence over `initial` if both are provided.\n */\n readonly initialState?: Primitive.InferState<TSchema>;\n}\n\n// =============================================================================\n// Document Implementation\n// =============================================================================\n\n/**\n * Creates a new Document for the given schema.\n */\nexport const make = <TSchema extends Primitive.AnyPrimitive>(\n schema: TSchema,\n options?: DocumentOptions<TSchema>\n): Document<TSchema> => {\n // Internal state - determine initial state based on options\n // Priority: initialState (raw) > initial (needs conversion) > schema defaults\n let _state: Primitive.InferState<TSchema> | undefined =\n options?.initialState !== undefined\n ? options.initialState\n : options?.initial !== undefined\n ? (schema._internal.convertSetInputToState\n ? schema._internal.convertSetInputToState(options.initial)\n : options.initial as Primitive.InferState<TSchema>)\n : schema._internal.getInitialState();\n \n /**\n * An ops buffer that maintains a dedup index for O(1) lookups by path:kind.\n */\n const makeOpsBuffer = () => {\n let ops: Operation.Operation<any, any, any>[] = [];\n // Maps \"encodedPath:kind\" → array index for deduplicable ops\n let index = new Map<string, number>();\n\n const dedupKey = (op: Operation.Operation<any, any, any>): string =>\n `${OperationPath.encode(op.path)}:${String(op.kind)}`;\n\n return {\n push(op: Operation.Operation<any, any, any>): void {\n if (op.deduplicable) {\n const key = dedupKey(op);\n const existing = index.get(key);\n if (existing !== undefined) {\n // Remove old entry; shift indices above it down by 1\n ops.splice(existing, 1);\n // Rebuild affected index entries\n const newIndex = new Map<string, number>();\n for (const [k, v] of index) {\n if (k === key) continue;\n newIndex.set(k, v > existing ? v - 1 : v);\n }\n index = newIndex;\n }\n index.set(key, ops.length);\n }\n ops.push(op);\n },\n /** Drains all ops and resets the buffer. */\n drain(): Operation.Operation<any, any, any>[] {\n const result = ops;\n ops = [];\n index = new Map();\n return result;\n },\n /** Appends all ops from another buffer (used on tx commit). */\n mergeFrom(other: ReturnType<typeof makeOpsBuffer>): void {\n for (const op of other.toArray()) {\n this.push(op);\n }\n },\n toArray(): readonly Operation.Operation<any, any, any>[] {\n return ops;\n },\n reset(): void {\n ops = [];\n index = new Map();\n },\n };\n };\n\n // Pending operations buffer (local changes not yet flushed)\n const _pending = makeOpsBuffer();\n\n // Transaction state\n let _inTransaction = false;\n let _txOps = makeOpsBuffer();\n let _txBaseState: Primitive.InferState<TSchema> | undefined = undefined;\n\n /**\n * Gets state at the given path.\n */\n const getStateAtPath = (path: OperationPath.OperationPath): unknown => {\n const tokens = path.toTokens().filter(t => t !== \"\");\n \n if (tokens.length === 0) {\n return _state;\n }\n \n let current: unknown = _state;\n for (const token of tokens) {\n if (current === null || current === undefined) {\n return undefined;\n }\n \n if (typeof current === \"object\") {\n // Handle array entries (which have { id, pos, value } structure)\n if (Array.isArray(current)) {\n // Try to find by ID in array entries\n const entry = current.find((e: any) => e.id === token);\n if (entry) {\n current = entry.value;\n continue;\n }\n }\n \n // Handle regular object property access\n current = (current as Record<string, unknown>)[token];\n } else {\n return undefined;\n }\n }\n \n return current;\n };\n\n /**\n * Applies a single operation to the current state.\n */\n const applyOperation = (op: Operation.Operation<any, any, any>): void => {\n try {\n _state = schema._internal.applyOperation(_state, op);\n } catch (error) {\n if (error instanceof Error) {\n throw new OperationError(error.message);\n }\n throw new OperationError(String(error));\n }\n };\n\n /**\n * Handles an operation from a proxy.\n * In transaction mode: collects operations, applies to state immediately for subsequent reads.\n * Outside transaction mode: auto-wraps in a single-operation transaction.\n */\n const handleOperation = (op: Operation.Operation<any, any, any>): void => {\n if (_inTransaction) {\n // In transaction: collect op and apply immediately for subsequent reads\n _txOps.push(op);\n applyOperation(op);\n } else {\n // Not in transaction: auto-wrap in single-operation transaction\n const baseState = _state;\n try {\n applyOperation(op);\n _pending.push(op);\n } catch (error) {\n // Rollback on error\n _state = baseState;\n throw error;\n }\n }\n };\n\n /**\n * Creates a ProxyEnvironment for the document.\n */\n const createEnv = (): ProxyEnvironment.ProxyEnvironment => {\n return ProxyEnvironment.make({\n onOperation: handleOperation,\n getState: getStateAtPath,\n });\n };\n\n // Create the root proxy\n const env = createEnv();\n const rootProxy = schema._internal.createProxy(env, OperationPath.make(\"\")) as Primitive.InferProxy<TSchema>;\n\n // Document implementation\n const document: Document<TSchema> = {\n schema,\n root: rootProxy,\n \n get: (): Primitive.InferState<TSchema> | undefined => {\n return _state;\n },\n \n toSnapshot: (): Primitive.InferSnapshot<TSchema> => {\n return (rootProxy as { toSnapshot(): Primitive.InferSnapshot<TSchema> }).toSnapshot();\n },\n \n transaction: <R,>(fn: (root: Primitive.InferProxy<TSchema>) => R): R => {\n if (_inTransaction) {\n throw new NestedTransactionError();\n }\n \n // Start transaction\n _inTransaction = true;\n _txOps.reset();\n _txBaseState = _state;\n \n try {\n // Execute the transaction function\n const result = fn(rootProxy);\n \n // Commit: add transaction ops to pending\n _pending.mergeFrom(_txOps);\n \n return result;\n } catch (error) {\n // Rollback: restore base state\n _state = _txBaseState;\n throw error;\n } finally {\n // Clean up transaction state\n _inTransaction = false;\n _txOps.reset();\n _txBaseState = undefined;\n }\n },\n \n apply: (ops: ReadonlyArray<Operation.Operation<any, any, any>>): void => {\n for (const op of ops) {\n applyOperation(op);\n }\n },\n \n flush: (): Transaction.Transaction => {\n const tx = Transaction.make(_pending.drain());\n return tx;\n },\n };\n\n return document;\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"Document.mjs","names":["_state: Primitive.InferState<TSchema> | undefined","ops: BufferedOperation[]","OperationPath.encode","_txBaseState: Primitive.InferState<TSchema> | undefined","current: unknown","ProxyEnvironment.make","OperationPath.make","Transaction.make"],"sources":["../src/Document.ts"],"sourcesContent":["import * as Operation from \"./Operation\";\nimport * as OperationPath from \"./OperationPath\";\nimport * as ProxyEnvironment from \"./ProxyEnvironment\";\nimport * as Transaction from \"./Transaction\";\nimport type * as Primitive from \"./Primitive\";\n\n// =============================================================================\n// Document Errors\n// =============================================================================\n\n/**\n * Error thrown when attempting to start a nested transaction.\n */\nexport class NestedTransactionError extends Error {\n readonly _tag = \"NestedTransactionError\";\n constructor() {\n super(\"Nested transactions are not supported\");\n this.name = \"NestedTransactionError\";\n }\n}\n\n/**\n * Error thrown when an operation fails to apply.\n */\nexport class OperationError extends Error {\n readonly _tag = \"OperationError\";\n constructor(message: string) {\n super(message);\n this.name = \"OperationError\";\n }\n}\n\n// =============================================================================\n// Document Interface\n// =============================================================================\n\n/**\n * A Document manages state for a primitive-based schema with transaction support.\n */\nexport interface Document<TSchema extends Primitive.AnyPrimitive> {\n /** The schema defining this document's structure */\n readonly schema: TSchema;\n \n /** Root proxy for accessing and modifying document data */\n readonly root: Primitive.InferProxy<TSchema>;\n \n /** Returns the current document state */\n get(): Primitive.InferState<TSchema> | undefined;\n \n /**\n * Returns a readonly snapshot of the entire document state for rendering.\n * The snapshot is a type-safe, readonly structure where:\n * - Required fields and fields with defaults are guaranteed to be defined\n * - Optional fields may be undefined\n */\n toSnapshot(): Primitive.InferSnapshot<TSchema>;\n \n /**\n * Runs a function within a transaction.\n * All operations are collected and applied atomically.\n * If the function throws, all changes are rolled back.\n * @returns The return value of the function\n */\n transaction<R>(fn: (root: Primitive.InferProxy<TSchema>) => R): R;\n \n /**\n * Applies external operations (e.g., from server/peers) to the document.\n * These operations are NOT added to pending operations.\n */\n apply(ops: ReadonlyArray<Operation.Operation<any, any, any>>): void;\n \n /**\n * Returns pending local operations as a Transaction and clears the buffer.\n */\n flush(): Transaction.Transaction;\n}\n\n// =============================================================================\n// Document Options\n// =============================================================================\n\nexport interface DocumentOptions<TSchema extends Primitive.AnyPrimitive> {\n /** Initial value for the document (using set input format) */\n readonly initial?: Primitive.InferSetInput<TSchema>;\n /**\n * Raw initial state for the document (already in internal state format).\n * Use this when loading state from the server or storage.\n * Takes precedence over `initial` if both are provided.\n */\n readonly initialState?: Primitive.InferState<TSchema>;\n}\n\n// =============================================================================\n// Document Implementation\n// =============================================================================\n\n/**\n * Creates a new Document for the given schema.\n */\nexport const make = <TSchema extends Primitive.AnyPrimitive>(\n schema: TSchema,\n options?: DocumentOptions<TSchema>\n): Document<TSchema> => {\n // Internal state - determine initial state based on options\n // Priority: initialState (raw) > initial (needs conversion) > schema defaults\n let _state: Primitive.InferState<TSchema> | undefined =\n options?.initialState !== undefined\n ? options.initialState\n : options?.initial !== undefined\n ? (schema._internal.convertSetInputToState\n ? schema._internal.convertSetInputToState(options.initial)\n : options.initial as Primitive.InferState<TSchema>)\n : schema._internal.getInitialState();\n \n /**\n * An ops buffer that maintains a dedup index for O(1) lookups by path:kind.\n */\n type BufferedOperation = Operation.Operation<any, any, any>;\n interface OpsBuffer {\n push(op: BufferedOperation): void;\n drain(): BufferedOperation[];\n mergeFrom(other: OpsBuffer): void;\n toArray(): readonly BufferedOperation[];\n reset(): void;\n }\n\n const makeOpsBuffer = (): OpsBuffer => {\n let ops: BufferedOperation[] = [];\n // Maps \"encodedPath:kind\" → array index for deduplicable ops\n let index = new Map<string, number>();\n\n const dedupKey = (op: BufferedOperation): string =>\n `${OperationPath.encode(op.path)}:${String(op.kind)}`;\n\n return {\n push(op: Operation.Operation<any, any, any>): void {\n if (op.deduplicable) {\n const key = dedupKey(op);\n const existing = index.get(key);\n if (existing !== undefined) {\n // Remove old entry; shift indices above it down by 1\n ops.splice(existing, 1);\n // Rebuild affected index entries\n const newIndex = new Map<string, number>();\n for (const [k, v] of index) {\n if (k === key) continue;\n newIndex.set(k, v > existing ? v - 1 : v);\n }\n index = newIndex;\n }\n index.set(key, ops.length);\n }\n ops.push(op);\n },\n /** Drains all ops and resets the buffer. */\n drain(): Operation.Operation<any, any, any>[] {\n const result = ops;\n ops = [];\n index = new Map();\n return result;\n },\n /** Appends all ops from another buffer (used on tx commit). */\n mergeFrom(other: OpsBuffer): void {\n for (const op of other.toArray()) {\n this.push(op);\n }\n },\n toArray(): readonly Operation.Operation<any, any, any>[] {\n return ops;\n },\n reset(): void {\n ops = [];\n index = new Map();\n },\n };\n };\n\n // Pending operations buffer (local changes not yet flushed)\n const _pending = makeOpsBuffer();\n\n // Transaction state\n let _inTransaction = false;\n let _txOps = makeOpsBuffer();\n let _txBaseState: Primitive.InferState<TSchema> | undefined = undefined;\n\n /**\n * Gets state at the given path.\n */\n const getStateAtPath = (path: OperationPath.OperationPath): unknown => {\n const tokens = path.toTokens().filter(t => t !== \"\");\n \n if (tokens.length === 0) {\n return _state;\n }\n \n let current: unknown = _state;\n for (const token of tokens) {\n if (current === null || current === undefined) {\n return undefined;\n }\n \n if (typeof current === \"object\") {\n // Handle array entries (which have { id, pos, value } structure)\n if (Array.isArray(current)) {\n // Try to find by ID in array entries\n const entry = current.find((e: any) => e.id === token);\n if (entry) {\n current = entry.value;\n continue;\n }\n }\n \n // Handle regular object property access\n current = (current as Record<string, unknown>)[token];\n } else {\n return undefined;\n }\n }\n \n return current;\n };\n\n /**\n * Applies a single operation to the current state.\n */\n const applyOperation = (op: Operation.Operation<any, any, any>): void => {\n try {\n _state = schema._internal.applyOperation(_state, op);\n } catch (error) {\n if (error instanceof Error) {\n throw new OperationError(error.message);\n }\n throw new OperationError(String(error));\n }\n };\n\n /**\n * Handles an operation from a proxy.\n * In transaction mode: collects operations, applies to state immediately for subsequent reads.\n * Outside transaction mode: auto-wraps in a single-operation transaction.\n */\n const handleOperation = (op: Operation.Operation<any, any, any>): void => {\n if (_inTransaction) {\n // In transaction: collect op and apply immediately for subsequent reads\n _txOps.push(op);\n applyOperation(op);\n } else {\n // Not in transaction: auto-wrap in single-operation transaction\n const baseState = _state;\n try {\n applyOperation(op);\n _pending.push(op);\n } catch (error) {\n // Rollback on error\n _state = baseState;\n throw error;\n }\n }\n };\n\n /**\n * Creates a ProxyEnvironment for the document.\n */\n const createEnv = (): ProxyEnvironment.ProxyEnvironment => {\n return ProxyEnvironment.make({\n onOperation: handleOperation,\n getState: getStateAtPath,\n });\n };\n\n // Create the root proxy\n const env = createEnv();\n const rootProxy = schema._internal.createProxy(env, OperationPath.make(\"\")) as Primitive.InferProxy<TSchema>;\n\n // Document implementation\n const document: Document<TSchema> = {\n schema,\n root: rootProxy,\n \n get: (): Primitive.InferState<TSchema> | undefined => {\n return _state;\n },\n \n toSnapshot: (): Primitive.InferSnapshot<TSchema> => {\n return (rootProxy as { toSnapshot(): Primitive.InferSnapshot<TSchema> }).toSnapshot();\n },\n \n transaction: <R,>(fn: (root: Primitive.InferProxy<TSchema>) => R): R => {\n if (_inTransaction) {\n throw new NestedTransactionError();\n }\n \n // Start transaction\n _inTransaction = true;\n _txOps.reset();\n _txBaseState = _state;\n \n try {\n // Execute the transaction function\n const result = fn(rootProxy);\n \n // Commit: add transaction ops to pending\n _pending.mergeFrom(_txOps);\n \n return result;\n } catch (error) {\n // Rollback: restore base state\n _state = _txBaseState;\n throw error;\n } finally {\n // Clean up transaction state\n _inTransaction = false;\n _txOps.reset();\n _txBaseState = undefined;\n }\n },\n \n apply: (ops: ReadonlyArray<Operation.Operation<any, any, any>>): void => {\n for (const op of ops) {\n applyOperation(op);\n }\n },\n \n flush: (): Transaction.Transaction => {\n const tx = Transaction.make(_pending.drain());\n return tx;\n },\n };\n\n return document;\n};\n"],"mappings":";;;;;;;;;;;;;;;AAaA,IAAa,yBAAb,cAA4C,MAAM;CAEhD,cAAc;AACZ,QAAM,wCAAwC;wBAFvC,QAAO;AAGd,OAAK,OAAO;;;;;;AAOhB,IAAa,iBAAb,cAAoC,MAAM;CAExC,YAAY,SAAiB;AAC3B,QAAM,QAAQ;wBAFP,QAAO;AAGd,OAAK,OAAO;;;;;;AAuEhB,MAAa,QACX,QACA,YACsB;CAGtB,IAAIA,4DACF,QAAS,kBAAiB,SACtB,QAAQ,kEACR,QAAS,aAAY,SAClB,OAAO,UAAU,yBACd,OAAO,UAAU,uBAAuB,QAAQ,QAAQ,GACxD,QAAQ,UACZ,OAAO,UAAU,iBAAiB;CAc1C,MAAM,sBAAiC;EACrC,IAAIC,MAA2B,EAAE;EAEjC,IAAI,wBAAQ,IAAI,KAAqB;EAErC,MAAM,YAAY,OAChB,GAAGC,OAAqB,GAAG,KAAK,CAAC,GAAG,OAAO,GAAG,KAAK;AAErD,SAAO;GACL,KAAK,IAA8C;AACjD,QAAI,GAAG,cAAc;KACnB,MAAM,MAAM,SAAS,GAAG;KACxB,MAAM,WAAW,MAAM,IAAI,IAAI;AAC/B,SAAI,aAAa,QAAW;AAE1B,UAAI,OAAO,UAAU,EAAE;MAEvB,MAAM,2BAAW,IAAI,KAAqB;AAC1C,WAAK,MAAM,CAAC,GAAG,MAAM,OAAO;AAC1B,WAAI,MAAM,IAAK;AACf,gBAAS,IAAI,GAAG,IAAI,WAAW,IAAI,IAAI,EAAE;;AAE3C,cAAQ;;AAEV,WAAM,IAAI,KAAK,IAAI,OAAO;;AAE5B,QAAI,KAAK,GAAG;;GAGd,QAA8C;IAC5C,MAAM,SAAS;AACf,UAAM,EAAE;AACR,4BAAQ,IAAI,KAAK;AACjB,WAAO;;GAGT,UAAU,OAAwB;AAChC,SAAK,MAAM,MAAM,MAAM,SAAS,CAC9B,MAAK,KAAK,GAAG;;GAGjB,UAAyD;AACvD,WAAO;;GAET,QAAc;AACZ,UAAM,EAAE;AACR,4BAAQ,IAAI,KAAK;;GAEpB;;CAIH,MAAM,WAAW,eAAe;CAGhC,IAAI,iBAAiB;CACrB,IAAI,SAAS,eAAe;CAC5B,IAAIC,eAA0D;;;;CAK9D,MAAM,kBAAkB,SAA+C;EACrE,MAAM,SAAS,KAAK,UAAU,CAAC,QAAO,MAAK,MAAM,GAAG;AAEpD,MAAI,OAAO,WAAW,EACpB,QAAO;EAGT,IAAIC,UAAmB;AACvB,OAAK,MAAM,SAAS,QAAQ;AAC1B,OAAI,YAAY,QAAQ,YAAY,OAClC;AAGF,OAAI,OAAO,YAAY,UAAU;AAE/B,QAAI,MAAM,QAAQ,QAAQ,EAAE;KAE1B,MAAM,QAAQ,QAAQ,MAAM,MAAW,EAAE,OAAO,MAAM;AACtD,SAAI,OAAO;AACT,gBAAU,MAAM;AAChB;;;AAKJ,cAAW,QAAoC;SAE/C;;AAIJ,SAAO;;;;;CAMT,MAAM,kBAAkB,OAAiD;AACvE,MAAI;AACF,YAAS,OAAO,UAAU,eAAe,QAAQ,GAAG;WAC7C,OAAO;AACd,OAAI,iBAAiB,MACnB,OAAM,IAAI,eAAe,MAAM,QAAQ;AAEzC,SAAM,IAAI,eAAe,OAAO,MAAM,CAAC;;;;;;;;CAS3C,MAAM,mBAAmB,OAAiD;AACxE,MAAI,gBAAgB;AAElB,UAAO,KAAK,GAAG;AACf,kBAAe,GAAG;SACb;GAEL,MAAM,YAAY;AAClB,OAAI;AACF,mBAAe,GAAG;AAClB,aAAS,KAAK,GAAG;YACV,OAAO;AAEd,aAAS;AACT,UAAM;;;;;;;CAQZ,MAAM,kBAAqD;AACzD,SAAOC,OAAsB;GAC3B,aAAa;GACb,UAAU;GACX,CAAC;;CAIJ,MAAM,MAAM,WAAW;CACvB,MAAM,YAAY,OAAO,UAAU,YAAY,KAAKC,OAAmB,GAAG,CAAC;AAyD3E,QAtDoC;EAClC;EACA,MAAM;EAEN,WAAsD;AACpD,UAAO;;EAGT,kBAAoD;AAClD,UAAQ,UAAiE,YAAY;;EAGvF,cAAkB,OAAsD;AACtE,OAAI,eACF,OAAM,IAAI,wBAAwB;AAIpC,oBAAiB;AACjB,UAAO,OAAO;AACd,kBAAe;AAEf,OAAI;IAEF,MAAM,SAAS,GAAG,UAAU;AAG5B,aAAS,UAAU,OAAO;AAE1B,WAAO;YACA,OAAO;AAEd,aAAS;AACT,UAAM;aACE;AAER,qBAAiB;AACjB,WAAO,OAAO;AACd,mBAAe;;;EAInB,QAAQ,QAAiE;AACvE,QAAK,MAAM,MAAM,IACf,gBAAe,GAAG;;EAItB,aAAsC;AAEpC,UADWC,OAAiB,SAAS,OAAO,CAAC;;EAGhD"}
@@ -40,6 +40,7 @@ var Primitive_exports = /* @__PURE__ */ require_rolldown_runtime.__export({
40
40
  ValidationError: () => require_shared.ValidationError,
41
41
  applyDefaults: () => require_shared.applyDefaults,
42
42
  isCompatibleOperation: () => require_shared.isCompatibleOperation,
43
+ primitiveAllowsNullValue: () => require_shared.primitiveAllowsNullValue,
43
44
  runValidators: () => require_shared.runValidators
44
45
  });
45
46
 
@@ -1,6 +1,6 @@
1
- import { AnyPrimitive, HasDefault, InferProxy, InferSetInput, InferSnapshot, InferState, InferUpdateInput, IsDefined, IsRequired, MaybeUndefined, NeedsValue, Optional, Primitive, PrimitiveInternal, ValidationError, Validator, applyDefaults, isCompatibleOperation, runValidators } from "./primitives/shared.cjs";
1
+ import { AnyPrimitive, HasDefault, InferProxy, InferSetInput, InferSnapshot, InferState, InferUpdateInput, IsDefined, IsRequired, MaybeUndefined, NeedsValue, Optional, Primitive, PrimitiveInternal, ValidationError, Validator, applyDefaults, isCompatibleOperation, primitiveAllowsNullValue, runValidators } from "./primitives/shared.cjs";
2
2
  import { String, StringPrimitive, StringProxy } from "./primitives/String.cjs";
3
- import { InferStructSnapshot, InferStructState, MakeOptional, PartialFields, Struct, StructPrimitive, StructProxy, StructSetInput, StructUpdateValue } from "./primitives/Struct.cjs";
3
+ import { InferStructSnapshot, InferStructState, MakeOptional, MakeOptionalNoDefault, PartialFields, PartialFieldsNoDefault, Struct, StructPrimitive, StructProxy, StructSetInput, StructUpdateValue } from "./primitives/Struct.cjs";
4
4
  import { Boolean, BooleanPrimitive, BooleanProxy } from "./primitives/Boolean.cjs";
5
5
  import { Number, NumberPrimitive, NumberProxy } from "./primitives/Number.cjs";
6
6
  import { Literal, LiteralPrimitive, LiteralProxy, LiteralValue } from "./primitives/Literal.cjs";
@@ -13,7 +13,7 @@ import { InferTreeSetInput, InferTreeSnapshot, Tree, TreeNodeDataSetInput, TreeN
13
13
 
14
14
  //#region src/Primitive.d.ts
15
15
  declare namespace Primitive_d_exports {
16
- export { AnyPrimitive, AnyTreeNodePrimitive, Array, ArrayElementSetInput, ArrayEntry, ArrayEntrySnapshot, ArrayPrimitive, ArrayProxy, ArraySetInput, ArraySnapshot, ArrayState, ArrayUpdateInput, Boolean, BooleanPrimitive, BooleanProxy, Either, EitherMatchHandlers, EitherPrimitive, EitherProxy, HasDefault, InferEitherSnapshot, InferEitherState, InferLazyProxy, InferLazySetInput, InferLazySnapshot, InferLazyState, InferLazyUpdateInput, InferProxy, InferSetInput, InferSnapshot, InferState, InferStructSnapshot, InferStructState, InferTreeNodeChildren, InferTreeNodeDataState, InferTreeNodeType, InferTreeSetInput, InferTreeSnapshot, InferUnionSnapshot, InferUnionState, InferUpdateInput, IsDefined, IsRequired, Lazy, LazyPrimitive, Literal, LiteralPrimitive, LiteralProxy, LiteralValue, MakeOptional, MaybeUndefined, NeedsValue, Number, NumberPrimitive, NumberProxy, Optional, PartialFields, Primitive, PrimitiveInternal, ScalarPrimitive, String, StringPrimitive, StringProxy, Struct, StructPrimitive, StructProxy, StructSetInput, StructUpdateValue, Tree, TreeNode, TreeNodeChildrenInput, TreeNodeConfig, TreeNodeDataSetInput, TreeNodePrimitive, TreeNodeProxyBase, TreeNodeSelf, TreeNodeSelfType, TreeNodeSetInput, TreeNodeSetInputUnion, TreeNodeSnapshot, TreeNodeState, TreeNodeUpdateValue, TreeOptions, TreePrimitive, TreeProxy, TreeSetInput, TreeState, TreeUpdateInput, TypedNodeProxy, TypedTreeNodeState, Union, UnionOptions, UnionPrimitive, UnionProxy, UnionSetInput, UnionVariants, ValidationError, Validator, applyDefaults, isCompatibleOperation, runValidators };
16
+ export { AnyPrimitive, AnyTreeNodePrimitive, Array, ArrayElementSetInput, ArrayEntry, ArrayEntrySnapshot, ArrayPrimitive, ArrayProxy, ArraySetInput, ArraySnapshot, ArrayState, ArrayUpdateInput, Boolean, BooleanPrimitive, BooleanProxy, Either, EitherMatchHandlers, EitherPrimitive, EitherProxy, HasDefault, InferEitherSnapshot, InferEitherState, InferLazyProxy, InferLazySetInput, InferLazySnapshot, InferLazyState, InferLazyUpdateInput, InferProxy, InferSetInput, InferSnapshot, InferState, InferStructSnapshot, InferStructState, InferTreeNodeChildren, InferTreeNodeDataState, InferTreeNodeType, InferTreeSetInput, InferTreeSnapshot, InferUnionSnapshot, InferUnionState, InferUpdateInput, IsDefined, IsRequired, Lazy, LazyPrimitive, Literal, LiteralPrimitive, LiteralProxy, LiteralValue, MakeOptional, MakeOptionalNoDefault, MaybeUndefined, NeedsValue, Number, NumberPrimitive, NumberProxy, Optional, PartialFields, PartialFieldsNoDefault, Primitive, PrimitiveInternal, ScalarPrimitive, String, StringPrimitive, StringProxy, Struct, StructPrimitive, StructProxy, StructSetInput, StructUpdateValue, Tree, TreeNode, TreeNodeChildrenInput, TreeNodeConfig, TreeNodeDataSetInput, TreeNodePrimitive, TreeNodeProxyBase, TreeNodeSelf, TreeNodeSelfType, TreeNodeSetInput, TreeNodeSetInputUnion, TreeNodeSnapshot, TreeNodeState, TreeNodeUpdateValue, TreeOptions, TreePrimitive, TreeProxy, TreeSetInput, TreeState, TreeUpdateInput, TypedNodeProxy, TypedTreeNodeState, Union, UnionOptions, UnionPrimitive, UnionProxy, UnionSetInput, UnionVariants, ValidationError, Validator, applyDefaults, isCompatibleOperation, primitiveAllowsNullValue, runValidators };
17
17
  }
18
18
  //#endregion
19
19
  export { Primitive_d_exports };
@@ -1,6 +1,6 @@
1
- import { AnyPrimitive, HasDefault, InferProxy, InferSetInput, InferSnapshot, InferState, InferUpdateInput, IsDefined, IsRequired, MaybeUndefined, NeedsValue, Optional, Primitive, PrimitiveInternal, ValidationError, Validator, applyDefaults, isCompatibleOperation, runValidators } from "./primitives/shared.mjs";
1
+ import { AnyPrimitive, HasDefault, InferProxy, InferSetInput, InferSnapshot, InferState, InferUpdateInput, IsDefined, IsRequired, MaybeUndefined, NeedsValue, Optional, Primitive, PrimitiveInternal, ValidationError, Validator, applyDefaults, isCompatibleOperation, primitiveAllowsNullValue, runValidators } from "./primitives/shared.mjs";
2
2
  import { String, StringPrimitive, StringProxy } from "./primitives/String.mjs";
3
- import { InferStructSnapshot, InferStructState, MakeOptional, PartialFields, Struct, StructPrimitive, StructProxy, StructSetInput, StructUpdateValue } from "./primitives/Struct.mjs";
3
+ import { InferStructSnapshot, InferStructState, MakeOptional, MakeOptionalNoDefault, PartialFields, PartialFieldsNoDefault, Struct, StructPrimitive, StructProxy, StructSetInput, StructUpdateValue } from "./primitives/Struct.mjs";
4
4
  import { Boolean, BooleanPrimitive, BooleanProxy } from "./primitives/Boolean.mjs";
5
5
  import { Number, NumberPrimitive, NumberProxy } from "./primitives/Number.mjs";
6
6
  import { Literal, LiteralPrimitive, LiteralProxy, LiteralValue } from "./primitives/Literal.mjs";
@@ -13,7 +13,7 @@ import { InferTreeSetInput, InferTreeSnapshot, Tree, TreeNodeDataSetInput, TreeN
13
13
 
14
14
  //#region src/Primitive.d.ts
15
15
  declare namespace Primitive_d_exports {
16
- export { AnyPrimitive, AnyTreeNodePrimitive, Array, ArrayElementSetInput, ArrayEntry, ArrayEntrySnapshot, ArrayPrimitive, ArrayProxy, ArraySetInput, ArraySnapshot, ArrayState, ArrayUpdateInput, Boolean, BooleanPrimitive, BooleanProxy, Either, EitherMatchHandlers, EitherPrimitive, EitherProxy, HasDefault, InferEitherSnapshot, InferEitherState, InferLazyProxy, InferLazySetInput, InferLazySnapshot, InferLazyState, InferLazyUpdateInput, InferProxy, InferSetInput, InferSnapshot, InferState, InferStructSnapshot, InferStructState, InferTreeNodeChildren, InferTreeNodeDataState, InferTreeNodeType, InferTreeSetInput, InferTreeSnapshot, InferUnionSnapshot, InferUnionState, InferUpdateInput, IsDefined, IsRequired, Lazy, LazyPrimitive, Literal, LiteralPrimitive, LiteralProxy, LiteralValue, MakeOptional, MaybeUndefined, NeedsValue, Number, NumberPrimitive, NumberProxy, Optional, PartialFields, Primitive, PrimitiveInternal, ScalarPrimitive, String, StringPrimitive, StringProxy, Struct, StructPrimitive, StructProxy, StructSetInput, StructUpdateValue, Tree, TreeNode, TreeNodeChildrenInput, TreeNodeConfig, TreeNodeDataSetInput, TreeNodePrimitive, TreeNodeProxyBase, TreeNodeSelf, TreeNodeSelfType, TreeNodeSetInput, TreeNodeSetInputUnion, TreeNodeSnapshot, TreeNodeState, TreeNodeUpdateValue, TreeOptions, TreePrimitive, TreeProxy, TreeSetInput, TreeState, TreeUpdateInput, TypedNodeProxy, TypedTreeNodeState, Union, UnionOptions, UnionPrimitive, UnionProxy, UnionSetInput, UnionVariants, ValidationError, Validator, applyDefaults, isCompatibleOperation, runValidators };
16
+ export { AnyPrimitive, AnyTreeNodePrimitive, Array, ArrayElementSetInput, ArrayEntry, ArrayEntrySnapshot, ArrayPrimitive, ArrayProxy, ArraySetInput, ArraySnapshot, ArrayState, ArrayUpdateInput, Boolean, BooleanPrimitive, BooleanProxy, Either, EitherMatchHandlers, EitherPrimitive, EitherProxy, HasDefault, InferEitherSnapshot, InferEitherState, InferLazyProxy, InferLazySetInput, InferLazySnapshot, InferLazyState, InferLazyUpdateInput, InferProxy, InferSetInput, InferSnapshot, InferState, InferStructSnapshot, InferStructState, InferTreeNodeChildren, InferTreeNodeDataState, InferTreeNodeType, InferTreeSetInput, InferTreeSnapshot, InferUnionSnapshot, InferUnionState, InferUpdateInput, IsDefined, IsRequired, Lazy, LazyPrimitive, Literal, LiteralPrimitive, LiteralProxy, LiteralValue, MakeOptional, MakeOptionalNoDefault, MaybeUndefined, NeedsValue, Number, NumberPrimitive, NumberProxy, Optional, PartialFields, PartialFieldsNoDefault, Primitive, PrimitiveInternal, ScalarPrimitive, String, StringPrimitive, StringProxy, Struct, StructPrimitive, StructProxy, StructSetInput, StructUpdateValue, Tree, TreeNode, TreeNodeChildrenInput, TreeNodeConfig, TreeNodeDataSetInput, TreeNodePrimitive, TreeNodeProxyBase, TreeNodeSelf, TreeNodeSelfType, TreeNodeSetInput, TreeNodeSetInputUnion, TreeNodeSnapshot, TreeNodeState, TreeNodeUpdateValue, TreeOptions, TreePrimitive, TreeProxy, TreeSetInput, TreeState, TreeUpdateInput, TypedNodeProxy, TypedTreeNodeState, Union, UnionOptions, UnionPrimitive, UnionProxy, UnionSetInput, UnionVariants, ValidationError, Validator, applyDefaults, isCompatibleOperation, primitiveAllowsNullValue, runValidators };
17
17
  }
18
18
  //#endregion
19
19
  export { Primitive_d_exports };
@@ -1,5 +1,5 @@
1
1
  import { __export } from "./_virtual/rolldown_runtime.mjs";
2
- import { ValidationError, applyDefaults, isCompatibleOperation, runValidators } from "./primitives/shared.mjs";
2
+ import { ValidationError, applyDefaults, isCompatibleOperation, primitiveAllowsNullValue, runValidators } from "./primitives/shared.mjs";
3
3
  import { String, StringPrimitive } from "./primitives/String.mjs";
4
4
  import { Struct, StructPrimitive } from "./primitives/Struct.mjs";
5
5
  import { Boolean, BooleanPrimitive } from "./primitives/Boolean.mjs";
@@ -40,6 +40,7 @@ var Primitive_exports = /* @__PURE__ */ __export({
40
40
  ValidationError: () => ValidationError,
41
41
  applyDefaults: () => applyDefaults,
42
42
  isCompatibleOperation: () => isCompatibleOperation,
43
+ primitiveAllowsNullValue: () => primitiveAllowsNullValue,
43
44
  runValidators: () => runValidators
44
45
  });
45
46
 
@@ -174,11 +174,15 @@ const make = (options) => {
174
174
  * If disconnected, the transport will queue it for later submission.
175
175
  */
176
176
  const submitTransaction = (tx) => {
177
+ var _Error$stack;
177
178
  debugLog("submitTransaction", {
178
179
  txId: tx.id,
179
180
  ops: tx.ops,
180
181
  pendingCount: _pending.length + 1,
181
- isConnected: transport.isConnected()
182
+ isConnected: transport.isConnected(),
183
+ activeDraftCount: _drafts.size,
184
+ activeDraftIds: Array.from(_drafts.keys()),
185
+ callStack: (_Error$stack = (/* @__PURE__ */ new Error()).stack) === null || _Error$stack === void 0 ? void 0 : _Error$stack.split("\n").slice(1, 6).join("\n")
182
186
  });
183
187
  const pending = {
184
188
  transaction: tx,
@@ -475,10 +479,14 @@ const make = (options) => {
475
479
  getPendingCount: () => _pending.length,
476
480
  hasPendingChanges: () => _pending.length > 0,
477
481
  transaction: (fn) => {
482
+ var _Error$stack2;
478
483
  debugLog("transaction: starting", {
479
484
  isConnected: transport.isConnected(),
480
485
  isReady: _initState.type === "ready",
481
- pendingCount: _pending.length
486
+ pendingCount: _pending.length,
487
+ activeDraftCount: _drafts.size,
488
+ activeDraftIds: Array.from(_drafts.keys()),
489
+ callStack: (_Error$stack2 = (/* @__PURE__ */ new Error()).stack) === null || _Error$stack2 === void 0 ? void 0 : _Error$stack2.split("\n").slice(1, 6).join("\n")
482
490
  });
483
491
  if (_initState.type !== "ready") throw new require_errors.InvalidStateError("Client is not ready. Wait for initialization to complete.");
484
492
  const result = _optimisticDoc.transaction(fn);
@@ -579,6 +587,12 @@ const make = (options) => {
579
587
  return {
580
588
  id: draftId,
581
589
  update: (fn) => {
590
+ debugLog("draft.update: starting", {
591
+ draftId,
592
+ consumed,
593
+ currentOpsCount: draftState.ops.size,
594
+ pendingCount: _pending.length
595
+ });
582
596
  if (consumed) throw new require_errors.InvalidStateError("Draft has already been committed or discarded.");
583
597
  const baseDoc = require_Document.make(schema, { initialState: _serverState });
584
598
  for (const pending of _pending) baseDoc.apply(pending.transaction.ops);
@@ -598,32 +612,47 @@ const make = (options) => {
598
612
  draftState.ops.set(uniqueKey, op);
599
613
  }
600
614
  }
601
- debugLog("draft.update", {
615
+ debugLog("draft.update: complete", {
602
616
  draftId,
603
617
  newOpsCount: tx.ops.length,
604
- totalOps: draftState.ops.size
618
+ totalOps: draftState.ops.size,
619
+ note: "Ops stored in draft - NOT sent to server"
605
620
  });
606
621
  recomputeOptimisticState();
607
622
  notifyDraftChange();
608
623
  },
609
624
  commit: () => {
625
+ debugLog("draft.commit: starting", {
626
+ draftId,
627
+ consumed,
628
+ opsCount: draftState.ops.size
629
+ });
610
630
  if (consumed) throw new require_errors.InvalidStateError("Draft has already been committed or discarded.");
611
631
  consumed = true;
612
632
  const ops = Array.from(draftState.ops.values());
613
633
  _drafts.delete(draftId);
614
- debugLog("draft.commit", {
634
+ debugLog("draft.commit: submitting", {
615
635
  draftId,
616
- opsCount: ops.length
636
+ opsCount: ops.length,
637
+ note: ops.length > 0 ? "Will call submitTransaction" : "Empty draft - no transaction"
617
638
  });
618
639
  if (ops.length > 0) submitTransaction(require_Transaction.make(ops));
619
640
  recomputeOptimisticState();
620
641
  notifyDraftChange();
621
642
  },
622
643
  discard: () => {
644
+ debugLog("draft.discard: starting", {
645
+ draftId,
646
+ consumed,
647
+ opsCount: draftState.ops.size
648
+ });
623
649
  if (consumed) throw new require_errors.InvalidStateError("Draft has already been committed or discarded.");
624
650
  consumed = true;
625
651
  _drafts.delete(draftId);
626
- debugLog("draft.discard", { draftId });
652
+ debugLog("draft.discard: complete", {
653
+ draftId,
654
+ note: "Draft discarded - no transaction sent to server"
655
+ });
627
656
  recomputeOptimisticState();
628
657
  notifyDraftChange();
629
658
  }
@@ -1 +1 @@
1
- {"version":3,"file":"ClientDocument.d.mts","names":[],"sources":["../../src/client/ClientDocument.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;;UA6BiB,4BAA4B;;;;oBAIzB,WAAqB;;;;;;AAJzC;;;AAIoB,UAwCH,gBAxCG,CAAA,MAAA,CAAA,CAAA;EAAoB;EAwCvB,SAAA,gBAAgB,CAAA,EAAA,GAAA,GAAA,IAAA;AAQjC;;;;AAiByB,UAjBR,cAiBQ,CAAA,KAAA,CAAA,CAAA;EAKwC;;;;EAkBf,SAAA,MAAA,EAAA,GAAA,GAAA,MAAA,GAAA,SAAA;EAAjB;;AAMjC;;EAEoB,SAAA,IAAA,EAAA,GAAA,GArCG,KAqCH,GAAA,SAAA;EAGD;;;;EASF,SAAA,MAAA,EAAA,GAAA,GA3CQ,WA2CR,CAAA,MAAA,EA3C4B,aA2C5B,CA3CmD,KA2CnD,CAAA,CAAA;EAIuC;;;EAiB3B,SAAA,GAAA,EAAA,GAAA,GA3DP,WA2DO,CAAA,MAAA,EA3Da,aA2Db,CA3DoC,KA2DpC,CAAA,CAAA;EAAkB;;;;AAM/C;EAAwD,SAAA,GAAA,EAAA,CAAA,IAAA,EA1DjC,KA0DiC,EAAA,GAAA,IAAA;EAEA;;;EAYvC,SAAA,KAAA,EAAA,GAAc,GAAA,IAAA;EACb;;;;EAOD,SAAA,SAAA,EAAA,CAAA,QAAA,EArEgB,gBAqEhB,CArEiC,KAqEjC,CAAA,EAAA,GAAA,GAAA,GAAA,IAAA;;;;;AAqBgC,UApFhC,qBAoFgC,CAAA,gBAnF/B,YAmF+B,EAAA,kBAlF7B,WAkF6B,GAAA,SAAA,GAAA,SAAA,CAAA,CAAA;EAArB;EAAkC,SAAA,MAAA,EA/E3C,OA+E2C;EAAI;EAKrD,SAAA,SAAA,EAlFS,SAkFT;EA0BgC;EAAvB,SAAA,YAAA,CAAA,EA1GI,UA0GJ,CA1GyB,OA0GzB,CAAA;EAMO;EAAZ,SAAA,cAAA,CAAA,EAAA,MAAA;EAKM;EAMF,SAAA,WAAA,CAAA,EAAA,CAAA,WAAA,EAtHJ,WAsHI,EAAA,MAAA,EAAA,MAAA,EAAA,GAAA,IAAA;EAAkB;EACH,SAAA,aAAA,CAAA,EAAA,CAAA,KAAA,EAnHD,UAmHC,CAnHoB,OAmHpB,CAAA,GAAA,SAAA,EAAA,GAAA,IAAA;EAAf;EAAf,SAAA,kBAAA,CAAA,EAAA,CAAA,SAAA,EAAA,OAAA,EAAA,GAAA,IAAA;EAAc;EAWP,SA0iCZ,OAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EAziCiB;EACE,SAAA,kBAAA,CAAA,EAAA,MAAA;EAEa;EAAS,SAAA,WAAA,CAAA,EAAA,MAAA;EAA/B;EACO,SAAA,KAAA,CAAA,EAAA,OAAA;EAAS;;;;sBApHL;;6BAEO,kBAAkB,cAAuB,MAAe;;;;;UAMpE,uCAAuC;;mCAErB,WAAqB;;;;;;;;;;;UAYvC,+BACC,gCACE;;mBAGD;;iBAGF,WAAqB;;SAG7B,WAAqB;;oBAGV,WAAqB;;;;;;;;;;;4BAeb,WAAqB,aAAa,IAAI;;;;aAKrD;;;;;;;;;;;;;;;;;;;;;sBA0BS,uBAAuB;;;;;iBAM5B,YAAY;;;;uBAKN;;;;;qBAMF,kBAAkB,cACjC,eAAe,MAAe;;;;;cAWvB,uBACK,gCACE,8CAET,sBAAsB,SAAS,eACvC,eAAe,SAAS"}
1
+ {"version":3,"file":"ClientDocument.d.mts","names":[],"sources":["../../src/client/ClientDocument.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;;UA6BiB,4BAA4B;;;;oBAIzB,WAAqB;;;;;;AAJzC;;;AAIoB,UAwCH,gBAxCG,CAAA,MAAA,CAAA,CAAA;EAAoB;EAwCvB,SAAA,gBAAgB,CAAA,EAAA,GAAA,GAAA,IAAA;AAQjC;;;;AAiByB,UAjBR,cAiBQ,CAAA,KAAA,CAAA,CAAA;EAKwC;;;;EAkBf,SAAA,MAAA,EAAA,GAAA,GAAA,MAAA,GAAA,SAAA;EAAjB;;AAMjC;;EAEoB,SAAA,IAAA,EAAA,GAAA,GArCG,KAqCH,GAAA,SAAA;EAGD;;;;EASF,SAAA,MAAA,EAAA,GAAA,GA3CQ,WA2CR,CAAA,MAAA,EA3C4B,aA2C5B,CA3CmD,KA2CnD,CAAA,CAAA;EAIuC;;;EAiB3B,SAAA,GAAA,EAAA,GAAA,GA3DP,WA2DO,CAAA,MAAA,EA3Da,aA2Db,CA3DoC,KA2DpC,CAAA,CAAA;EAAkB;;;;AAM/C;EAAwD,SAAA,GAAA,EAAA,CAAA,IAAA,EA1DjC,KA0DiC,EAAA,GAAA,IAAA;EAEA;;;EAYvC,SAAA,KAAA,EAAA,GAAc,GAAA,IAAA;EACb;;;;EAOD,SAAA,SAAA,EAAA,CAAA,QAAA,EArEgB,gBAqEhB,CArEiC,KAqEjC,CAAA,EAAA,GAAA,GAAA,GAAA,IAAA;;;;;AAqBgC,UApFhC,qBAoFgC,CAAA,gBAnF/B,YAmF+B,EAAA,kBAlF7B,WAkF6B,GAAA,SAAA,GAAA,SAAA,CAAA,CAAA;EAArB;EAAkC,SAAA,MAAA,EA/E3C,OA+E2C;EAAI;EAKrD,SAAA,SAAA,EAlFS,SAkFT;EA0BgC;EAAvB,SAAA,YAAA,CAAA,EA1GI,UA0GJ,CA1GyB,OA0GzB,CAAA;EAMO;EAAZ,SAAA,cAAA,CAAA,EAAA,MAAA;EAKM;EAMF,SAAA,WAAA,CAAA,EAAA,CAAA,WAAA,EAtHJ,WAsHI,EAAA,MAAA,EAAA,MAAA,EAAA,GAAA,IAAA;EAAkB;EACH,SAAA,aAAA,CAAA,EAAA,CAAA,KAAA,EAnHD,UAmHC,CAnHoB,OAmHpB,CAAA,GAAA,SAAA,EAAA,GAAA,IAAA;EAAf;EAAf,SAAA,kBAAA,CAAA,EAAA,CAAA,SAAA,EAAA,OAAA,EAAA,GAAA,IAAA;EAAc;EAWP,SA+kCZ,OAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EA9kCiB;EACE,SAAA,kBAAA,CAAA,EAAA,MAAA;EAEa;EAAS,SAAA,WAAA,CAAA,EAAA,MAAA;EAA/B;EACO,SAAA,KAAA,CAAA,EAAA,OAAA;EAAS;;;;sBApHL;;6BAEO,kBAAkB,cAAuB,MAAe;;;;;UAMpE,uCAAuC;;mCAErB,WAAqB;;;;;;;;;;;UAYvC,+BACC,gCACE;;mBAGD;;iBAGF,WAAqB;;SAG7B,WAAqB;;oBAGV,WAAqB;;;;;;;;;;;4BAeb,WAAqB,aAAa,IAAI;;;;aAKrD;;;;;;;;;;;;;;;;;;;;;sBA0BS,uBAAuB;;;;;iBAM5B,YAAY;;;;uBAKN;;;;;qBAMF,kBAAkB,cACjC,eAAe,MAAe;;;;;cAWvB,uBACK,gCACE,8CAET,sBAAsB,SAAS,eACvC,eAAe,SAAS"}
@@ -174,11 +174,15 @@ const make = (options) => {
174
174
  * If disconnected, the transport will queue it for later submission.
175
175
  */
176
176
  const submitTransaction = (tx) => {
177
+ var _Error$stack;
177
178
  debugLog("submitTransaction", {
178
179
  txId: tx.id,
179
180
  ops: tx.ops,
180
181
  pendingCount: _pending.length + 1,
181
- isConnected: transport.isConnected()
182
+ isConnected: transport.isConnected(),
183
+ activeDraftCount: _drafts.size,
184
+ activeDraftIds: Array.from(_drafts.keys()),
185
+ callStack: (_Error$stack = (/* @__PURE__ */ new Error()).stack) === null || _Error$stack === void 0 ? void 0 : _Error$stack.split("\n").slice(1, 6).join("\n")
182
186
  });
183
187
  const pending = {
184
188
  transaction: tx,
@@ -475,10 +479,14 @@ const make = (options) => {
475
479
  getPendingCount: () => _pending.length,
476
480
  hasPendingChanges: () => _pending.length > 0,
477
481
  transaction: (fn) => {
482
+ var _Error$stack2;
478
483
  debugLog("transaction: starting", {
479
484
  isConnected: transport.isConnected(),
480
485
  isReady: _initState.type === "ready",
481
- pendingCount: _pending.length
486
+ pendingCount: _pending.length,
487
+ activeDraftCount: _drafts.size,
488
+ activeDraftIds: Array.from(_drafts.keys()),
489
+ callStack: (_Error$stack2 = (/* @__PURE__ */ new Error()).stack) === null || _Error$stack2 === void 0 ? void 0 : _Error$stack2.split("\n").slice(1, 6).join("\n")
482
490
  });
483
491
  if (_initState.type !== "ready") throw new InvalidStateError("Client is not ready. Wait for initialization to complete.");
484
492
  const result = _optimisticDoc.transaction(fn);
@@ -579,6 +587,12 @@ const make = (options) => {
579
587
  return {
580
588
  id: draftId,
581
589
  update: (fn) => {
590
+ debugLog("draft.update: starting", {
591
+ draftId,
592
+ consumed,
593
+ currentOpsCount: draftState.ops.size,
594
+ pendingCount: _pending.length
595
+ });
582
596
  if (consumed) throw new InvalidStateError("Draft has already been committed or discarded.");
583
597
  const baseDoc = make$2(schema, { initialState: _serverState });
584
598
  for (const pending of _pending) baseDoc.apply(pending.transaction.ops);
@@ -598,32 +612,47 @@ const make = (options) => {
598
612
  draftState.ops.set(uniqueKey, op);
599
613
  }
600
614
  }
601
- debugLog("draft.update", {
615
+ debugLog("draft.update: complete", {
602
616
  draftId,
603
617
  newOpsCount: tx.ops.length,
604
- totalOps: draftState.ops.size
618
+ totalOps: draftState.ops.size,
619
+ note: "Ops stored in draft - NOT sent to server"
605
620
  });
606
621
  recomputeOptimisticState();
607
622
  notifyDraftChange();
608
623
  },
609
624
  commit: () => {
625
+ debugLog("draft.commit: starting", {
626
+ draftId,
627
+ consumed,
628
+ opsCount: draftState.ops.size
629
+ });
610
630
  if (consumed) throw new InvalidStateError("Draft has already been committed or discarded.");
611
631
  consumed = true;
612
632
  const ops = Array.from(draftState.ops.values());
613
633
  _drafts.delete(draftId);
614
- debugLog("draft.commit", {
634
+ debugLog("draft.commit: submitting", {
615
635
  draftId,
616
- opsCount: ops.length
636
+ opsCount: ops.length,
637
+ note: ops.length > 0 ? "Will call submitTransaction" : "Empty draft - no transaction"
617
638
  });
618
639
  if (ops.length > 0) submitTransaction(make$1(ops));
619
640
  recomputeOptimisticState();
620
641
  notifyDraftChange();
621
642
  },
622
643
  discard: () => {
644
+ debugLog("draft.discard: starting", {
645
+ draftId,
646
+ consumed,
647
+ opsCount: draftState.ops.size
648
+ });
623
649
  if (consumed) throw new InvalidStateError("Draft has already been committed or discarded.");
624
650
  consumed = true;
625
651
  _drafts.delete(draftId);
626
- debugLog("draft.discard", { draftId });
652
+ debugLog("draft.discard: complete", {
653
+ draftId,
654
+ note: "Draft discarded - no transaction sent to server"
655
+ });
627
656
  recomputeOptimisticState();
628
657
  notifyDraftChange();
629
658
  }