@livestore/livestore 0.0.39-dev.3 → 0.0.40

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 (215) hide show
  1. package/README.md +15 -24
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/__tests__/react/fixture.d.ts +210 -35
  4. package/dist/__tests__/react/fixture.d.ts.map +1 -1
  5. package/dist/__tests__/react/fixture.js +10 -29
  6. package/dist/__tests__/react/fixture.js.map +1 -1
  7. package/dist/cud.d.ts +28 -0
  8. package/dist/cud.d.ts.map +1 -0
  9. package/dist/cud.js +50 -0
  10. package/dist/cud.js.map +1 -0
  11. package/dist/cud.test.d.ts +2 -0
  12. package/dist/cud.test.d.ts.map +1 -0
  13. package/dist/cud.test.js +47 -0
  14. package/dist/cud.test.js.map +1 -0
  15. package/dist/inMemoryDatabase.d.ts +1 -1
  16. package/dist/inMemoryDatabase.d.ts.map +1 -1
  17. package/dist/inMemoryDatabase.js +1 -4
  18. package/dist/inMemoryDatabase.js.map +1 -1
  19. package/dist/index.d.ts +4 -4
  20. package/dist/index.d.ts.map +1 -1
  21. package/dist/index.js +3 -3
  22. package/dist/index.js.map +1 -1
  23. package/dist/migrations.d.ts.map +1 -1
  24. package/dist/migrations.js +11 -7
  25. package/dist/migrations.js.map +1 -1
  26. package/dist/query-info.d.ts +49 -0
  27. package/dist/query-info.d.ts.map +1 -0
  28. package/dist/{update-path.js → query-info.js} +4 -3
  29. package/dist/query-info.js.map +1 -0
  30. package/dist/react/LiveStoreContext.d.ts +0 -6
  31. package/dist/react/LiveStoreContext.d.ts.map +1 -1
  32. package/dist/react/LiveStoreContext.js.map +1 -1
  33. package/dist/react/useAtom.d.ts +2 -2
  34. package/dist/react/useAtom.d.ts.map +1 -1
  35. package/dist/react/useAtom.js +3 -3
  36. package/dist/react/useAtom.js.map +1 -1
  37. package/dist/react/useQuery.d.ts.map +1 -1
  38. package/dist/react/useQuery.test.d.ts.map +1 -0
  39. package/dist/{__tests__/react → react}/useQuery.test.js +8 -11
  40. package/dist/react/useQuery.test.js.map +1 -0
  41. package/dist/react/useRow.d.ts +2 -2
  42. package/dist/react/useRow.d.ts.map +1 -1
  43. package/dist/react/useRow.js +5 -5
  44. package/dist/react/useRow.js.map +1 -1
  45. package/dist/react/useRow.test.d.ts.map +1 -0
  46. package/dist/{__tests__/react → react}/useRow.test.js +14 -38
  47. package/dist/react/useRow.test.js.map +1 -0
  48. package/dist/react/useTemporaryQuery.d.ts +2 -2
  49. package/dist/react/useTemporaryQuery.d.ts.map +1 -1
  50. package/dist/reactive.d.ts +2 -2
  51. package/dist/reactive.d.ts.map +1 -1
  52. package/dist/reactive.js +50 -15
  53. package/dist/reactive.js.map +1 -1
  54. package/dist/reactive.test.d.ts.map +1 -0
  55. package/dist/{__tests__/reactive.test.js → reactive.test.js} +1 -1
  56. package/dist/reactive.test.js.map +1 -0
  57. package/dist/reactiveQueries/base-class.d.ts +16 -8
  58. package/dist/reactiveQueries/base-class.d.ts.map +1 -1
  59. package/dist/reactiveQueries/base-class.js +2 -1
  60. package/dist/reactiveQueries/base-class.js.map +1 -1
  61. package/dist/reactiveQueries/graphql.d.ts +15 -9
  62. package/dist/reactiveQueries/graphql.d.ts.map +1 -1
  63. package/dist/reactiveQueries/graphql.js +29 -8
  64. package/dist/reactiveQueries/graphql.js.map +1 -1
  65. package/dist/reactiveQueries/js.d.ts +8 -8
  66. package/dist/reactiveQueries/js.d.ts.map +1 -1
  67. package/dist/reactiveQueries/js.js +5 -4
  68. package/dist/reactiveQueries/js.js.map +1 -1
  69. package/dist/reactiveQueries/sql.d.ts +11 -11
  70. package/dist/reactiveQueries/sql.d.ts.map +1 -1
  71. package/dist/reactiveQueries/sql.js +7 -6
  72. package/dist/reactiveQueries/sql.js.map +1 -1
  73. package/dist/reactiveQueries/sql.test.d.ts.map +1 -0
  74. package/dist/{__tests__/reactiveQueries → reactiveQueries}/sql.test.js +44 -34
  75. package/dist/reactiveQueries/sql.test.js.map +1 -0
  76. package/dist/row-query.d.ts +5 -5
  77. package/dist/row-query.d.ts.map +1 -1
  78. package/dist/row-query.js +11 -9
  79. package/dist/row-query.js.map +1 -1
  80. package/dist/schema/index.d.ts +20 -7
  81. package/dist/schema/index.d.ts.map +1 -1
  82. package/dist/schema/index.js +18 -3
  83. package/dist/schema/index.js.map +1 -1
  84. package/dist/schema/mutations.d.ts +81 -0
  85. package/dist/schema/mutations.d.ts.map +1 -0
  86. package/dist/schema/mutations.js +29 -0
  87. package/dist/schema/mutations.js.map +1 -0
  88. package/dist/schema/parse-utils.d.ts +3 -6
  89. package/dist/schema/parse-utils.d.ts.map +1 -1
  90. package/dist/schema/parse-utils.js +2 -27
  91. package/dist/schema/parse-utils.js.map +1 -1
  92. package/dist/schema/system-tables.d.ts +8 -8
  93. package/dist/schema/table-def.d.ts +6 -6
  94. package/dist/schema/table-def.d.ts.map +1 -1
  95. package/dist/schema/table-def.js +2 -2
  96. package/dist/schema/table-def.js.map +1 -1
  97. package/dist/storage/in-memory/index.d.ts +4 -0
  98. package/dist/storage/in-memory/index.d.ts.map +1 -1
  99. package/dist/storage/in-memory/index.js +3 -0
  100. package/dist/storage/in-memory/index.js.map +1 -1
  101. package/dist/storage/index.d.ts +4 -0
  102. package/dist/storage/index.d.ts.map +1 -1
  103. package/dist/storage/tauri/index.d.ts +4 -0
  104. package/dist/storage/tauri/index.d.ts.map +1 -1
  105. package/dist/storage/tauri/index.js +6 -0
  106. package/dist/storage/tauri/index.js.map +1 -1
  107. package/dist/storage/utils/idb.d.ts +1 -0
  108. package/dist/storage/utils/idb.d.ts.map +1 -1
  109. package/dist/storage/utils/idb.js +11 -0
  110. package/dist/storage/utils/idb.js.map +1 -1
  111. package/dist/storage/web-worker/common.d.ts +11 -0
  112. package/dist/storage/web-worker/common.d.ts.map +1 -0
  113. package/dist/storage/web-worker/common.js +2 -0
  114. package/dist/storage/web-worker/common.js.map +1 -0
  115. package/dist/storage/web-worker/index.d.ts +14 -7
  116. package/dist/storage/web-worker/index.d.ts.map +1 -1
  117. package/dist/storage/web-worker/index.js +70 -14
  118. package/dist/storage/web-worker/index.js.map +1 -1
  119. package/dist/storage/web-worker/make-worker.d.ts +20 -0
  120. package/dist/storage/web-worker/make-worker.d.ts.map +1 -0
  121. package/dist/storage/web-worker/make-worker.js +155 -0
  122. package/dist/storage/web-worker/make-worker.js.map +1 -0
  123. package/dist/storage/web-worker/vite-dev-polyfill.d.ts +2 -0
  124. package/dist/storage/web-worker/vite-dev-polyfill.d.ts.map +1 -0
  125. package/dist/storage/web-worker/vite-dev-polyfill.js +35 -0
  126. package/dist/storage/web-worker/vite-dev-polyfill.js.map +1 -0
  127. package/dist/store.d.ts +32 -42
  128. package/dist/store.d.ts.map +1 -1
  129. package/dist/store.js +82 -131
  130. package/dist/store.js.map +1 -1
  131. package/dist/utils/dev.d.ts +3 -0
  132. package/dist/utils/dev.d.ts.map +1 -0
  133. package/dist/utils/dev.js +16 -0
  134. package/dist/utils/dev.js.map +1 -0
  135. package/dist/utils/util.d.ts +2 -0
  136. package/dist/utils/util.d.ts.map +1 -1
  137. package/dist/utils/util.js +2 -0
  138. package/dist/utils/util.js.map +1 -1
  139. package/package.json +26 -14
  140. package/src/__tests__/react/fixture.tsx +12 -30
  141. package/src/cud.test.ts +52 -0
  142. package/src/cud.ts +92 -0
  143. package/src/inMemoryDatabase.ts +2 -7
  144. package/src/index.ts +14 -8
  145. package/src/migrations.ts +10 -7
  146. package/src/{update-path.ts → query-info.ts} +18 -21
  147. package/src/react/LiveStoreContext.ts +0 -9
  148. package/src/react/useAtom.ts +6 -6
  149. package/src/{__tests__/react → react}/useQuery.test.tsx +11 -11
  150. package/src/react/useQuery.ts +1 -1
  151. package/src/{__tests__/react → react}/useRow.test.tsx +21 -39
  152. package/src/react/useRow.ts +10 -10
  153. package/src/{__tests__/reactive.test.ts → reactive.test.ts} +1 -1
  154. package/src/reactive.ts +60 -19
  155. package/src/reactiveQueries/base-class.ts +23 -9
  156. package/src/reactiveQueries/graphql.ts +49 -13
  157. package/src/reactiveQueries/js.ts +15 -13
  158. package/src/{__tests__/reactiveQueries → reactiveQueries}/sql.test.ts +44 -34
  159. package/src/reactiveQueries/sql.ts +24 -22
  160. package/src/row-query.ts +24 -22
  161. package/src/schema/index.ts +47 -11
  162. package/src/schema/mutations.ts +129 -0
  163. package/src/schema/parse-utils.ts +3 -45
  164. package/src/schema/table-def.ts +9 -2
  165. package/src/storage/in-memory/index.ts +7 -0
  166. package/src/storage/index.ts +8 -0
  167. package/src/storage/tauri/index.ts +10 -0
  168. package/src/storage/utils/idb.ts +14 -0
  169. package/src/storage/web-worker/common.ts +6 -0
  170. package/src/storage/web-worker/index.ts +86 -17
  171. package/src/storage/web-worker/make-worker.ts +214 -0
  172. package/src/storage/web-worker/vite-dev-polyfill.ts +33 -0
  173. package/src/store.ts +142 -212
  174. package/src/utils/dev.ts +23 -0
  175. package/src/utils/util.ts +4 -0
  176. package/dist/__tests__/mutations.test.d.ts +0 -2
  177. package/dist/__tests__/mutations.test.d.ts.map +0 -1
  178. package/dist/__tests__/mutations.test.js +0 -40
  179. package/dist/__tests__/mutations.test.js.map +0 -1
  180. package/dist/__tests__/react/useQuery.test.d.ts.map +0 -1
  181. package/dist/__tests__/react/useQuery.test.js.map +0 -1
  182. package/dist/__tests__/react/useRow.test.d.ts.map +0 -1
  183. package/dist/__tests__/react/useRow.test.js.map +0 -1
  184. package/dist/__tests__/reactive.test.d.ts.map +0 -1
  185. package/dist/__tests__/reactive.test.js.map +0 -1
  186. package/dist/__tests__/reactiveQueries/sql.test.d.ts.map +0 -1
  187. package/dist/__tests__/reactiveQueries/sql.test.js.map +0 -1
  188. package/dist/events.d.ts +0 -7
  189. package/dist/events.d.ts.map +0 -1
  190. package/dist/events.js +0 -2
  191. package/dist/events.js.map +0 -1
  192. package/dist/mutations.d.ts +0 -33
  193. package/dist/mutations.d.ts.map +0 -1
  194. package/dist/mutations.js +0 -38
  195. package/dist/mutations.js.map +0 -1
  196. package/dist/schema/action.d.ts +0 -30
  197. package/dist/schema/action.d.ts.map +0 -1
  198. package/dist/schema/action.js +0 -3
  199. package/dist/schema/action.js.map +0 -1
  200. package/dist/storage/web-worker/worker.d.ts +0 -13
  201. package/dist/storage/web-worker/worker.d.ts.map +0 -1
  202. package/dist/storage/web-worker/worker.js +0 -110
  203. package/dist/storage/web-worker/worker.js.map +0 -1
  204. package/dist/update-path.d.ts +0 -52
  205. package/dist/update-path.d.ts.map +0 -1
  206. package/dist/update-path.js.map +0 -1
  207. package/src/__tests__/mutations.test.ts +0 -43
  208. package/src/events.ts +0 -8
  209. package/src/mutations.ts +0 -79
  210. package/src/schema/action.ts +0 -41
  211. package/src/storage/web-worker/worker.ts +0 -141
  212. /package/dist/{__tests__/react → react}/useQuery.test.d.ts +0 -0
  213. /package/dist/{__tests__/react → react}/useRow.test.d.ts +0 -0
  214. /package/dist/{__tests__/reactive.test.d.ts → reactive.test.d.ts} +0 -0
  215. /package/dist/{__tests__/reactiveQueries → reactiveQueries}/sql.test.d.ts +0 -0
