document-drive 4.0.1 → 4.1.0-dev.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (264) hide show
  1. package/dist/index.d.ts +2 -2
  2. package/dist/index.d.ts.map +1 -1
  3. package/dist/index.js +2 -2
  4. package/dist/index.js.map +1 -1
  5. package/dist/prisma/schema.prisma +1 -2
  6. package/dist/src/drive-document-model/gen/document-model.js +3 -3
  7. package/dist/src/drive-document-model/gen/document-model.js.map +1 -1
  8. package/dist/src/drive-document-model/gen/drive/actions.d.ts +9 -9
  9. package/dist/src/drive-document-model/gen/drive/actions.d.ts.map +1 -1
  10. package/dist/src/drive-document-model/gen/node/actions.d.ts +8 -8
  11. package/dist/src/drive-document-model/gen/node/actions.d.ts.map +1 -1
  12. package/dist/src/drive-document-model/gen/node/creators.d.ts +6 -2
  13. package/dist/src/drive-document-model/gen/node/creators.d.ts.map +1 -1
  14. package/dist/src/drive-document-model/gen/node/creators.js +8 -1
  15. package/dist/src/drive-document-model/gen/node/creators.js.map +1 -1
  16. package/dist/src/drive-document-model/gen/reducer.d.ts.map +1 -1
  17. package/dist/src/drive-document-model/gen/reducer.js.map +1 -1
  18. package/dist/src/drive-document-model/gen/schema/types.d.ts +1 -14
  19. package/dist/src/drive-document-model/gen/schema/types.d.ts.map +1 -1
  20. package/dist/src/drive-document-model/gen/schema/zod.d.ts +1 -5
  21. package/dist/src/drive-document-model/gen/schema/zod.d.ts.map +1 -1
  22. package/dist/src/drive-document-model/gen/schema/zod.js +0 -12
  23. package/dist/src/drive-document-model/gen/schema/zod.js.map +1 -1
  24. package/dist/src/drive-document-model/gen/types.d.ts +13 -4
  25. package/dist/src/drive-document-model/gen/types.d.ts.map +1 -1
  26. package/dist/src/drive-document-model/gen/types.js.map +1 -1
  27. package/dist/src/drive-document-model/module.d.ts +2 -1
  28. package/dist/src/drive-document-model/module.d.ts.map +1 -1
  29. package/dist/src/drive-document-model/src/reducers/node.d.ts.map +1 -1
  30. package/dist/src/drive-document-model/src/reducers/node.js +1 -25
  31. package/dist/src/drive-document-model/src/reducers/node.js.map +1 -1
  32. package/dist/src/drive-document-model/src/tests/actions.test.js +1 -23
  33. package/dist/src/drive-document-model/src/tests/actions.test.js.map +1 -1
  34. package/dist/src/drive-document-model/src/tests/base.test.js +0 -32
  35. package/dist/src/drive-document-model/src/tests/base.test.js.map +1 -1
  36. package/dist/src/drive-document-model/src/tests/utils.test.js +7 -37
  37. package/dist/src/drive-document-model/src/tests/utils.test.js.map +1 -1
  38. package/dist/src/drive-document-model/src/utils.d.ts +2 -8
  39. package/dist/src/drive-document-model/src/utils.d.ts.map +1 -1
  40. package/dist/src/drive-document-model/src/utils.js +6 -55
  41. package/dist/src/drive-document-model/src/utils.js.map +1 -1
  42. package/dist/src/processors/types.d.ts +2 -1
  43. package/dist/src/processors/types.d.ts.map +1 -1
  44. package/dist/src/queue/base.d.ts +6 -27
  45. package/dist/src/queue/base.d.ts.map +1 -1
  46. package/dist/src/queue/base.js +15 -203
  47. package/dist/src/queue/base.js.map +1 -1
  48. package/dist/src/queue/event.d.ts +41 -0
  49. package/dist/src/queue/event.d.ts.map +1 -0
  50. package/dist/src/queue/event.js +222 -0
  51. package/dist/src/queue/event.js.map +1 -0
  52. package/dist/src/queue/redis.d.ts +1 -27
  53. package/dist/src/queue/redis.d.ts.map +1 -1
  54. package/dist/src/queue/redis.js +122 -110
  55. package/dist/src/queue/redis.js.map +1 -1
  56. package/dist/src/queue/types.d.ts +18 -12
  57. package/dist/src/queue/types.d.ts.map +1 -1
  58. package/dist/src/queue/types.js +3 -0
  59. package/dist/src/queue/types.js.map +1 -1
  60. package/dist/src/server/base-server.d.ts +87 -11
  61. package/dist/src/server/base-server.d.ts.map +1 -1
  62. package/dist/src/server/base-server.js +549 -250
  63. package/dist/src/server/base-server.js.map +1 -1
  64. package/dist/src/server/builder.js +2 -2
  65. package/dist/src/server/builder.js.map +1 -1
  66. package/dist/src/server/error.d.ts +3 -3
  67. package/dist/src/server/error.d.ts.map +1 -1
  68. package/dist/src/server/error.js +2 -2
  69. package/dist/src/server/error.js.map +1 -1
  70. package/dist/src/server/listener/listener-manager.d.ts +5 -6
  71. package/dist/src/server/listener/listener-manager.d.ts.map +1 -1
  72. package/dist/src/server/listener/listener-manager.js +62 -79
  73. package/dist/src/server/listener/listener-manager.js.map +1 -1
  74. package/dist/src/server/listener/transmitter/internal.d.ts +3 -3
  75. package/dist/src/server/listener/transmitter/internal.d.ts.map +1 -1
  76. package/dist/src/server/listener/transmitter/internal.js +18 -13
  77. package/dist/src/server/listener/transmitter/internal.js.map +1 -1
  78. package/dist/src/server/listener/transmitter/pull-responder.d.ts.map +1 -1
  79. package/dist/src/server/listener/transmitter/pull-responder.js +14 -8
  80. package/dist/src/server/listener/transmitter/pull-responder.js.map +1 -1
  81. package/dist/src/server/listener/transmitter/switchboard-push.d.ts.map +1 -1
  82. package/dist/src/server/listener/transmitter/switchboard-push.js +13 -8
  83. package/dist/src/server/listener/transmitter/switchboard-push.js.map +1 -1
  84. package/dist/src/server/sync-manager.d.ts +8 -10
  85. package/dist/src/server/sync-manager.d.ts.map +1 -1
  86. package/dist/src/server/sync-manager.js +62 -147
  87. package/dist/src/server/sync-manager.js.map +1 -1
  88. package/dist/src/server/sync-unit-map.d.ts +137 -0
  89. package/dist/src/server/sync-unit-map.d.ts.map +1 -0
  90. package/dist/src/server/sync-unit-map.js +234 -0
  91. package/dist/src/server/sync-unit-map.js.map +1 -0
  92. package/dist/src/server/types.d.ts +116 -33
  93. package/dist/src/server/types.d.ts.map +1 -1
  94. package/dist/src/server/types.js.map +1 -1
  95. package/dist/src/server/utils.d.ts +10 -1
  96. package/dist/src/server/utils.d.ts.map +1 -1
  97. package/dist/src/server/utils.js +44 -1
  98. package/dist/src/server/utils.js.map +1 -1
  99. package/dist/src/storage/browser.d.ts +7 -2
  100. package/dist/src/storage/browser.d.ts.map +1 -1
  101. package/dist/src/storage/browser.js +80 -22
  102. package/dist/src/storage/browser.js.map +1 -1
  103. package/dist/src/storage/filesystem.d.ts +7 -2
  104. package/dist/src/storage/filesystem.d.ts.map +1 -1
  105. package/dist/src/storage/filesystem.js +79 -22
  106. package/dist/src/storage/filesystem.js.map +1 -1
  107. package/dist/src/storage/memory.d.ts +7 -2
  108. package/dist/src/storage/memory.d.ts.map +1 -1
  109. package/dist/src/storage/memory.js +76 -22
  110. package/dist/src/storage/memory.js.map +1 -1
  111. package/dist/src/storage/prisma/client/edge.js +5 -4
  112. package/dist/src/storage/prisma/client/index-browser.js +2 -1
  113. package/dist/src/storage/prisma/client/index.d.ts +58 -249
  114. package/dist/src/storage/prisma/client/index.js +5 -4
  115. package/dist/src/storage/prisma/client/package.json +1 -1
  116. package/dist/src/storage/prisma/client/schema.prisma +2 -3
  117. package/dist/src/storage/prisma/client/wasm.js +2 -1
  118. package/dist/src/storage/prisma/prisma.d.ts +9 -4
  119. package/dist/src/storage/prisma/prisma.d.ts.map +1 -1
  120. package/dist/src/storage/prisma/prisma.js +119 -51
  121. package/dist/src/storage/prisma/prisma.js.map +1 -1
  122. package/dist/src/storage/types.d.ts +43 -4
  123. package/dist/src/storage/types.d.ts.map +1 -1
  124. package/dist/src/storage/utils.d.ts +3 -0
  125. package/dist/src/storage/utils.d.ts.map +1 -1
  126. package/dist/src/storage/utils.js +14 -0
  127. package/dist/src/storage/utils.js.map +1 -1
  128. package/dist/src/utils/gql-transformations.d.ts +14 -5
  129. package/dist/src/utils/gql-transformations.d.ts.map +1 -1
  130. package/dist/src/utils/gql-transformations.js +1 -0
  131. package/dist/src/utils/gql-transformations.js.map +1 -1
  132. package/dist/src/utils/migrations.d.ts.map +1 -1
  133. package/dist/src/utils/migrations.js.map +1 -1
  134. package/dist/src/utils/misc.d.ts +2 -0
  135. package/dist/src/utils/misc.d.ts.map +1 -1
  136. package/dist/src/utils/misc.js +4 -0
  137. package/dist/src/utils/misc.js.map +1 -1
  138. package/dist/tsconfig.lib.tsbuildinfo +1 -0
  139. package/package.json +4 -4
  140. package/dist/test/cache.test.d.ts +0 -2
  141. package/dist/test/cache.test.d.ts.map +0 -1
  142. package/dist/test/cache.test.js +0 -281
  143. package/dist/test/cache.test.js.map +0 -1
  144. package/dist/test/default-remote-drives.test.d.ts +0 -2
  145. package/dist/test/default-remote-drives.test.d.ts.map +0 -1
  146. package/dist/test/default-remote-drives.test.js +0 -446
  147. package/dist/test/default-remote-drives.test.js.map +0 -1
  148. package/dist/test/document-helpers/addUndo.test.d.ts +0 -2
  149. package/dist/test/document-helpers/addUndo.test.d.ts.map +0 -1
  150. package/dist/test/document-helpers/addUndo.test.js +0 -120
  151. package/dist/test/document-helpers/addUndo.test.js.map +0 -1
  152. package/dist/test/document-helpers/attachBranch.test.d.ts +0 -2
  153. package/dist/test/document-helpers/attachBranch.test.d.ts.map +0 -1
  154. package/dist/test/document-helpers/attachBranch.test.js +0 -333
  155. package/dist/test/document-helpers/attachBranch.test.js.map +0 -1
  156. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.d.ts +0 -2
  157. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.d.ts.map +0 -1
  158. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.js +0 -252
  159. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.js.map +0 -1
  160. package/dist/test/document-helpers/garbageCollect.test.d.ts +0 -2
  161. package/dist/test/document-helpers/garbageCollect.test.d.ts.map +0 -1
  162. package/dist/test/document-helpers/garbageCollect.test.js +0 -136
  163. package/dist/test/document-helpers/garbageCollect.test.js.map +0 -1
  164. package/dist/test/document-helpers/groupOperationsByScope.test.d.ts +0 -2
  165. package/dist/test/document-helpers/groupOperationsByScope.test.d.ts.map +0 -1
  166. package/dist/test/document-helpers/groupOperationsByScope.test.js +0 -98
  167. package/dist/test/document-helpers/groupOperationsByScope.test.js.map +0 -1
  168. package/dist/test/document-helpers/merge.test.d.ts +0 -2
  169. package/dist/test/document-helpers/merge.test.d.ts.map +0 -1
  170. package/dist/test/document-helpers/merge.test.js +0 -757
  171. package/dist/test/document-helpers/merge.test.js.map +0 -1
  172. package/dist/test/document-helpers/nextSkipNumber.test.d.ts +0 -2
  173. package/dist/test/document-helpers/nextSkipNumber.test.d.ts.map +0 -1
  174. package/dist/test/document-helpers/nextSkipNumber.test.js +0 -123
  175. package/dist/test/document-helpers/nextSkipNumber.test.js.map +0 -1
  176. package/dist/test/document-helpers/prepareOperations.test.d.ts +0 -2
  177. package/dist/test/document-helpers/prepareOperations.test.d.ts.map +0 -1
  178. package/dist/test/document-helpers/prepareOperations.test.js +0 -304
  179. package/dist/test/document-helpers/prepareOperations.test.js.map +0 -1
  180. package/dist/test/document-helpers/removeExistingOperations.test.d.ts +0 -2
  181. package/dist/test/document-helpers/removeExistingOperations.test.d.ts.map +0 -1
  182. package/dist/test/document-helpers/removeExistingOperations.test.js +0 -150
  183. package/dist/test/document-helpers/removeExistingOperations.test.js.map +0 -1
  184. package/dist/test/document-helpers/reshuffleByTimestamp.test.d.ts +0 -2
  185. package/dist/test/document-helpers/reshuffleByTimestamp.test.d.ts.map +0 -1
  186. package/dist/test/document-helpers/reshuffleByTimestamp.test.js +0 -148
  187. package/dist/test/document-helpers/reshuffleByTimestamp.test.js.map +0 -1
  188. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.d.ts +0 -2
  189. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.d.ts.map +0 -1
  190. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.js +0 -200
  191. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.js.map +0 -1
  192. package/dist/test/document-helpers/sortOperations.test.d.ts +0 -2
  193. package/dist/test/document-helpers/sortOperations.test.d.ts.map +0 -1
  194. package/dist/test/document-helpers/sortOperations.test.js +0 -101
  195. package/dist/test/document-helpers/sortOperations.test.js.map +0 -1
  196. package/dist/test/document-helpers/split.test.d.ts +0 -2
  197. package/dist/test/document-helpers/split.test.d.ts.map +0 -1
  198. package/dist/test/document-helpers/split.test.js +0 -121
  199. package/dist/test/document-helpers/split.test.js.map +0 -1
  200. package/dist/test/document-helpers/utils.d.ts +0 -8
  201. package/dist/test/document-helpers/utils.d.ts.map +0 -1
  202. package/dist/test/document-helpers/utils.js +0 -22
  203. package/dist/test/document-helpers/utils.js.map +0 -1
  204. package/dist/test/drive-operations.test.d.ts +0 -2
  205. package/dist/test/drive-operations.test.d.ts.map +0 -1
  206. package/dist/test/drive-operations.test.js +0 -145
  207. package/dist/test/drive-operations.test.js.map +0 -1
  208. package/dist/test/graphql.test.d.ts +0 -2
  209. package/dist/test/graphql.test.d.ts.map +0 -1
  210. package/dist/test/graphql.test.js +0 -10
  211. package/dist/test/graphql.test.js.map +0 -1
  212. package/dist/test/internal-listener.test.d.ts +0 -2
  213. package/dist/test/internal-listener.test.d.ts.map +0 -1
  214. package/dist/test/internal-listener.test.js +0 -277
  215. package/dist/test/internal-listener.test.js.map +0 -1
  216. package/dist/test/queue.test.d.ts +0 -2
  217. package/dist/test/queue.test.d.ts.map +0 -1
  218. package/dist/test/queue.test.js +0 -338
  219. package/dist/test/queue.test.js.map +0 -1
  220. package/dist/test/read-mode.test.d.ts +0 -2
  221. package/dist/test/read-mode.test.d.ts.map +0 -1
  222. package/dist/test/read-mode.test.js +0 -578
  223. package/dist/test/read-mode.test.js.map +0 -1
  224. package/dist/test/server/driveOperationsConflictResolution.test.d.ts +0 -2
  225. package/dist/test/server/driveOperationsConflictResolution.test.d.ts.map +0 -1
  226. package/dist/test/server/driveOperationsConflictResolution.test.js +0 -460
  227. package/dist/test/server/driveOperationsConflictResolution.test.js.map +0 -1
  228. package/dist/test/server/mergeOperations.test.d.ts +0 -2
  229. package/dist/test/server/mergeOperations.test.d.ts.map +0 -1
  230. package/dist/test/server/mergeOperations.test.js +0 -107
  231. package/dist/test/server/mergeOperations.test.js.map +0 -1
  232. package/dist/test/server/processOperations.test.d.ts +0 -2
  233. package/dist/test/server/processOperations.test.d.ts.map +0 -1
  234. package/dist/test/server/processOperations.test.js +0 -380
  235. package/dist/test/server/processOperations.test.js.map +0 -1
  236. package/dist/test/server.test.d.ts +0 -2
  237. package/dist/test/server.test.d.ts.map +0 -1
  238. package/dist/test/server.test.js +0 -899
  239. package/dist/test/server.test.js.map +0 -1
  240. package/dist/test/signature-migration.test.d.ts +0 -2
  241. package/dist/test/signature-migration.test.d.ts.map +0 -1
  242. package/dist/test/signature-migration.test.js +0 -239
  243. package/dist/test/signature-migration.test.js.map +0 -1
  244. package/dist/test/storage.test.d.ts +0 -2
  245. package/dist/test/storage.test.d.ts.map +0 -1
  246. package/dist/test/storage.test.js +0 -523
  247. package/dist/test/storage.test.js.map +0 -1
  248. package/dist/test/utils.d.ts +0 -48
  249. package/dist/test/utils.d.ts.map +0 -1
  250. package/dist/test/utils.js +0 -133
  251. package/dist/test/utils.js.map +0 -1
  252. package/dist/test/utils.test.d.ts +0 -2
  253. package/dist/test/utils.test.d.ts.map +0 -1
  254. package/dist/test/utils.test.js +0 -89
  255. package/dist/test/utils.test.js.map +0 -1
  256. package/dist/test/vitest-setup.d.ts +0 -2
  257. package/dist/test/vitest-setup.d.ts.map +0 -1
  258. package/dist/test/vitest-setup.js +0 -5
  259. package/dist/test/vitest-setup.js.map +0 -1
  260. package/dist/tsconfig.tsbuildinfo +0 -1
  261. package/dist/vitest.config.d.ts +0 -3
  262. package/dist/vitest.config.d.ts.map +0 -1
  263. package/dist/vitest.config.js +0 -27
  264. package/dist/vitest.config.js.map +0 -1
@@ -1,150 +0,0 @@
1
- import { removeExistingOperations } from "document-model";
2
- import { describe, expect, it } from "vitest";
3
- import { buildOperations } from "./utils.js";
4
- describe("removeExistingOperations", () => {
5
- const scenarios = [
6
- {
7
- title: "case 1: all new operations should be applied",
8
- operationsHistory: [
9
- { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
10
- { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
11
- { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
12
- ],
13
- newOperations: [
14
- { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
15
- { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
16
- { index: 6, skip: 0, type: "OP_6", hash: "hash_6" },
17
- ],
18
- expected: [
19
- { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
20
- { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
21
- { index: 6, skip: 0, type: "OP_6", hash: "hash_6" },
22
- ],
23
- },
24
- {
25
- title: "case 2: return no operations, all of them already exist in the history",
26
- operationsHistory: [
27
- { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
28
- { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
29
- { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
30
- ],
31
- newOperations: [
32
- { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
33
- { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
34
- { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
35
- ],
36
- expected: [],
37
- },
38
- {
39
- title: "case 3: return only operation that does not exist in the history",
40
- operationsHistory: [
41
- { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
42
- { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
43
- { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
44
- { index: 3, skip: 0, type: "OP_3", hash: "hash_3" },
45
- { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
46
- { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
47
- ],
48
- newOperations: [
49
- { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
50
- { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
51
- { index: 6, skip: 0, type: "OP_6", hash: "hash_6" },
52
- { index: 7, skip: 0, type: "OP_7", hash: "hash_7" },
53
- ],
54
- expected: [
55
- { index: 6, skip: 0, type: "OP_6", hash: "hash_6" },
56
- { index: 7, skip: 0, type: "OP_7", hash: "hash_7" },
57
- ],
58
- },
59
- {
60
- title: "case 4: return only operation that does not exist in the history",
61
- operationsHistory: [
62
- { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
63
- { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
64
- { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
65
- ],
66
- newOperations: [
67
- { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
68
- { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
69
- { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
70
- { index: 3, skip: 0, type: "OP_3", hash: "hash_3" },
71
- { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
72
- { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
73
- ],
74
- expected: [
75
- { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
76
- { index: 3, skip: 0, type: "OP_3", hash: "hash_3" },
77
- { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
78
- ],
79
- },
80
- ];
81
- it.each(scenarios)("$title", (testInput) => {
82
- const newOperations = buildOperations(testInput.newOperations);
83
- const operationsHistory = buildOperations(testInput.operationsHistory);
84
- const result = removeExistingOperations(newOperations, operationsHistory);
85
- expect(result).toMatchObject(testInput.expected);
86
- });
87
- it("should not consider operations skipped", () => {
88
- const existingOperations = [
89
- {
90
- type: "NOOP",
91
- input: {},
92
- scope: "global",
93
- index: 0,
94
- timestamp: "2024-04-22T18:33:20.624Z",
95
- hash: "pLimr2HqW//d6upWCv4tGfI0W4c=",
96
- skip: 0,
97
- },
98
- {
99
- type: "ADD_FOLDER",
100
- input: { id: "1", name: "test1" },
101
- scope: "global",
102
- index: 1,
103
- timestamp: "2024-04-22T18:33:20.631Z",
104
- hash: "P6p5OmHl7FpHRN9ftOS0k+eaU4E=",
105
- skip: 1,
106
- },
107
- {
108
- type: "ADD_FOLDER",
109
- input: { id: "2", name: "test2" },
110
- scope: "global",
111
- index: 2,
112
- timestamp: "2024-04-22T18:33:20.631Z",
113
- hash: "5XOFEY2NKrHVyOA3c3oXDibrjwM=",
114
- skip: 0,
115
- },
116
- ];
117
- const operationsHistory = [
118
- {
119
- type: "ADD_FOLDER",
120
- input: { id: "1", name: "test1" },
121
- scope: "global",
122
- index: 0,
123
- timestamp: "2024-04-22T18:33:20.628Z",
124
- hash: "P6p5OmHl7FpHRN9ftOS0k+eaU4E=",
125
- skip: 0,
126
- },
127
- {
128
- type: "ADD_FOLDER",
129
- input: { id: "1", name: "test1" },
130
- scope: "global",
131
- index: 1,
132
- timestamp: "2024-04-22T18:33:20.630Z",
133
- hash: "P6p5OmHl7FpHRN9ftOS0k+eaU4E=",
134
- skip: 1,
135
- },
136
- {
137
- type: "ADD_FOLDER",
138
- input: { id: "2", name: "test2" },
139
- scope: "global",
140
- index: 2,
141
- timestamp: "2024-04-22T18:33:20.630Z",
142
- hash: "5XOFEY2NKrHVyOA3c3oXDibrjwM=",
143
- skip: 0,
144
- },
145
- ];
146
- const result = removeExistingOperations(existingOperations, operationsHistory);
147
- expect(result).toMatchObject([]);
148
- });
149
- });
150
- //# sourceMappingURL=removeExistingOperations.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"removeExistingOperations.test.js","sourceRoot":"","sources":["../../../test/document-helpers/removeExistingOperations.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=reshuffleByTimestamp.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"reshuffleByTimestamp.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/reshuffleByTimestamp.test.ts"],"names":[],"mappings":""}
@@ -1,148 +0,0 @@
1
- import { reshuffleByTimestamp } from "document-model";
2
- import { describe, expect, it } from "vitest";
3
- import { buildOperations } from "./utils.js";
4
- describe("reshuffleByTimestamp", () => {
5
- const scenarios = [
6
- {
7
- title: "case 1",
8
- startIndex: { index: 6, skip: 2 },
9
- operationsA: buildOperations([
10
- {
11
- index: 4,
12
- skip: 0,
13
- type: "OP_A_4",
14
- timestamp: "2021-01-01T00:00:00.000Z",
15
- },
16
- {
17
- index: 5,
18
- skip: 0,
19
- type: "OP_A_5",
20
- timestamp: "2021-01-04T00:00:00.000Z",
21
- },
22
- {
23
- index: 6,
24
- skip: 0,
25
- type: "OP_A_6",
26
- timestamp: "2021-01-05T00:00:00.000Z",
27
- },
28
- ]),
29
- operationsB: buildOperations([
30
- {
31
- index: 4,
32
- skip: 0,
33
- type: "OP_B_4",
34
- timestamp: "2021-01-02T00:00:00.000Z",
35
- },
36
- {
37
- index: 5,
38
- skip: 0,
39
- type: "OP_B_5",
40
- timestamp: "2021-01-03T00:00:00.000Z",
41
- },
42
- ]),
43
- expected: [
44
- { index: 6, skip: 2, type: "OP_A_4" },
45
- { index: 7, skip: 0, type: "OP_B_4" },
46
- { index: 8, skip: 0, type: "OP_B_5" },
47
- { index: 9, skip: 0, type: "OP_A_5" },
48
- { index: 10, skip: 0, type: "OP_A_6" },
49
- ],
50
- },
51
- {
52
- title: "case 2 (remove skip from operations)",
53
- startIndex: { index: 3, skip: 1 },
54
- operationsA: buildOperations([
55
- {
56
- index: 2,
57
- skip: 0,
58
- type: "OP_A_2",
59
- timestamp: "2021-01-01T00:00:00.000Z",
60
- },
61
- {
62
- index: 3,
63
- skip: 0,
64
- type: "OP_A_3",
65
- timestamp: "2021-01-03T00:00:00.000Z",
66
- },
67
- {
68
- index: 4,
69
- skip: 0,
70
- type: "OP_A_4",
71
- timestamp: "2021-01-04T00:00:00.000Z",
72
- },
73
- ]),
74
- operationsB: buildOperations([
75
- {
76
- index: 3,
77
- skip: 0,
78
- type: "OP_B_3",
79
- timestamp: "2021-01-02T00:00:00.000Z",
80
- },
81
- {
82
- index: 5,
83
- skip: 1,
84
- type: "OP_B_5",
85
- timestamp: "2021-01-05T00:00:00.000Z",
86
- },
87
- ]),
88
- expected: [
89
- { index: 3, skip: 1, type: "OP_A_2" },
90
- { index: 4, skip: 0, type: "OP_B_3" },
91
- { index: 5, skip: 0, type: "OP_A_3" },
92
- { index: 6, skip: 0, type: "OP_A_4" },
93
- { index: 7, skip: 0, type: "OP_B_5" },
94
- ],
95
- },
96
- {
97
- title: "case 3 (should not consider index when sorting operations)",
98
- startIndex: { index: 3, skip: 1 },
99
- operationsA: buildOperations([
100
- {
101
- index: 2,
102
- skip: 0,
103
- type: "OP_A_2",
104
- timestamp: "2021-01-01T00:00:00.000Z",
105
- },
106
- {
107
- index: 3,
108
- skip: 0,
109
- type: "OP_A_3",
110
- timestamp: "2021-01-03T00:00:00.000Z",
111
- },
112
- {
113
- index: 4,
114
- skip: 0,
115
- type: "OP_A_4",
116
- timestamp: "2021-01-05T00:00:00.000Z",
117
- },
118
- ]),
119
- operationsB: buildOperations([
120
- {
121
- index: 3,
122
- skip: 0,
123
- type: "OP_B_3",
124
- timestamp: "2021-01-02T00:00:00.000Z",
125
- },
126
- {
127
- index: 5,
128
- skip: 1,
129
- type: "OP_B_5",
130
- timestamp: "2021-01-04T00:00:00.000Z",
131
- },
132
- ]),
133
- expected: [
134
- { index: 3, skip: 1, type: "OP_A_2" },
135
- { index: 4, skip: 0, type: "OP_B_3" },
136
- { index: 5, skip: 0, type: "OP_A_3" },
137
- { index: 6, skip: 0, type: "OP_B_5" },
138
- { index: 7, skip: 0, type: "OP_A_4" },
139
- ],
140
- },
141
- ];
142
- it.each(scenarios)("should reshuffle the operations: $title", (testInput) => {
143
- const result = reshuffleByTimestamp(testInput.startIndex, testInput.operationsA, testInput.operationsB);
144
- expect(result.length).toBe(testInput.expected.length);
145
- expect(result).toMatchObject(testInput.expected);
146
- });
147
- });
148
- //# sourceMappingURL=reshuffleByTimestamp.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"reshuffleByTimestamp.test.js","sourceRoot":"","sources":["../../../test/document-helpers/reshuffleByTimestamp.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=reshuffleByTimestampAndIndex.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"reshuffleByTimestampAndIndex.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/reshuffleByTimestampAndIndex.test.ts"],"names":[],"mappings":""}
@@ -1,200 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { reshuffleByTimestampAndIndex } from "../../../document-model/src/document/utils/document-helpers.js";
3
- import { buildOperations } from "./utils.js";
4
- describe("reshuffleByTimestamp", () => {
5
- const scenarios = [
6
- {
7
- title: "case 1",
8
- startIndex: { index: 6, skip: 2 },
9
- operationsA: buildOperations([
10
- {
11
- index: 4,
12
- skip: 0,
13
- type: "OP_A_4",
14
- timestamp: "2021-01-01T00:00:00.000Z",
15
- },
16
- {
17
- index: 5,
18
- skip: 0,
19
- type: "OP_A_5",
20
- timestamp: "2021-01-04T00:00:00.000Z",
21
- },
22
- {
23
- index: 6,
24
- skip: 0,
25
- type: "OP_A_6",
26
- timestamp: "2021-01-05T00:00:00.000Z",
27
- },
28
- ]),
29
- operationsB: buildOperations([
30
- {
31
- index: 4,
32
- skip: 0,
33
- type: "OP_B_4",
34
- timestamp: "2021-01-02T00:00:00.000Z",
35
- },
36
- {
37
- index: 5,
38
- skip: 0,
39
- type: "OP_B_5",
40
- timestamp: "2021-01-03T00:00:00.000Z",
41
- },
42
- ]),
43
- expected: [
44
- { index: 6, skip: 2, type: "OP_A_4" },
45
- { index: 7, skip: 0, type: "OP_B_4" },
46
- { index: 8, skip: 0, type: "OP_B_5" },
47
- { index: 9, skip: 0, type: "OP_A_5" },
48
- { index: 10, skip: 0, type: "OP_A_6" },
49
- ],
50
- },
51
- {
52
- title: "case 2 (remove skip from operations)",
53
- startIndex: { index: 3, skip: 1 },
54
- operationsA: buildOperations([
55
- {
56
- index: 2,
57
- skip: 0,
58
- type: "OP_A_2",
59
- timestamp: "2021-01-01T00:00:00.000Z",
60
- },
61
- {
62
- index: 3,
63
- skip: 0,
64
- type: "OP_A_3",
65
- timestamp: "2021-01-03T00:00:00.000Z",
66
- },
67
- {
68
- index: 4,
69
- skip: 0,
70
- type: "OP_A_4",
71
- timestamp: "2021-01-04T00:00:00.000Z",
72
- },
73
- ]),
74
- operationsB: buildOperations([
75
- {
76
- index: 3,
77
- skip: 0,
78
- type: "OP_B_3",
79
- timestamp: "2021-01-02T00:00:00.000Z",
80
- },
81
- {
82
- index: 5,
83
- skip: 1,
84
- type: "OP_B_5",
85
- timestamp: "2021-01-05T00:00:00.000Z",
86
- },
87
- ]),
88
- expected: [
89
- { index: 3, skip: 1, type: "OP_A_2" },
90
- { index: 4, skip: 0, type: "OP_B_3" },
91
- { index: 5, skip: 0, type: "OP_A_3" },
92
- { index: 6, skip: 0, type: "OP_A_4" },
93
- { index: 7, skip: 0, type: "OP_B_5" },
94
- ],
95
- },
96
- {
97
- title: "case 3 (should consider index when sorting operations)",
98
- startIndex: { index: 3, skip: 1 },
99
- operationsA: buildOperations([
100
- {
101
- index: 2,
102
- skip: 0,
103
- type: "OP_A_2",
104
- timestamp: "2021-01-01T00:00:00.000Z",
105
- },
106
- {
107
- index: 3,
108
- skip: 0,
109
- type: "OP_A_3",
110
- timestamp: "2021-01-03T00:00:00.000Z",
111
- },
112
- {
113
- index: 4,
114
- skip: 0,
115
- type: "OP_A_4",
116
- timestamp: "2021-01-05T00:00:00.000Z",
117
- },
118
- ]),
119
- operationsB: buildOperations([
120
- {
121
- index: 3,
122
- skip: 0,
123
- type: "OP_B_3",
124
- timestamp: "2021-01-02T00:00:00.000Z",
125
- },
126
- {
127
- index: 5,
128
- skip: 1,
129
- type: "OP_B_5",
130
- timestamp: "2021-01-04T00:00:00.000Z",
131
- },
132
- ]),
133
- expected: [
134
- { index: 3, skip: 1, type: "OP_A_2" },
135
- { index: 4, skip: 0, type: "OP_B_3" },
136
- { index: 5, skip: 0, type: "OP_A_3" },
137
- { index: 6, skip: 0, type: "OP_A_4" },
138
- { index: 7, skip: 0, type: "OP_B_5" },
139
- ],
140
- },
141
- {
142
- title: "case 4 (should consider index when sorting operations)",
143
- startIndex: { index: 3, skip: 1 },
144
- operationsA: buildOperations([
145
- {
146
- index: 2,
147
- skip: 0,
148
- type: "OP_A_2",
149
- timestamp: "2021-01-01T00:00:00.000Z",
150
- },
151
- {
152
- index: 3,
153
- skip: 0,
154
- type: "OP_A_3",
155
- timestamp: "2021-01-02T00:00:00.000Z",
156
- },
157
- {
158
- index: 4,
159
- skip: 0,
160
- type: "OP_A_4",
161
- timestamp: "2021-01-03T00:00:00.000Z",
162
- },
163
- ]),
164
- operationsB: buildOperations([
165
- {
166
- index: 2,
167
- skip: 0,
168
- type: "OP_B_2",
169
- timestamp: "2021-01-04T00:00:00.000Z",
170
- },
171
- {
172
- index: 3,
173
- skip: 0,
174
- type: "OP_B_3",
175
- timestamp: "2021-01-05T00:00:00.000Z",
176
- },
177
- {
178
- index: 4,
179
- skip: 0,
180
- type: "OP_B_4",
181
- timestamp: "2021-01-06T00:00:00.000Z",
182
- },
183
- ]),
184
- expected: [
185
- { index: 3, skip: 1, type: "OP_A_2" },
186
- { index: 4, skip: 0, type: "OP_B_2" },
187
- { index: 5, skip: 0, type: "OP_A_3" },
188
- { index: 6, skip: 0, type: "OP_B_3" },
189
- { index: 7, skip: 0, type: "OP_A_4" },
190
- { index: 8, skip: 0, type: "OP_B_4" },
191
- ],
192
- },
193
- ];
194
- it.each(scenarios)("should reshuffle the operations: $title", (testInput) => {
195
- const result = reshuffleByTimestampAndIndex(testInput.startIndex, testInput.operationsA, testInput.operationsB);
196
- expect(result.length).toBe(testInput.expected.length);
197
- expect(result).toMatchObject(testInput.expected);
198
- });
199
- });
200
- //# sourceMappingURL=reshuffleByTimestampAndIndex.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"reshuffleByTimestampAndIndex.test.js","sourceRoot":"","sources":["../../../test/document-helpers/reshuffleByTimestampAndIndex.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=sortOperations.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sortOperations.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/sortOperations.test.ts"],"names":[],"mappings":""}
@@ -1,101 +0,0 @@
1
- import { sortOperations } from "document-model";
2
- import { describe, expect, it } from "vitest";
3
- import { buildOperations } from "./utils.js";
4
- describe("sortOperations", () => {
5
- const scenarios = [
6
- {
7
- // 0:0 1:0 2:0 => 0:0 1:0 2:0
8
- title: "case 1",
9
- operations: [
10
- { index: 0, skip: 0 },
11
- { index: 1, skip: 0 },
12
- { index: 2, skip: 0 },
13
- ],
14
- expected: [
15
- { index: 0, skip: 0 },
16
- { index: 1, skip: 0 },
17
- { index: 2, skip: 0 },
18
- ],
19
- },
20
- {
21
- // 0:0 1:0 2:0 3:0 4:2 4:1 4:0 => 0:0 1:0 2:0 3:0 4:0 4:1 4:2
22
- title: "case 2 (with skip value)",
23
- operations: [
24
- { index: 0, skip: 0 },
25
- { index: 1, skip: 0 },
26
- { index: 2, skip: 0 },
27
- { index: 3, skip: 0 },
28
- { index: 4, skip: 2 },
29
- { index: 4, skip: 1 },
30
- { index: 4, skip: 0 },
31
- ],
32
- expected: [
33
- { index: 0, skip: 0 },
34
- { index: 1, skip: 0 },
35
- { index: 2, skip: 0 },
36
- { index: 3, skip: 0 },
37
- { index: 4, skip: 0 },
38
- { index: 4, skip: 1 },
39
- { index: 4, skip: 2 },
40
- ],
41
- },
42
- {
43
- // 1:1 5:0 4:0 3:0 => 1:1 3:0 4:0 5:0
44
- title: "case 3 (with skip value)",
45
- operations: [
46
- { index: 1, skip: 1 },
47
- { index: 5, skip: 0 },
48
- { index: 4, skip: 0 },
49
- { index: 3, skip: 0 },
50
- ],
51
- expected: [
52
- { index: 1, skip: 1 },
53
- { index: 3, skip: 0 },
54
- { index: 4, skip: 0 },
55
- { index: 5, skip: 0 },
56
- ],
57
- },
58
- {
59
- // 6:0 7:2 1:1 4:1 2:0 3:0 7:0 4:0 7:1 4:2 5:0 => 1:1 2:0 3:0 4:0 4:1 4:2 5:0 6:0 7:0 7:1 7:2
60
- title: "case 4 (with skip value)",
61
- operations: [
62
- { index: 6, skip: 0 },
63
- { index: 7, skip: 2 },
64
- { index: 1, skip: 1 },
65
- { index: 4, skip: 1 },
66
- { index: 2, skip: 0 },
67
- { index: 3, skip: 0 },
68
- { index: 7, skip: 0 },
69
- { index: 4, skip: 0 },
70
- { index: 7, skip: 1 },
71
- { index: 4, skip: 2 },
72
- { index: 5, skip: 0 },
73
- ],
74
- expected: [
75
- { index: 1, skip: 1 },
76
- { index: 2, skip: 0 },
77
- { index: 3, skip: 0 },
78
- { index: 4, skip: 0 },
79
- { index: 4, skip: 1 },
80
- { index: 4, skip: 2 },
81
- { index: 5, skip: 0 },
82
- { index: 6, skip: 0 },
83
- { index: 7, skip: 0 },
84
- { index: 7, skip: 1 },
85
- { index: 7, skip: 2 },
86
- ],
87
- },
88
- {
89
- // [] => []
90
- title: "case 5 (empty)",
91
- operations: [],
92
- expected: [],
93
- },
94
- ];
95
- it.each(scenarios)("should sort operations: $title", (testInput) => {
96
- const operations = buildOperations(testInput.operations);
97
- const result = sortOperations(operations);
98
- expect(result).toMatchObject(testInput.expected);
99
- });
100
- });
101
- //# sourceMappingURL=sortOperations.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sortOperations.test.js","sourceRoot":"","sources":["../../../test/document-helpers/sortOperations.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAE7C,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,MAAM,SAAS,GAAG;QAChB;YACE,6BAA6B;YAC7B,KAAK,EAAE,QAAQ;YACf,UAAU,EAAE;gBACV,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACtB;YACD,QAAQ,EAAE;gBACR,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACtB;SACF;QACD;YACE,6DAA6D;YAC7D,KAAK,EAAE,0BAA0B;YACjC,UAAU,EAAE;gBACV,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACtB;YACD,QAAQ,EAAE;gBACR,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACtB;SACF;QACD;YACE,qCAAqC;YACrC,KAAK,EAAE,0BAA0B;YACjC,UAAU,EAAE;gBACV,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACtB;YACD,QAAQ,EAAE;gBACR,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACtB;SACF;QACD;YACE,6FAA6F;YAC7F,KAAK,EAAE,0BAA0B;YACjC,UAAU,EAAE;gBACV,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACtB;YACD,QAAQ,EAAE;gBACR,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBACrB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;aACtB;SACF;QACD;YACE,WAAW;YACX,KAAK,EAAE,gBAAgB;YACvB,UAAU,EAAE,EAAE;YACd,QAAQ,EAAE,EAAE;SACb;KACF,CAAC;IAEF,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,gCAAgC,EAAE,CAAC,SAAS,EAAE,EAAE;QACjE,MAAM,UAAU,GAAG,eAAe,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAEzD,MAAM,MAAM,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC;QAE1C,MAAM,CAAC,MAAM,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}