@@ -11,24 +11,24 @@ export type AppState = {
11
11
  newTodoText: string;
12
12
  filter: Filter;
13
13
  };
14
- export declare const todos: DbSchema.TableDef<DbSchema.__SqliteDsl.TableDefinition<"todos", {
14
+ export declare const todos: DbSchema.TableDef<DbSchema.SqliteDsl.TableDefinition<"todos", {
15
15
  id: {
16
16
  columnType: "text";
17
- schema: import("@effect/schema/Schema").Schema<string, string>;
17
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
18
18
  default: import("effect/Option").None<never>;
19
19
  nullable: false;
20
20
  primaryKey: true;
21
- } & DbSchema.__SqliteDsl.ColumnDefinition<string, string>;
21
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
22
22
  text: {
23
23
  columnType: "text";
24
- schema: import("@effect/schema/Schema").Schema<string, string>;
24
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
25
25
  default: import("effect/Option").Some<"">;
26
26
  nullable: false;
27
27
  primaryKey: false;
28
28
  };
29
29
  completed: {
30
30
  columnType: "integer";
31
- schema: import("@effect/schema/Schema").Schema<number, boolean>;
31
+ schema: import("@effect/schema/Schema").Schema<never, number, boolean>;
32
32
  default: import("effect/Option").Some<false>;
33
33
  nullable: false;
34
34
  primaryKey: false;
@@ -37,7 +37,7 @@ export declare const todos: DbSchema.TableDef<DbSchema.__SqliteDsl.TableDefiniti
37
37
  isSingleton: false;
38
38
  dynamicRegistration: false;
39
39
  disableAutomaticIdColumn: false;
40
- }, import("@effect/schema/Schema").Schema<{
40
+ }, import("@effect/schema/Schema").Schema<never, {
41
41
  readonly id: string;
42
42
  readonly text: string;
43
43
  readonly completed: number;
@@ -46,54 +46,161 @@ export declare const todos: DbSchema.TableDef<DbSchema.__SqliteDsl.TableDefiniti
46
46
  readonly text: string;
47
47
  readonly completed: boolean;
48
48
  }>>;
49
+ export declare const app: DbSchema.TableDef<DbSchema.SqliteDsl.TableDefinition<"app", {
50
+ id: {
51
+ columnType: "text";
52
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
53
+ default: import("effect/Option").None<never>;
54
+ nullable: false;
55
+ primaryKey: true;
56
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
57
+ newTodoText: {
58
+ columnType: "text";
59
+ schema: import("@effect/schema/Schema").Schema<never, string | null, string | null>;
60
+ default: import("effect/Option").Some<"">;
61
+ nullable: true;
62
+ primaryKey: false;
63
+ };
64
+ filter: {
65
+ columnType: "text";
66
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
67
+ default: import("effect/Option").Some<"all">;
68
+ nullable: false;
69
+ primaryKey: false;
70
+ };
71
+ }>, false, {
72
+ isSingleton: false;
73
+ dynamicRegistration: false;
74
+ disableAutomaticIdColumn: false;
75
+ }, import("@effect/schema/Schema").Schema<never, {
76
+ readonly id: string;
77
+ readonly newTodoText: string | null;
78
+ readonly filter: string;
79
+ }, {
80
+ readonly id: string;
81
+ readonly newTodoText: string | null;
82
+ readonly filter: string;
83
+ }>>;
84
+ export declare const tables: {
85
+ todos: DbSchema.TableDef<DbSchema.SqliteDsl.TableDefinition<"todos", {
86
+ id: {
87
+ columnType: "text";
88
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
89
+ default: import("effect/Option").None<never>;
90
+ nullable: false;
91
+ primaryKey: true;
92
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
93
+ text: {
94
+ columnType: "text";
95
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
96
+ default: import("effect/Option").Some<"">;
97
+ nullable: false;
98
+ primaryKey: false;
99
+ };
100
+ completed: {
101
+ columnType: "integer";
102
+ schema: import("@effect/schema/Schema").Schema<never, number, boolean>;
103
+ default: import("effect/Option").Some<false>;
104
+ nullable: false;
105
+ primaryKey: false;
106
+ };
107
+ }>, false, {
108
+ isSingleton: false;
109
+ dynamicRegistration: false;
110
+ disableAutomaticIdColumn: false;
111
+ }, import("@effect/schema/Schema").Schema<never, {
112
+ readonly id: string;
113
+ readonly text: string;
114
+ readonly completed: number;
115
+ }, {
116
+ readonly id: string;
117
+ readonly text: string;
118
+ readonly completed: boolean;
119
+ }>>;
120
+ app: DbSchema.TableDef<DbSchema.SqliteDsl.TableDefinition<"app", {
121
+ id: {
122
+ columnType: "text";
123
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
124
+ default: import("effect/Option").None<never>;
125
+ nullable: false;
126
+ primaryKey: true;
127
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
128
+ newTodoText: {
129
+ columnType: "text";
130
+ schema: import("@effect/schema/Schema").Schema<never, string | null, string | null>;
131
+ default: import("effect/Option").Some<"">;
132
+ nullable: true;
133
+ primaryKey: false;
134
+ };
135
+ filter: {
136
+ columnType: "text";
137
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
138
+ default: import("effect/Option").Some<"all">;
139
+ nullable: false;
140
+ primaryKey: false;
141
+ };
142
+ }>, false, {
143
+ isSingleton: false;
144
+ dynamicRegistration: false;
145
+ disableAutomaticIdColumn: false;
146
+ }, import("@effect/schema/Schema").Schema<never, {
147
+ readonly id: string;
148
+ readonly newTodoText: string | null;
149
+ readonly filter: string;
150
+ }, {
151
+ readonly id: string;
152
+ readonly newTodoText: string | null;
153
+ readonly filter: string;
154
+ }>>;
155
+ };
49
156
  export declare const schema: import("../../index.js").LiveStoreSchema<{
50
- todos: DbSchema.__SqliteDsl.TableDefinition<"todos", {
157
+ todos: DbSchema.SqliteDsl.TableDefinition<"todos", {
51
158
  id: {
52
159
  columnType: "text";
53
- schema: import("@effect/schema/Schema").Schema<string, string>;
160
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
54
161
  default: import("effect/Option").None<never>;
55
162
  nullable: false;
56
163
  primaryKey: true;
57
- } & DbSchema.__SqliteDsl.ColumnDefinition<string, string>;
164
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
58
165
  text: {
59
166
  columnType: "text";
60
- schema: import("@effect/schema/Schema").Schema<string, string>;
167
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
61
168
  default: import("effect/Option").Some<"">;
62
169
  nullable: false;
63
170
  primaryKey: false;
64
171
  };
65
172
  completed: {
66
173
  columnType: "integer";
67
- schema: import("@effect/schema/Schema").Schema<number, boolean>;
174
+ schema: import("@effect/schema/Schema").Schema<never, number, boolean>;
68
175
  default: import("effect/Option").Some<false>;
69
176
  nullable: false;
70
177
  primaryKey: false;
71
178
  };
72
179
  }>;
73
- app: DbSchema.__SqliteDsl.TableDefinition<"app", {
180
+ app: DbSchema.SqliteDsl.TableDefinition<"app", {
74
181
  id: {
75
182
  columnType: "text";
76
- schema: import("@effect/schema/Schema").Schema<string, string>;
183
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
77
184
  default: import("effect/Option").None<never>;
78
185
  nullable: false;
79
186
  primaryKey: true;
80
- } & DbSchema.__SqliteDsl.ColumnDefinition<string, string>;
187
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
81
188
  newTodoText: {
82
189
  columnType: "text";
83
- schema: import("@effect/schema/Schema").Schema<string | null, string | null>;
190
+ schema: import("@effect/schema/Schema").Schema<never, string | null, string | null>;
84
191
  default: import("effect/Option").Some<"">;
85
192
  nullable: true;
86
193
  primaryKey: false;
87
194
  };
88
195
  filter: {
89
196
  columnType: "text";
90
- schema: import("@effect/schema/Schema").Schema<string, string>;
197
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
91
198
  default: import("effect/Option").Some<"all">;
92
199
  nullable: false;
93
200
  primaryKey: false;
94
201
  };
95
202
  }>;
96
- }>;
203
+ }, never>;
97
204
  export declare const parseTodos: (rawRows: readonly any[]) => readonly {
98
205
  text: string;
99
206
  id: string;
@@ -105,75 +212,143 @@ export declare const makeTodoMvc: ({ otelTracer, otelContext, useGlobalDbGraph,
105
212
  useGlobalDbGraph?: boolean | undefined;
106
213
  }) => Promise<{
107
214
  wrapper: ({ children }: any) => React.JSX.Element;
108
- AppComponentSchema: DbSchema.TableDef<DbSchema.__SqliteDsl.TableDefinition<"UserInfo", {
215
+ AppComponentSchema: DbSchema.TableDef<DbSchema.SqliteDsl.TableDefinition<"UserInfo", {
109
216
  username: {
110
217
  columnType: "text";
111
- schema: import("@effect/schema/Schema").Schema<string, string>;
218
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
112
219
  default: import("effect/Option").Some<"">;
113
220
  nullable: false;
114
221
  primaryKey: false;
115
222
  };
116
- id: DbSchema.__SqliteDsl.ColumnDefinition<string, string>;
223
+ id: DbSchema.SqliteDsl.ColumnDefinition<string, string>;
117
224
  }>, false, {
118
225
  isSingleton: false;
119
226
  dynamicRegistration: false;
120
227
  disableAutomaticIdColumn: false;
121
- }, import("@effect/schema/Schema").Schema<{
228
+ }, import("@effect/schema/Schema").Schema<never, {
122
229
  readonly username: string;
123
230
  readonly id: string;
124
231
  }, {
125
232
  readonly username: string;
126
233
  readonly id: string;
127
234
  }>>;
128
- store: import("../../store.js").Store<import("../../store.js").BaseGraphQLContext>;
129
- dbGraph: import("../../index.js").DbGraph;
130
- mutations: import("../../mutations.js").Mutations<{
131
- todos: DbSchema.__SqliteDsl.TableDefinition<"todos", {
235
+ store: import("../../store.js").Store<import("../../store.js").BaseGraphQLContext, import("../../index.js").LiveStoreSchema<{
236
+ todos: DbSchema.SqliteDsl.TableDefinition<"todos", {
132
237
  id: {
133
238
  columnType: "text";
134
- schema: import("@effect/schema/Schema").Schema<string, string>;
239
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
135
240
  default: import("effect/Option").None<never>;
136
241
  nullable: false;
137
242
  primaryKey: true;
138
- } & DbSchema.__SqliteDsl.ColumnDefinition<string, string>;
243
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
139
244
  text: {
140
245
  columnType: "text";
141
- schema: import("@effect/schema/Schema").Schema<string, string>;
246
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
142
247
  default: import("effect/Option").Some<"">;
143
248
  nullable: false;
144
249
  primaryKey: false;
145
250
  };
146
251
  completed: {
147
252
  columnType: "integer";
148
- schema: import("@effect/schema/Schema").Schema<number, boolean>;
253
+ schema: import("@effect/schema/Schema").Schema<never, number, boolean>;
149
254
  default: import("effect/Option").Some<false>;
150
255
  nullable: false;
151
256
  primaryKey: false;
152
257
  };
153
258
  }>;
154
- app: DbSchema.__SqliteDsl.TableDefinition<"app", {
259
+ app: DbSchema.SqliteDsl.TableDefinition<"app", {
155
260
  id: {
156
261
  columnType: "text";
157
- schema: import("@effect/schema/Schema").Schema<string, string>;
262
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
158
263
  default: import("effect/Option").None<never>;
159
264
  nullable: false;
160
265
  primaryKey: true;
161
- } & DbSchema.__SqliteDsl.ColumnDefinition<string, string>;
266
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
162
267
  newTodoText: {
163
268
  columnType: "text";
164
- schema: import("@effect/schema/Schema").Schema<string | null, string | null>;
269
+ schema: import("@effect/schema/Schema").Schema<never, string | null, string | null>;
165
270
  default: import("effect/Option").Some<"">;
166
271
  nullable: true;
167
272
  primaryKey: false;
168
273
  };
169
274
  filter: {
170
275
  columnType: "text";
171
- schema: import("@effect/schema/Schema").Schema<string, string>;
276
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
172
277
  default: import("effect/Option").Some<"all">;
173
278
  nullable: false;
174
279
  primaryKey: false;
175
280
  };
176
281
  }>;
177
- }>;
282
+ }, never>>;
283
+ dbGraph: import("../../index.js").DbGraph;
284
+ cud: import("../../cud.js").CudMutations<DbSchema.TableDef<DbSchema.SqliteDsl.TableDefinition<"todos", {
285
+ id: {
286
+ columnType: "text";
287
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
288
+ default: import("effect/Option").None<never>;
289
+ nullable: false;
290
+ primaryKey: true;
291
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
292
+ text: {
293
+ columnType: "text";
294
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
295
+ default: import("effect/Option").Some<"">;
296
+ nullable: false;
297
+ primaryKey: false;
298
+ };
299
+ completed: {
300
+ columnType: "integer";
301
+ schema: import("@effect/schema/Schema").Schema<never, number, boolean>;
302
+ default: import("effect/Option").Some<false>;
303
+ nullable: false;
304
+ primaryKey: false;
305
+ };
306
+ }>, false, {
307
+ isSingleton: false;
308
+ dynamicRegistration: false;
309
+ disableAutomaticIdColumn: false;
310
+ }, import("@effect/schema/Schema").Schema<never, {
311
+ readonly id: string;
312
+ readonly text: string;
313
+ readonly completed: number;
314
+ }, {
315
+ readonly id: string;
316
+ readonly text: string;
317
+ readonly completed: boolean;
318
+ }>> | DbSchema.TableDef<DbSchema.SqliteDsl.TableDefinition<"app", {
319
+ id: {
320
+ columnType: "text";
321
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
322
+ default: import("effect/Option").None<never>;
323
+ nullable: false;
324
+ primaryKey: true;
325
+ } & DbSchema.SqliteDsl.ColumnDefinition<string, string>;
326
+ newTodoText: {
327
+ columnType: "text";
328
+ schema: import("@effect/schema/Schema").Schema<never, string | null, string | null>;
329
+ default: import("effect/Option").Some<"">;
330
+ nullable: true;
331
+ primaryKey: false;
332
+ };
333
+ filter: {
334
+ columnType: "text";
335
+ schema: import("@effect/schema/Schema").Schema<never, string, string>;
336
+ default: import("effect/Option").Some<"all">;
337
+ nullable: false;
338
+ primaryKey: false;
339
+ };
340
+ }>, false, {
341
+ isSingleton: false;
342
+ dynamicRegistration: false;
343
+ disableAutomaticIdColumn: false;
344
+ }, import("@effect/schema/Schema").Schema<never, {
345
+ readonly id: string;
346
+ readonly newTodoText: string | null;
347
+ readonly filter: string;
348
+ }, {
349
+ readonly id: string;
350
+ readonly newTodoText: string | null;
351
+ readonly filter: string;
352
+ }>>>;
178
353
  }>;
179
354
  //# sourceMappingURL=fixture.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"fixture.d.ts","sourceRoot":"","sources":["../../../src/__tests__/react/fixture.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAC/C,OAAO,KAAK,MAAM,OAAO,CAAA;AAKzB,OAAO,EAAe,QAAQ,EAA2D,MAAM,gBAAgB,CAAA;AAI/G,MAAM,MAAM,IAAI,GAAG;IACjB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,SAAS,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,MAAM,MAAM,MAAM,GAAG,KAAK,GAAG,QAAQ,GAAG,WAAW,CAAA;AAEnD,MAAM,MAAM,QAAQ,GAAG;IACrB,WAAW,EAAE,MAAM,CAAA;IACnB,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AAED,eAAO,MAAM,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAIhB,CAAA;AAEF,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0BjB,CAAA;AAEF,eAAO,MAAM,UAAU;;;;GAAyB,CAAA;AAEhD,eAAO,MAAM,WAAW;;;;;4BAkCS,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAKnC,CAAA"}
1
+ {"version":3,"file":"fixture.d.ts","sourceRoot":"","sources":["../../../src/__tests__/react/fixture.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAC/C,OAAO,KAAK,MAAM,OAAO,CAAA;AAKzB,OAAO,EAAe,QAAQ,EAA8D,MAAM,gBAAgB,CAAA;AAIlH,MAAM,MAAM,IAAI,GAAG;IACjB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,SAAS,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,MAAM,MAAM,MAAM,GAAG,KAAK,GAAG,QAAQ,GAAG,WAAW,CAAA;AAEnD,MAAM,MAAM,QAAQ,GAAG;IACrB,WAAW,EAAE,MAAM,CAAA;IACnB,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AAED,eAAO,MAAM,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAIhB,CAAA;AAEF,eAAO,MAAM,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAId,CAAA;AAEF,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAiB,CAAA;AACpC,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAAyB,CAAA;AAE5C,eAAO,MAAM,UAAU;;;;GAAyB,CAAA;AAEhD,eAAO,MAAM,WAAW;;;;;4BAmCS,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAKnC,CAAA"}
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
2
  import initSqlite3Wasm from 'sqlite-esm';
3
3
  import { globalDbGraph } from '../../global-state.js';
4
- import { createStore, DbSchema, makeDbGraph, makeMutations, makeSchema, ParseUtils, sql } from '../../index.js';
4
+ import { createStore, DbSchema, makeCudMutations, makeDbGraph, makeSchema, ParseUtils, sql } from '../../index.js';
5
5
  import * as LiveStoreReact from '../../react/index.js';
6
6
  import { InMemoryStorage } from '../../storage/in-memory/index.js';
7
7
  export const todos = DbSchema.table('todos', {
@@ -9,33 +9,13 @@ export const todos = DbSchema.table('todos', {
9
9
  text: DbSchema.text({ default: '', nullable: false }),
10
10
  completed: DbSchema.boolean({ default: false, nullable: false }),
11
11
  });
12
- export const schema = makeSchema({
13
- tables: {
14
- todos,
15
- app: DbSchema.table('app', {
16
- id: DbSchema.text({ primaryKey: true }),
17
- newTodoText: DbSchema.text({ default: '', nullable: true }),
18
- filter: DbSchema.text({ default: 'all', nullable: false }),
19
- }),
20
- },
21
- actions: {
22
- // TODO: fix these actions to make them have write annotatinos
23
- addTodo: {
24
- statement: {
25
- sql: sql `INSERT INTO todos (id, text, completed) VALUES ($id, $text, false);`,
26
- writeTables: ['app'],
27
- },
28
- },
29
- completeTodo: { statement: { sql: sql `UPDATE todos SET completed = true WHERE id = $id;`, writeTables: ['app'] } },
30
- uncompleteTodo: {
31
- statement: { sql: sql `UPDATE todos SET completed = false WHERE id = $id;`, writeTables: ['app'] },
32
- },
33
- deleteTodo: { statement: { sql: sql `DELETE FROM todos WHERE id = $id;`, writeTables: ['app'] } },
34
- clearCompleted: { statement: { sql: sql `DELETE FROM todos WHERE completed = true;`, writeTables: ['app'] } },
35
- updateNewTodoText: { statement: { sql: sql `UPDATE app SET newTodoText = $text;`, writeTables: ['app'] } },
36
- setFilter: { statement: { sql: sql `UPDATE app SET filter = $filter;`, writeTables: ['app'] } },
37
- },
12
+ export const app = DbSchema.table('app', {
13
+ id: DbSchema.text({ primaryKey: true }),
14
+ newTodoText: DbSchema.text({ default: '', nullable: true }),
15
+ filter: DbSchema.text({ default: 'all', nullable: false }),
38
16
  });
17
+ export const tables = { todos, app };
18
+ export const schema = makeSchema({ tables });
39
19
  export const parseTodos = ParseUtils.many(todos);
40
20
  export const makeTodoMvc = async ({ otelTracer, otelContext, useGlobalDbGraph = true, } = {}) => {
41
21
  const AppComponentSchema = DbSchema.table('UserInfo', {
@@ -55,9 +35,10 @@ export const makeTodoMvc = async ({ otelTracer, otelContext, useGlobalDbGraph =
55
35
  otelTracer,
56
36
  otelRootSpanContext: otelContext,
57
37
  });
58
- const mutations = makeMutations(schema);
38
+ const cud = makeCudMutations(tables);
39
+ // TODO improve typing of `LiveStoreContext`
59
40
  const storeContext = { store };
60
41
  const wrapper = ({ children }) => (React.createElement(LiveStoreReact.LiveStoreContext.Provider, { value: storeContext }, children));
61
- return { wrapper, AppComponentSchema, store, dbGraph, mutations };
42
+ return { wrapper, AppComponentSchema, store, dbGraph, cud };
62
43
  };
63
44
  //# sourceMappingURL=fixture.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fixture.js","sourceRoot":"","sources":["../../../src/__tests__/react/fixture.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"fixture.js","sourceRoot":"","sources":["../../../src/__tests__/react/fixture.tsx"],"names":[],"mappings":"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"}
package/dist/cud.d.ts ADDED
@@ -0,0 +1,28 @@
1
+ import type { SqliteDsl } from 'effect-db-schema';
2
+ import type { RowResult } from './row-query.js';
3
+ import { type RawSqlMutationEvent } from './schema/index.js';
4
+ import { type TableDef } from './schema/table-def.js';
5
+ import { type GetValForKey } from './utils/util.js';
6
+ export declare const makeCudMutations: <TTableDef extends TableDef>(tables: Iterable<TTableDef> | Record<string, TTableDef>) => CudMutations<TTableDef>;
7
+ export type UpdateMutation<TTableDef extends TableDef> = (args: {
8
+ where: Partial<RowResult<TTableDef>>;
9
+ values: Partial<RowResult<TTableDef>>;
10
+ }) => RawSqlMutationEvent;
11
+ export type RowInsert<TTableDef extends TableDef> = TTableDef['isSingleColumn'] extends true ? GetValForKey<SqliteDsl.FromColumns.InsertRowDecoded<TTableDef['sqliteDef']['columns']>, 'value'> : SqliteDsl.FromColumns.InsertRowDecoded<TTableDef['sqliteDef']['columns']>;
12
+ export type InsertMutation<TTableDef extends TableDef> = (values: RowInsert<TTableDef>) => RawSqlMutationEvent;
13
+ export type DeleteMutation<TTableDef extends TableDef> = (args: {
14
+ where: Partial<RowResult<TTableDef>>;
15
+ }) => RawSqlMutationEvent;
16
+ export type CudMutation<TTableDef extends TableDef> = {
17
+ insert: InsertMutation<TTableDef>;
18
+ update: UpdateMutation<TTableDef>;
19
+ delete: DeleteMutation<TTableDef>;
20
+ };
21
+ export type CudMutations<TTableDef extends TableDef> = {
22
+ [TTableName in TTableDef['sqliteDef']['name']]: CudMutation<Extract<TTableDef, {
23
+ sqliteDef: {
24
+ name: TTableName;
25
+ };
26
+ }>>;
27
+ };
28
+ //# sourceMappingURL=cud.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cud.d.ts","sourceRoot":"","sources":["../src/cud.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAEjD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAkB,KAAK,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AAC5E,OAAO,EAA2B,KAAK,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAC9E,OAAO,EAAE,KAAK,YAAY,EAAc,MAAM,iBAAiB,CAAA;AAE/D,eAAO,MAAM,gBAAgB,kHAa5B,CAAA;AA6CD,MAAM,MAAM,cAAc,CAAC,SAAS,SAAS,QAAQ,IAAI,CAAC,IAAI,EAAE;IAE9D,KAAK,EAAE,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAA;IACpC,MAAM,EAAE,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAA;CACtC,KAAK,mBAAmB,CAAA;AAEzB,MAAM,MAAM,SAAS,CAAC,SAAS,SAAS,QAAQ,IAAI,SAAS,CAAC,gBAAgB,CAAC,SAAS,IAAI,GACxF,YAAY,CAAC,SAAS,CAAC,WAAW,CAAC,gBAAgB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,OAAO,CAAC,GAChG,SAAS,CAAC,WAAW,CAAC,gBAAgB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,CAAA;AAE7E,MAAM,MAAM,cAAc,CAAC,SAAS,SAAS,QAAQ,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,SAAS,CAAC,KAAK,mBAAmB,CAAA;AAE9G,MAAM,MAAM,cAAc,CAAC,SAAS,SAAS,QAAQ,IAAI,CAAC,IAAI,EAAE;IAC9D,KAAK,EAAE,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAA;CACrC,KAAK,mBAAmB,CAAA;AAEzB,MAAM,MAAM,WAAW,CAAC,SAAS,SAAS,QAAQ,IAAI;IACpD,MAAM,EAAE,cAAc,CAAC,SAAS,CAAC,CAAA;IACjC,MAAM,EAAE,cAAc,CAAC,SAAS,CAAC,CAAA;IACjC,MAAM,EAAE,cAAc,CAAC,SAAS,CAAC,CAAA;CAClC,CAAA;AAED,MAAM,MAAM,YAAY,CAAC,SAAS,SAAS,QAAQ,IAAI;KACpD,UAAU,IAAI,SAAS,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,GAAG,WAAW,CAAC,OAAO,CAAC,SAAS,EAAE;QAAE,SAAS,EAAE;YAAE,IAAI,EAAE,UAAU,CAAA;SAAE,CAAA;KAAE,CAAC,CAAC;CACrH,CAAA"}
package/dist/cud.js ADDED
@@ -0,0 +1,50 @@
1
+ import * as SqlQueries from '@livestore/sql-queries';
2
+ import { pipe, ReadonlyRecord } from '@livestore/utils/effect';
3
+ import { rawSqlMutation } from './schema/index.js';
4
+ import { getDefaultValuesEncoded } from './schema/table-def.js';
5
+ import { isIterable } from './utils/util.js';
6
+ export const makeCudMutations = (tables) => {
7
+ const cudMutationRecord = {};
8
+ const tables_ = isIterable(tables) ? tables : Object.values(tables);
9
+ for (const tableDef of tables_) {
10
+ const [tableName, cudMutation] = cudMutationsForTable(tableDef);
11
+ cudMutationRecord[tableName] = cudMutation;
12
+ }
13
+ return cudMutationRecord;
14
+ };
15
+ const cudMutationsForTable = (tableDef) => {
16
+ const table = tableDef.sqliteDef;
17
+ const writeTables = new Set([table.name]);
18
+ const api = {
19
+ insert: (values_) => {
20
+ const defaultValues = getDefaultValuesEncoded(tableDef);
21
+ const values = pipe(tableDef.sqliteDef.columns, ReadonlyRecord.map((_, columnName) => values_?.[columnName] ?? defaultValues[columnName]));
22
+ const [sql, bindValues] = SqlQueries.insertRow({
23
+ tableName: table.name,
24
+ columns: table.columns,
25
+ options: { orReplace: false },
26
+ values: values,
27
+ });
28
+ return rawSqlMutation({ sql, bindValues, writeTables });
29
+ },
30
+ update: ({ where, values }) => {
31
+ const [sql, bindValues] = SqlQueries.updateRows({
32
+ tableName: table.name,
33
+ columns: table.columns,
34
+ where: where,
35
+ updateValues: values,
36
+ });
37
+ return rawSqlMutation({ sql, bindValues, writeTables });
38
+ },
39
+ delete: ({ where }) => {
40
+ const [sql, bindValues] = SqlQueries.deleteRows({
41
+ tableName: table.name,
42
+ columns: table.columns,
43
+ where: where,
44
+ });
45
+ return rawSqlMutation({ sql, bindValues, writeTables });
46
+ },
47
+ };
48
+ return [tableDef.sqliteDef.name, api];
49
+ };
50
+ //# sourceMappingURL=cud.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cud.js","sourceRoot":"","sources":["../src/cud.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=cud.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cud.test.d.ts","sourceRoot":"","sources":["../src/cud.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,47 @@
1
+ import { describe, expect, test } from 'vitest';
2
+ import { tables } from './__tests__/react/fixture.js';
3
+ import { makeCudMutations } from './cud.js';
4
+ describe('cud mutations', () => {
5
+ const cud = makeCudMutations(tables);
6
+ test('basic', () => {
7
+ expect(patchId(cud.todos.insert({ id: 't1', completed: true, text: 'Task 1' }))).toMatchInlineSnapshot(`
8
+ {
9
+ "args": {
10
+ "bindValues": {
11
+ "completed": 1,
12
+ "id": "t1",
13
+ "text": "Task 1",
14
+ },
15
+ "sql": "INSERT INTO todos (id, text, completed) VALUES ($id, $text, $completed)",
16
+ "writeTables": Set {
17
+ "todos",
18
+ },
19
+ },
20
+ "id": "00000000-0000-0000-0000-000000000000",
21
+ "mutation": "livestore.RawSql",
22
+ }
23
+ `);
24
+ expect(patchId(cud.todos.update({ where: { id: 't1' }, values: { text: 'Task 1 - fixed' } })))
25
+ .toMatchInlineSnapshot(`
26
+ {
27
+ "args": {
28
+ "bindValues": {
29
+ "update_text": "Task 1 - fixed",
30
+ "where_id": "t1",
31
+ },
32
+ "sql": "UPDATE todos SET text = $update_text WHERE id = $where_id",
33
+ "writeTables": Set {
34
+ "todos",
35
+ },
36
+ },
37
+ "id": "00000000-0000-0000-0000-000000000000",
38
+ "mutation": "livestore.RawSql",
39
+ }
40
+ `);
41
+ });
42
+ });
43
+ const patchId = (muationEvent) => {
44
+ const id = `00000000-0000-0000-0000-000000000000`;
45
+ return { ...muationEvent, id };
46
+ };
47
+ //# sourceMappingURL=cud.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cud.test.js","sourceRoot":"","sources":["../src/cud.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAE/C,OAAO,EAAE,MAAM,EAAE,MAAM,8BAA8B,CAAA;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAG3C,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,MAAM,GAAG,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAA;IAEpC,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE;QACjB,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC;;;;;;;;;;;;;;;;KAgBtG,CAAC,CAAA;QAEF,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,EAAE,CAAC,CAAC,CAAC;aAC3F,qBAAqB,CAAC;;;;;;;;;;;;;;;OAetB,CAAC,CAAA;IACN,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,MAAM,OAAO,GAAG,CAAC,YAA+B,EAAE,EAAE;IAClD,MAAM,EAAE,GAAG,sCAAsC,CAAA;IACjD,OAAO,EAAE,GAAG,YAAY,EAAE,EAAE,EAAE,CAAA;AAChC,CAAC,CAAA"}
@@ -39,7 +39,7 @@ export declare class InMemoryDatabase {
39
39
  }): InMemoryDatabase;
40
40
  txn<TRes>(callback: () => TRes): TRes;
41
41
  getTablesUsed(query: string): Set<string>;
42
- execute(query: string, bindValues?: PreparedBindValues, writeTables?: ReadonlyArray<string>, options?: {
42
+ execute(query: string, bindValues?: PreparedBindValues, writeTables?: ReadonlySet<string>, options?: {
43
43
  hasNoEffects?: boolean;
44
44
  otelContext?: otel.Context;
45
45
  }): {
@@ -1 +1 @@
1
- {"version":3,"file":"inMemoryDatabase.d.ts","sourceRoot":"","sources":["../src/inMemoryDatabase.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAC/C,OAAO,KAAK,KAAK,MAAM,MAAM,YAAY,CAAA;AAKzC,OAAiB,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAA;AAErE,OAAO,KAAK,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAEnE,KAAK,gBAAgB,GAAG,MAAM,CAAC,QAAQ,GAAG;IAAE,IAAI,EAAE,MAAM,CAAC,IAAI,CAAA;CAAE,CAAA;AAE/D,MAAM,WAAW,SAAS;IACxB,WAAW,EAAE,UAAU,CAAC,aAAa,CAAC,CAAA;IACtC,kBAAkB,EAAE,MAAM,CAAA;IAC1B,eAAe,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,UAAU,CAAC,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAA;CACzE;AAED,MAAM,MAAM,aAAa,GAAG;IAC1B,QAAQ,EAAE,MAAM;IAChB,UAAU,EAAE,kBAAkB,GAAG,SAAS;IAC1C,UAAU,EAAE,MAAM;IAClB,SAAS,EAAE,MAAM,GAAG,SAAS;IAC7B,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC;IAC1B,gBAAgB,EAAE,mBAAmB;CACtC,CAAA;AAED,eAAO,MAAM,cAAc,QAAO,SAKhC,CAAA;AAEF,qBAAa,gBAAgB;IASzB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,mBAAmB;IACpB,GAAG,EAAE,MAAM,CAAC,aAAa;IAVlC,OAAO,CAAC,WAAW,CAAsD;IACzE,OAAO,CAAC,eAAe,CAAyC;IAChE,OAAO,CAAC,WAAW,CAAmB;IACtC,OAAO,CAAC,cAAc,CAAA;IACf,SAAS,EAAE,SAAS,CAAmB;gBAGpC,EAAE,EAAE,gBAAgB,EACpB,UAAU,EAAE,IAAI,CAAC,MAAM,EACvB,mBAAmB,EAAE,IAAI,CAAC,OAAO,EAClC,GAAG,EAAE,MAAM,CAAC,aAAa;IAOlC,MAAM,CAAC,IAAI,CAAC,EACV,IAAI,EACJ,UAAU,EACV,mBAAmB,EACnB,OAAO,GACR,EAAE;QACD,IAAI,EAAE,UAAU,GAAG,SAAS,CAAA;QAC5B,UAAU,EAAE,IAAI,CAAC,MAAM,CAAA;QACvB,mBAAmB,EAAE,IAAI,CAAC,OAAO,CAAA;QACjC,OAAO,EAAE,MAAM,CAAC,aAAa,CAAA;KAC9B,GAAG,gBAAgB;IA4BpB,GAAG,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,IAAI,GAAG,IAAI;IAoBrC,aAAa,CAAC,KAAK,EAAE,MAAM;IAsB3B,OAAO,CACL,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,kBAAkB,EAC/B,WAAW,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC,EACnC,OAAO,CAAC,EAAE;QAAE,YAAY,CAAC,EAAE,OAAO,CAAC;QAAC,WAAW,CAAC,EAAE,IAAI,CAAC,OAAO,CAAA;KAAE,GAC/D;QAAE,UAAU,EAAE,MAAM,CAAA;KAAE;IAmEzB,MAAM,CAAC,CAAC,GAAG,GAAG,EACZ,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE;QACR,aAAa,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;QAC3B,UAAU,CAAC,EAAE,kBAAkB,CAAA;QAC/B,SAAS,CAAC,EAAE,OAAO,CAAA;QACnB,WAAW,CAAC,EAAE,IAAI,CAAC,OAAO,CAAA;KAC3B,GACA,aAAa,CAAC,CAAC,CAAC;IA4FnB,MAAM;CAQP"}
1
+ {"version":3,"file":"inMemoryDatabase.d.ts","sourceRoot":"","sources":["../src/inMemoryDatabase.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAC/C,OAAO,KAAK,KAAK,MAAM,MAAM,YAAY,CAAA;AAKzC,OAAiB,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAA;AAErE,OAAO,KAAK,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAEnE,KAAK,gBAAgB,GAAG,MAAM,CAAC,QAAQ,GAAG;IAAE,IAAI,EAAE,MAAM,CAAC,IAAI,CAAA;CAAE,CAAA;AAE/D,MAAM,WAAW,SAAS;IACxB,WAAW,EAAE,UAAU,CAAC,aAAa,CAAC,CAAA;IACtC,kBAAkB,EAAE,MAAM,CAAA;IAC1B,eAAe,EAAE,MAAM,CAAA;IACvB,MAAM,EAAE,UAAU,CAAC,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAA;CACzE;AAED,MAAM,MAAM,aAAa,GAAG;IAC1B,QAAQ,EAAE,MAAM;IAChB,UAAU,EAAE,kBAAkB,GAAG,SAAS;IAC1C,UAAU,EAAE,MAAM;IAClB,SAAS,EAAE,MAAM,GAAG,SAAS;IAC7B,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC;IAC1B,gBAAgB,EAAE,mBAAmB;CACtC,CAAA;AAED,eAAO,MAAM,cAAc,QAAO,SAKhC,CAAA;AAEF,qBAAa,gBAAgB;IASzB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,mBAAmB;IACpB,GAAG,EAAE,MAAM,CAAC,aAAa;IAVlC,OAAO,CAAC,WAAW,CAAsD;IACzE,OAAO,CAAC,eAAe,CAAyC;IAChE,OAAO,CAAC,WAAW,CAAmB;IACtC,OAAO,CAAC,cAAc,CAAA;IACf,SAAS,EAAE,SAAS,CAAmB;gBAGpC,EAAE,EAAE,gBAAgB,EACpB,UAAU,EAAE,IAAI,CAAC,MAAM,EACvB,mBAAmB,EAAE,IAAI,CAAC,OAAO,EAClC,GAAG,EAAE,MAAM,CAAC,aAAa;IAOlC,MAAM,CAAC,IAAI,CAAC,EACV,IAAI,EACJ,UAAU,EACV,mBAAmB,EACnB,OAAO,GACR,EAAE;QACD,IAAI,EAAE,UAAU,GAAG,SAAS,CAAA;QAC5B,UAAU,EAAE,IAAI,CAAC,MAAM,CAAA;QACvB,mBAAmB,EAAE,IAAI,CAAC,OAAO,CAAA;QACjC,OAAO,EAAE,MAAM,CAAC,aAAa,CAAA;KAC9B,GAAG,gBAAgB;IA4BpB,GAAG,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,IAAI,GAAG,IAAI;IAoBrC,aAAa,CAAC,KAAK,EAAE,MAAM;IAsB3B,OAAO,CACL,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,kBAAkB,EAC/B,WAAW,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,EACjC,OAAO,CAAC,EAAE;QAAE,YAAY,CAAC,EAAE,OAAO,CAAC;QAAC,WAAW,CAAC,EAAE,IAAI,CAAC,OAAO,CAAA;KAAE,GAC/D;QAAE,UAAU,EAAE,MAAM,CAAA;KAAE;IA8DzB,MAAM,CAAC,CAAC,GAAG,GAAG,EACZ,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE;QACR,aAAa,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;QAC3B,UAAU,CAAC,EAAE,kBAAkB,CAAA;QAC/B,SAAS,CAAC,EAAE,OAAO,CAAA;QACnB,WAAW,CAAC,EAAE,IAAI,CAAC,OAAO,CAAA;KAC3B,GACA,aAAa,CAAC,CAAC,CAAC;IA4FnB,MAAM;CAQP"}
@@ -109,10 +109,7 @@ export class InMemoryDatabase {
109
109
  }
110
110
  }
111
111
  catch (error) {
112
- shouldNeverHappen(`Error executing query: ${error} \n ${JSON.stringify({
113
- query,
114
- bindValues,
115
- })}`);
112
+ shouldNeverHappen(`Error executing query: ${error} \n ${JSON.stringify({ query, bindValues })}`);
116
113
  }
117
114
  if (options?.hasNoEffects !== true && !this.resultCache.ignoreQuery(query)) {
118
115
  // TODO use write tables instead