spacetimedb 0.0.2 → 0.0.3

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 (278) hide show
  1. package/dist/browser/react/index.mjs.map +1 -1
  2. package/dist/index.browser.mjs +18 -4
  3. package/dist/index.browser.mjs.map +1 -1
  4. package/dist/index.cjs +18 -16
  5. package/dist/index.cjs.map +1 -1
  6. package/dist/index.d.ts +13 -0
  7. package/dist/index.d.ts.map +1 -0
  8. package/dist/index.mjs +18 -16
  9. package/dist/index.mjs.map +1 -1
  10. package/dist/lib/algebraic_type.d.ts +115 -0
  11. package/dist/lib/algebraic_type.d.ts.map +1 -0
  12. package/dist/lib/algebraic_value.d.ts +6 -0
  13. package/dist/lib/algebraic_value.d.ts.map +1 -0
  14. package/dist/lib/autogen/algebraic_type_type.d.ts +64 -0
  15. package/dist/lib/autogen/algebraic_type_type.d.ts.map +1 -0
  16. package/dist/lib/autogen/algebraic_type_variants.d.ts +68 -0
  17. package/dist/lib/autogen/algebraic_type_variants.d.ts.map +1 -0
  18. package/dist/lib/autogen/index_type_type.d.ts +16 -0
  19. package/dist/lib/autogen/index_type_type.d.ts.map +1 -0
  20. package/dist/lib/autogen/index_type_variants.d.ts +7 -0
  21. package/dist/lib/autogen/index_type_variants.d.ts.map +1 -0
  22. package/dist/lib/autogen/lifecycle_type.d.ts +19 -0
  23. package/dist/lib/autogen/lifecycle_type.d.ts.map +1 -0
  24. package/dist/lib/autogen/lifecycle_variants.d.ts +10 -0
  25. package/dist/lib/autogen/lifecycle_variants.d.ts.map +1 -0
  26. package/dist/lib/autogen/misc_module_export_type.d.ts +12 -0
  27. package/dist/lib/autogen/misc_module_export_type.d.ts.map +1 -0
  28. package/dist/lib/autogen/misc_module_export_variants.d.ts +6 -0
  29. package/dist/lib/autogen/misc_module_export_variants.d.ts.map +1 -0
  30. package/dist/lib/autogen/product_type_element_type.d.ts +20 -0
  31. package/dist/lib/autogen/product_type_element_type.d.ts.map +1 -0
  32. package/dist/lib/autogen/product_type_type.d.ts +19 -0
  33. package/dist/lib/autogen/product_type_type.d.ts.map +1 -0
  34. package/dist/lib/autogen/raw_column_def_v_8_type.d.ts +20 -0
  35. package/dist/lib/autogen/raw_column_def_v_8_type.d.ts.map +1 -0
  36. package/dist/lib/autogen/raw_column_default_value_v_9_type.d.ts +20 -0
  37. package/dist/lib/autogen/raw_column_default_value_v_9_type.d.ts.map +1 -0
  38. package/dist/lib/autogen/raw_constraint_data_v_9_type.d.ts +12 -0
  39. package/dist/lib/autogen/raw_constraint_data_v_9_type.d.ts.map +1 -0
  40. package/dist/lib/autogen/raw_constraint_data_v_9_variants.d.ts +6 -0
  41. package/dist/lib/autogen/raw_constraint_data_v_9_variants.d.ts.map +1 -0
  42. package/dist/lib/autogen/raw_constraint_def_v_8_type.d.ts +20 -0
  43. package/dist/lib/autogen/raw_constraint_def_v_8_type.d.ts.map +1 -0
  44. package/dist/lib/autogen/raw_constraint_def_v_9_type.d.ts +20 -0
  45. package/dist/lib/autogen/raw_constraint_def_v_9_type.d.ts.map +1 -0
  46. package/dist/lib/autogen/raw_index_algorithm_type.d.ts +13 -0
  47. package/dist/lib/autogen/raw_index_algorithm_type.d.ts.map +1 -0
  48. package/dist/lib/autogen/raw_index_algorithm_variants.d.ts +13 -0
  49. package/dist/lib/autogen/raw_index_algorithm_variants.d.ts.map +1 -0
  50. package/dist/lib/autogen/raw_index_def_v_8_type.d.ts +22 -0
  51. package/dist/lib/autogen/raw_index_def_v_8_type.d.ts.map +1 -0
  52. package/dist/lib/autogen/raw_index_def_v_9_type.d.ts +21 -0
  53. package/dist/lib/autogen/raw_index_def_v_9_type.d.ts.map +1 -0
  54. package/dist/lib/autogen/raw_misc_module_export_v_9_type.d.ts +12 -0
  55. package/dist/lib/autogen/raw_misc_module_export_v_9_type.d.ts.map +1 -0
  56. package/dist/lib/autogen/raw_misc_module_export_v_9_variants.d.ts +6 -0
  57. package/dist/lib/autogen/raw_misc_module_export_v_9_variants.d.ts.map +1 -0
  58. package/dist/lib/autogen/raw_module_def_type.d.ts +14 -0
  59. package/dist/lib/autogen/raw_module_def_type.d.ts.map +1 -0
  60. package/dist/lib/autogen/raw_module_def_v_8_type.d.ts +25 -0
  61. package/dist/lib/autogen/raw_module_def_v_8_type.d.ts.map +1 -0
  62. package/dist/lib/autogen/raw_module_def_v_9_type.d.ts +29 -0
  63. package/dist/lib/autogen/raw_module_def_v_9_type.d.ts.map +1 -0
  64. package/dist/lib/autogen/raw_module_def_variants.d.ts +11 -0
  65. package/dist/lib/autogen/raw_module_def_variants.d.ts.map +1 -0
  66. package/dist/lib/autogen/raw_reducer_def_v_9_type.d.ts +22 -0
  67. package/dist/lib/autogen/raw_reducer_def_v_9_type.d.ts.map +1 -0
  68. package/dist/lib/autogen/raw_row_level_security_def_v_9_type.d.ts +18 -0
  69. package/dist/lib/autogen/raw_row_level_security_def_v_9_type.d.ts.map +1 -0
  70. package/dist/lib/autogen/raw_schedule_def_v_9_type.d.ts +20 -0
  71. package/dist/lib/autogen/raw_schedule_def_v_9_type.d.ts.map +1 -0
  72. package/dist/lib/autogen/raw_scoped_type_name_v_9_type.d.ts +19 -0
  73. package/dist/lib/autogen/raw_scoped_type_name_v_9_type.d.ts.map +1 -0
  74. package/dist/lib/autogen/raw_sequence_def_v_8_type.d.ts +24 -0
  75. package/dist/lib/autogen/raw_sequence_def_v_8_type.d.ts.map +1 -0
  76. package/dist/lib/autogen/raw_sequence_def_v_9_type.d.ts +23 -0
  77. package/dist/lib/autogen/raw_sequence_def_v_9_type.d.ts.map +1 -0
  78. package/dist/lib/autogen/raw_table_def_v_8_type.d.ts +29 -0
  79. package/dist/lib/autogen/raw_table_def_v_8_type.d.ts.map +1 -0
  80. package/dist/lib/autogen/raw_table_def_v_9_type.d.ts +32 -0
  81. package/dist/lib/autogen/raw_table_def_v_9_type.d.ts.map +1 -0
  82. package/dist/lib/autogen/raw_type_def_v_9_type.d.ts +21 -0
  83. package/dist/lib/autogen/raw_type_def_v_9_type.d.ts.map +1 -0
  84. package/dist/lib/autogen/raw_unique_constraint_data_v_9_type.d.ts +18 -0
  85. package/dist/lib/autogen/raw_unique_constraint_data_v_9_type.d.ts.map +1 -0
  86. package/dist/lib/autogen/reducer_def_type.d.ts +20 -0
  87. package/dist/lib/autogen/reducer_def_type.d.ts.map +1 -0
  88. package/dist/lib/autogen/sum_type_type.d.ts +19 -0
  89. package/dist/lib/autogen/sum_type_type.d.ts.map +1 -0
  90. package/dist/lib/autogen/sum_type_variant_type.d.ts +20 -0
  91. package/dist/lib/autogen/sum_type_variant_type.d.ts.map +1 -0
  92. package/dist/lib/autogen/table_access_type.d.ts +16 -0
  93. package/dist/lib/autogen/table_access_type.d.ts.map +1 -0
  94. package/dist/lib/autogen/table_access_variants.d.ts +7 -0
  95. package/dist/lib/autogen/table_access_variants.d.ts.map +1 -0
  96. package/dist/lib/autogen/table_desc_type.d.ts +20 -0
  97. package/dist/lib/autogen/table_desc_type.d.ts.map +1 -0
  98. package/dist/lib/autogen/table_type_type.d.ts +16 -0
  99. package/dist/lib/autogen/table_type_type.d.ts.map +1 -0
  100. package/dist/lib/autogen/table_type_variants.d.ts +7 -0
  101. package/dist/lib/autogen/table_type_variants.d.ts.map +1 -0
  102. package/dist/lib/autogen/type_alias_type.d.ts +19 -0
  103. package/dist/lib/autogen/type_alias_type.d.ts.map +1 -0
  104. package/dist/lib/autogen/typespace_type.d.ts +19 -0
  105. package/dist/lib/autogen/typespace_type.d.ts.map +1 -0
  106. package/dist/lib/binary_reader.d.ts +25 -0
  107. package/dist/lib/binary_reader.d.ts.map +1 -0
  108. package/dist/lib/binary_writer.d.ts +25 -0
  109. package/dist/lib/binary_writer.d.ts.map +1 -0
  110. package/dist/lib/connection_id.d.ts +37 -0
  111. package/dist/lib/connection_id.d.ts.map +1 -0
  112. package/dist/lib/identity.d.ts +39 -0
  113. package/dist/lib/identity.d.ts.map +1 -0
  114. package/dist/lib/schedule_at.d.ts +23 -0
  115. package/dist/lib/schedule_at.d.ts.map +1 -0
  116. package/dist/lib/time_duration.d.ts +18 -0
  117. package/dist/lib/time_duration.d.ts.map +1 -0
  118. package/dist/lib/timestamp.d.ts +35 -0
  119. package/dist/lib/timestamp.d.ts.map +1 -0
  120. package/dist/lib/utils.d.ts +13 -0
  121. package/dist/lib/utils.d.ts.map +1 -0
  122. package/dist/min/index.browser.mjs +1 -1
  123. package/dist/min/index.browser.mjs.map +1 -1
  124. package/dist/min/react/index.mjs.map +1 -1
  125. package/dist/min/sdk/index.browser.mjs +1 -1
  126. package/dist/min/sdk/index.browser.mjs.map +1 -1
  127. package/dist/react/SpacetimeDBProvider.d.ts +8 -0
  128. package/dist/react/SpacetimeDBProvider.d.ts.map +1 -0
  129. package/dist/react/index.cjs.map +1 -1
  130. package/dist/react/index.d.ts +4 -0
  131. package/dist/react/index.d.ts.map +1 -0
  132. package/dist/react/index.mjs.map +1 -1
  133. package/dist/react/useSpacetimeDB.d.ts +5 -0
  134. package/dist/react/useSpacetimeDB.d.ts.map +1 -0
  135. package/dist/react/useTable.d.ts +120 -0
  136. package/dist/react/useTable.d.ts.map +1 -0
  137. package/dist/sdk/client_api/bsatn_row_list_type.d.ts +20 -0
  138. package/dist/sdk/client_api/bsatn_row_list_type.d.ts.map +1 -0
  139. package/dist/sdk/client_api/call_reducer_type.d.ts +21 -0
  140. package/dist/sdk/client_api/call_reducer_type.d.ts.map +1 -0
  141. package/dist/sdk/client_api/client_message_type.d.ts +24 -0
  142. package/dist/sdk/client_api/client_message_type.d.ts.map +1 -0
  143. package/dist/sdk/client_api/client_message_variants.d.ts +36 -0
  144. package/dist/sdk/client_api/client_message_variants.d.ts.map +1 -0
  145. package/dist/sdk/client_api/compressable_query_update_type.d.ts +14 -0
  146. package/dist/sdk/client_api/compressable_query_update_type.d.ts.map +1 -0
  147. package/dist/sdk/client_api/compressable_query_update_variants.d.ts +14 -0
  148. package/dist/sdk/client_api/compressable_query_update_variants.d.ts.map +1 -0
  149. package/dist/sdk/client_api/database_update_type.d.ts +19 -0
  150. package/dist/sdk/client_api/database_update_type.d.ts.map +1 -0
  151. package/dist/sdk/client_api/energy_quanta_type.d.ts +18 -0
  152. package/dist/sdk/client_api/energy_quanta_type.d.ts.map +1 -0
  153. package/dist/sdk/client_api/identity_token_type.d.ts +20 -0
  154. package/dist/sdk/client_api/identity_token_type.d.ts.map +1 -0
  155. package/dist/sdk/client_api/index.d.ts +86 -0
  156. package/dist/sdk/client_api/index.d.ts.map +1 -0
  157. package/dist/sdk/client_api/initial_subscription_type.d.ts +21 -0
  158. package/dist/sdk/client_api/initial_subscription_type.d.ts.map +1 -0
  159. package/dist/sdk/client_api/one_off_query_response_type.d.ts +22 -0
  160. package/dist/sdk/client_api/one_off_query_response_type.d.ts.map +1 -0
  161. package/dist/sdk/client_api/one_off_query_type.d.ts +19 -0
  162. package/dist/sdk/client_api/one_off_query_type.d.ts.map +1 -0
  163. package/dist/sdk/client_api/one_off_table_type.d.ts +20 -0
  164. package/dist/sdk/client_api/one_off_table_type.d.ts.map +1 -0
  165. package/dist/sdk/client_api/query_id_type.d.ts +18 -0
  166. package/dist/sdk/client_api/query_id_type.d.ts.map +1 -0
  167. package/dist/sdk/client_api/query_update_type.d.ts +20 -0
  168. package/dist/sdk/client_api/query_update_type.d.ts.map +1 -0
  169. package/dist/sdk/client_api/reducer_call_info_type.d.ts +21 -0
  170. package/dist/sdk/client_api/reducer_call_info_type.d.ts.map +1 -0
  171. package/dist/sdk/client_api/row_size_hint_type.d.ts +12 -0
  172. package/dist/sdk/client_api/row_size_hint_type.d.ts.map +1 -0
  173. package/dist/sdk/client_api/row_size_hint_variants.d.ts +9 -0
  174. package/dist/sdk/client_api/row_size_hint_variants.d.ts.map +1 -0
  175. package/dist/sdk/client_api/server_message_type.d.ts +30 -0
  176. package/dist/sdk/client_api/server_message_type.d.ts.map +1 -0
  177. package/dist/sdk/client_api/server_message_variants.d.ts +51 -0
  178. package/dist/sdk/client_api/server_message_variants.d.ts.map +1 -0
  179. package/dist/sdk/client_api/subscribe_applied_type.d.ts +23 -0
  180. package/dist/sdk/client_api/subscribe_applied_type.d.ts.map +1 -0
  181. package/dist/sdk/client_api/subscribe_multi_applied_type.d.ts +23 -0
  182. package/dist/sdk/client_api/subscribe_multi_applied_type.d.ts.map +1 -0
  183. package/dist/sdk/client_api/subscribe_multi_type.d.ts +21 -0
  184. package/dist/sdk/client_api/subscribe_multi_type.d.ts.map +1 -0
  185. package/dist/sdk/client_api/subscribe_rows_type.d.ts +21 -0
  186. package/dist/sdk/client_api/subscribe_rows_type.d.ts.map +1 -0
  187. package/dist/sdk/client_api/subscribe_single_type.d.ts +21 -0
  188. package/dist/sdk/client_api/subscribe_single_type.d.ts.map +1 -0
  189. package/dist/sdk/client_api/subscribe_type.d.ts +19 -0
  190. package/dist/sdk/client_api/subscribe_type.d.ts.map +1 -0
  191. package/dist/sdk/client_api/subscription_error_type.d.ts +22 -0
  192. package/dist/sdk/client_api/subscription_error_type.d.ts.map +1 -0
  193. package/dist/sdk/client_api/table_update_type.d.ts +22 -0
  194. package/dist/sdk/client_api/table_update_type.d.ts.map +1 -0
  195. package/dist/sdk/client_api/transaction_update_light_type.d.ts +20 -0
  196. package/dist/sdk/client_api/transaction_update_light_type.d.ts.map +1 -0
  197. package/dist/sdk/client_api/transaction_update_type.d.ts +27 -0
  198. package/dist/sdk/client_api/transaction_update_type.d.ts.map +1 -0
  199. package/dist/sdk/client_api/unsubscribe_applied_type.d.ts +23 -0
  200. package/dist/sdk/client_api/unsubscribe_applied_type.d.ts.map +1 -0
  201. package/dist/sdk/client_api/unsubscribe_multi_applied_type.d.ts +23 -0
  202. package/dist/sdk/client_api/unsubscribe_multi_applied_type.d.ts.map +1 -0
  203. package/dist/sdk/client_api/unsubscribe_multi_type.d.ts +20 -0
  204. package/dist/sdk/client_api/unsubscribe_multi_type.d.ts.map +1 -0
  205. package/dist/sdk/client_api/unsubscribe_type.d.ts +20 -0
  206. package/dist/sdk/client_api/unsubscribe_type.d.ts.map +1 -0
  207. package/dist/sdk/client_api/update_status_type.d.ts +16 -0
  208. package/dist/sdk/client_api/update_status_type.d.ts.map +1 -0
  209. package/dist/sdk/client_api/update_status_variants.d.ts +13 -0
  210. package/dist/sdk/client_api/update_status_variants.d.ts.map +1 -0
  211. package/dist/sdk/client_cache.d.ts +17 -0
  212. package/dist/sdk/client_cache.d.ts.map +1 -0
  213. package/dist/sdk/db_connection_builder.d.ts +145 -0
  214. package/dist/sdk/db_connection_builder.d.ts.map +1 -0
  215. package/dist/sdk/db_connection_impl.d.ts +102 -0
  216. package/dist/sdk/db_connection_impl.d.ts.map +1 -0
  217. package/dist/sdk/db_context.d.ts +25 -0
  218. package/dist/sdk/db_context.d.ts.map +1 -0
  219. package/dist/sdk/decompress.d.ts +2 -0
  220. package/dist/sdk/decompress.d.ts.map +1 -0
  221. package/dist/sdk/event.d.ts +15 -0
  222. package/dist/sdk/event.d.ts.map +1 -0
  223. package/dist/sdk/event_context.d.ts +18 -0
  224. package/dist/sdk/event_context.d.ts.map +1 -0
  225. package/dist/sdk/event_emitter.d.ts +7 -0
  226. package/dist/sdk/event_emitter.d.ts.map +1 -0
  227. package/dist/sdk/index.browser.mjs +18 -4
  228. package/dist/sdk/index.browser.mjs.map +1 -1
  229. package/dist/sdk/index.cjs +18 -16
  230. package/dist/sdk/index.cjs.map +1 -1
  231. package/dist/sdk/index.d.ts +4 -0
  232. package/dist/sdk/index.d.ts.map +1 -0
  233. package/dist/sdk/index.mjs +18 -16
  234. package/dist/sdk/index.mjs.map +1 -1
  235. package/dist/sdk/json_api.d.ts +40 -0
  236. package/dist/sdk/json_api.d.ts.map +1 -0
  237. package/dist/sdk/logger.d.ts +4 -0
  238. package/dist/sdk/logger.d.ts.map +1 -0
  239. package/dist/sdk/message_types.d.ts +50 -0
  240. package/dist/sdk/message_types.d.ts.map +1 -0
  241. package/dist/sdk/reducer_event.d.ts +42 -0
  242. package/dist/sdk/reducer_event.d.ts.map +1 -0
  243. package/dist/sdk/spacetime_module.d.ts +31 -0
  244. package/dist/sdk/spacetime_module.d.ts.map +1 -0
  245. package/dist/sdk/subscription_builder_impl.d.ts +126 -0
  246. package/dist/sdk/subscription_builder_impl.d.ts.map +1 -0
  247. package/dist/sdk/table_cache.d.ts +111 -0
  248. package/dist/sdk/table_cache.d.ts.map +1 -0
  249. package/dist/sdk/version.d.ts +18 -0
  250. package/dist/sdk/version.d.ts.map +1 -0
  251. package/dist/sdk/websocket_decompress_adapter.d.ts +21 -0
  252. package/dist/sdk/websocket_decompress_adapter.d.ts.map +1 -0
  253. package/dist/sdk/websocket_test_adapter.d.ts +22 -0
  254. package/dist/sdk/websocket_test_adapter.d.ts.map +1 -0
  255. package/dist/sdk/ws.d.ts +2 -0
  256. package/dist/sdk/ws.d.ts.map +1 -0
  257. package/dist/server/index.d.ts +3 -0
  258. package/dist/server/index.d.ts.map +1 -0
  259. package/dist/server/type_builders.d.ts +656 -0
  260. package/dist/server/type_builders.d.ts.map +1 -0
  261. package/dist/server/type_builders.test-d.d.ts +2 -0
  262. package/dist/server/type_builders.test-d.d.ts.map +1 -0
  263. package/dist/server/type_util.d.ts +18 -0
  264. package/dist/server/type_util.d.ts.map +1 -0
  265. package/package.json +30 -27
  266. package/src/react/SpacetimeDBProvider.ts +4 -1
  267. package/src/react/useSpacetimeDB.ts +1 -1
  268. package/src/react/useTable.ts +1 -1
  269. package/src/sdk/db_connection_builder.ts +1 -1
  270. package/src/sdk/db_connection_impl.ts +6 -6
  271. package/src/sdk/message_types.ts +3 -3
  272. package/src/sdk/reducer_event.ts +3 -3
  273. package/src/sdk/spacetime_module.ts +1 -1
  274. package/src/sdk/table_cache.ts +1 -1
  275. package/src/sdk/websocket_decompress_adapter.ts +2 -30
  276. package/src/sdk/websocket_test_adapter.ts +1 -1
  277. package/src/sdk/ws.ts +24 -0
  278. package/LICENSE.txt +0 -759
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/react/useSpacetimeDB.ts","../../../src/react/SpacetimeDBProvider.ts","../../../src/react/useTable.ts"],"names":["where"],"mappings":"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","file":"index.mjs","sourcesContent":["import { createContext, useContext, type Context } from 'react';\nimport type { DbConnectionImpl } from '../index';\n\nexport const SpacetimeDBContext: Context<DbConnectionImpl | undefined> =\n createContext<DbConnectionImpl | undefined>(undefined);\n\n// Throws an error if used outside of a SpacetimeDBProvider\n// Error is caught by other hooks like useTable so they can provide better error messages\nexport function useSpacetimeDB<\n DbConnection extends DbConnectionImpl,\n>(): DbConnection {\n const context = useContext(SpacetimeDBContext) as DbConnection | undefined;\n if (!context) {\n throw new Error(\n 'useSpacetimeDB must be used within a SpacetimeDBProvider component. Did you forget to add a `SpacetimeDBProvider` to your component tree?'\n );\n }\n return context;\n}\n","import { DbConnectionBuilder, type DbConnectionImpl } from '../index';\nimport * as React from 'react';\nimport { SpacetimeDBContext } from './useSpacetimeDB';\n\nexport interface SpacetimeDBProviderProps<\n DbConnection extends DbConnectionImpl,\n ErrorContext,\n SubscriptionEventContext,\n> {\n connectionBuilder: DbConnectionBuilder<\n DbConnection,\n ErrorContext,\n SubscriptionEventContext\n >;\n children?: React.ReactNode;\n}\n\nexport function SpacetimeDBProvider<\n DbConnection extends DbConnectionImpl,\n ErrorContext,\n SubscriptionEventContext,\n>({\n connectionBuilder,\n children,\n}: SpacetimeDBProviderProps<\n DbConnection,\n ErrorContext,\n SubscriptionEventContext\n>): React.JSX.Element {\n return React.createElement(\n SpacetimeDBContext.Provider,\n { value: connectionBuilder.build() }, // May need to modify this to do it lazily in server-side rendering\n children\n );\n}\n","import {\n useCallback,\n useEffect,\n useRef,\n useState,\n useSyncExternalStore,\n} from 'react';\nimport { useSpacetimeDB } from './useSpacetimeDB';\nimport { DbConnectionImpl, TableCache } from '../sdk';\n\nexport interface UseQueryCallbacks<RowType> {\n onInsert?: (row: RowType) => void;\n onDelete?: (row: RowType) => void;\n onUpdate?: (oldRow: RowType, newRow: RowType) => void;\n}\n\nexport type Value = string | number | boolean;\n\nexport type Expr<Column extends string> =\n | { type: 'eq'; key: Column; value: Value }\n | { type: 'and'; children: Expr<Column>[] }\n | { type: 'or'; children: Expr<Column>[] };\n\nexport const eq = <Column extends string>(\n key: Column,\n value: Value\n): Expr<Column> => ({ type: 'eq', key, value });\n\nexport const and = <Column extends string>(\n ...children: Expr<Column>[]\n): Expr<Column> => {\n const flat: Expr<Column>[] = [];\n for (const c of children) {\n if (!c) continue;\n if (c.type === 'and') flat.push(...c.children);\n else flat.push(c);\n }\n const pruned = flat.filter(Boolean);\n if (pruned.length === 0) return { type: 'and', children: [] };\n if (pruned.length === 1) return pruned[0];\n return { type: 'and', children: pruned };\n};\n\nexport const or = <Column extends string>(\n ...children: Expr<Column>[]\n): Expr<Column> => {\n const flat: Expr<Column>[] = [];\n for (const c of children) {\n if (!c) continue;\n if (c.type === 'or') flat.push(...c.children);\n else flat.push(c);\n }\n const pruned = flat.filter(Boolean);\n if (pruned.length === 0) return { type: 'or', children: [] };\n if (pruned.length === 1) return pruned[0];\n return { type: 'or', children: pruned };\n};\n\nexport const isEq = <Column extends string>(\n e: Expr<Column>\n): e is Extract<Expr<Column>, { type: 'eq' }> => e.type === 'eq';\nexport const isAnd = <Column extends string>(\n e: Expr<Column>\n): e is Extract<Expr<Column>, { type: 'and' }> => e.type === 'and';\nexport const isOr = <Column extends string>(\n e: Expr<Column>\n): e is Extract<Expr<Column>, { type: 'or' }> => e.type === 'or';\n\ntype RecordLike<Column extends string> = Record<Column, unknown>;\n\nexport function evaluate<Column extends string>(\n expr: Expr<Column>,\n row: RecordLike<Column>\n): boolean {\n switch (expr.type) {\n case 'eq': {\n const v = row[expr.key];\n if (\n typeof v === 'string' ||\n typeof v === 'number' ||\n typeof v === 'boolean'\n ) {\n return v === expr.value;\n }\n return false;\n }\n case 'and':\n return (\n expr.children.length === 0 || expr.children.every(c => evaluate(c, row))\n );\n case 'or':\n return (\n expr.children.length !== 0 && expr.children.some(c => evaluate(c, row))\n );\n }\n}\n\nfunction formatValue(v: Value): string {\n switch (typeof v) {\n case 'string':\n return `'${v.replace(/'/g, \"''\")}'`;\n case 'number':\n return Number.isFinite(v) ? String(v) : `'${String(v)}'`;\n case 'boolean':\n return v ? 'TRUE' : 'FALSE';\n }\n}\n\nfunction escapeIdent(id: string): string {\n if (/^[A-Za-z_][A-Za-z0-9_]*$/.test(id)) return id;\n return `\"${id.replace(/\"/g, '\"\"')}\"`;\n}\n\nfunction parenthesize(s: string): string {\n if (!s.includes(' AND ') && !s.includes(' OR ')) return s;\n return `(${s})`;\n}\n\nexport function toString<Column extends string>(expr: Expr<Column>): string {\n switch (expr.type) {\n case 'eq':\n return `${escapeIdent(expr.key)} = ${formatValue(expr.value)}`;\n case 'and':\n return parenthesize(expr.children.map(toString).join(' AND '));\n case 'or':\n return parenthesize(expr.children.map(toString).join(' OR '));\n }\n}\n\n/**\n * This is just the identity function to make things look like SQL.\n * @param expr\n * @returns\n */\nexport function where<Column extends string>(expr: Expr<Column>): Expr<Column> {\n return expr;\n}\n\ntype Snapshot<RowType> = {\n readonly rows: readonly RowType[];\n readonly state: 'loading' | 'ready';\n};\n\ntype MembershipChange = 'enter' | 'leave' | 'stayIn' | 'stayOut';\n\nfunction classifyMembership<\n Col extends string,\n R extends Record<string, unknown>,\n>(where: Expr<Col> | undefined, oldRow: R, newRow: R): MembershipChange {\n // No filter: everything is in, so updates are always \"stayIn\".\n if (!where) {\n return 'stayIn';\n }\n\n const oldIn = evaluate(where, oldRow);\n const newIn = evaluate(where, newRow);\n\n if (oldIn && !newIn) {\n return 'leave';\n }\n if (!oldIn && newIn) {\n return 'enter';\n }\n if (oldIn && newIn) {\n return 'stayIn';\n }\n return 'stayOut';\n}\n\n/**\n * Extracts the column names from a RowType whose values are of type Value.\n * Note that this will exclude columns that are of type object, array, etc.\n */\ntype ColumnsFromRow<R> = {\n [K in keyof R]-?: R[K] extends Value | undefined ? K : never;\n}[keyof R] &\n string;\n\n/**\n * React hook to subscribe to a table in SpacetimeDB and receive live updates as rows are inserted, updated, or deleted.\n *\n * This hook returns a snapshot of the table's rows, filtered by an optional `where` clause, and provides a loading state\n * until the initial subscription is applied. It also allows you to specify callbacks for row insertions, deletions, and updates.\n *\n * The hook must be used within a component tree wrapped by `SpacetimeDBProvider`.\n *\n * Overloads:\n * - `useTable(tableName, where, callbacks?)`: Subscribe to a table with a filter and optional callbacks.\n * - `useTable(tableName, callbacks?)`: Subscribe to a table without a filter, with optional callbacks.\n *\n * @template DbConnection The type of the SpacetimeDB connection.\n * @template RowType The type of the table row.\n * @template TableName The name of the table.\n *\n * @param tableName - The name of the table to subscribe to.\n * @param whereClauseOrCallbacks - (Optional) Either a filter expression (where clause) or the callbacks object.\n * @param callbacks - (Optional) Callbacks for row insert, delete, and update events.\n *\n * @returns A snapshot object containing the current rows and the subscription state (`'loading'` or `'ready'`).\n *\n * @throws Error if the hook is used outside of a `SpacetimeDBProvider`.\n *\n * @example\n * ```tsx\n * const { rows, state } = useTable('users', where(eq('isActive', true)), {\n * onInsert: (row) => console.log('Inserted:', row),\n * onDelete: (row) => console.log('Deleted:', row),\n * onUpdate: (oldRow, newRow) => console.log('Updated:', oldRow, newRow),\n * });\n * ```\n */\nexport function useTable<\n DbConnection extends DbConnectionImpl,\n RowType extends Record<string, any>,\n TableName extends keyof DbConnection['db'] &\n string = keyof DbConnection['db'] & string,\n>(\n tableName: TableName,\n where: Expr<ColumnsFromRow<RowType>>,\n callbacks?: UseQueryCallbacks<RowType>\n): Snapshot<RowType>;\n\n/**\n * React hook to subscribe to a table in SpacetimeDB and receive live updates as rows are inserted, updated, or deleted.\n *\n * This hook returns a snapshot of the table's rows, filtered by an optional `where` clause, and provides a loading state\n * until the initial subscription is applied. It also allows you to specify callbacks for row insertions, deletions, and updates.\n *\n * The hook must be used within a component tree wrapped by `SpacetimeDBProvider`.\n *\n * Overloads:\n * - `useTable(tableName, where, callbacks?)`: Subscribe to a table with a filter and optional callbacks.\n * - `useTable(tableName, callbacks?)`: Subscribe to a table without a filter, with optional callbacks.\n *\n * @template DbConnection The type of the SpacetimeDB connection.\n * @template RowType The type of the table row.\n * @template TableName The name of the table.\n *\n * @param tableName - The name of the table to subscribe to.\n * @param whereClauseOrCallbacks - (Optional) Either a filter expression (where clause) or the callbacks object.\n * @param callbacks - (Optional) Callbacks for row insert, delete, and update events.\n *\n * @returns A snapshot object containing the current rows and the subscription state (`'loading'` or `'ready'`).\n *\n * @throws Error if the hook is used outside of a `SpacetimeDBProvider`.\n *\n * @example\n * ```tsx\n * const { rows, state } = useTable('users', where(eq('isActive', true)), {\n * onInsert: (row) => console.log('Inserted:', row),\n * onDelete: (row) => console.log('Deleted:', row),\n * onUpdate: (oldRow, newRow) => console.log('Updated:', oldRow, newRow),\n * });\n * ```\n */\nexport function useTable<\n DbConnection extends DbConnectionImpl,\n RowType extends Record<string, any>,\n TableName extends keyof DbConnection['db'] &\n string = keyof DbConnection['db'] & string,\n>(\n tableName: TableName,\n callbacks?: UseQueryCallbacks<RowType>\n): Snapshot<RowType>;\n\nexport function useTable<\n DbConnection extends DbConnectionImpl,\n RowType extends Record<string, any>,\n TableName extends keyof DbConnection['db'] &\n string = keyof DbConnection['db'] & string,\n>(\n tableName: TableName,\n whereClauseOrCallbacks?:\n | Expr<ColumnsFromRow<RowType>>\n | UseQueryCallbacks<RowType>,\n callbacks?: UseQueryCallbacks<RowType>\n): Snapshot<RowType> {\n let whereClause: Expr<ColumnsFromRow<RowType>> | undefined;\n if (\n whereClauseOrCallbacks &&\n typeof whereClauseOrCallbacks === 'object' &&\n 'type' in whereClauseOrCallbacks\n ) {\n whereClause = whereClauseOrCallbacks as Expr<ColumnsFromRow<RowType>>;\n } else {\n callbacks = whereClauseOrCallbacks as\n | UseQueryCallbacks<RowType>\n | undefined;\n }\n const [subscribeApplied, setSubscribeApplied] = useState(false);\n const [isActive, setIsActive] = useState(false);\n let spacetime: DbConnection | undefined;\n try {\n spacetime = useSpacetimeDB<DbConnection>();\n } catch {\n throw new Error(\n 'Could not find SpacetimeDB client! Did you forget to add a ' +\n '`SpacetimeDBProvider`? `useTable` must be used in the React component tree ' +\n 'under a `SpacetimeDBProvider` component.'\n );\n }\n const client = spacetime;\n\n const query =\n `SELECT * FROM ${tableName}` +\n (whereClause ? ` WHERE ${toString(whereClause)}` : '');\n\n const latestTransactionEvent = useRef<any>(null);\n const lastSnapshotRef = useRef<Snapshot<RowType> | null>(null);\n\n const whereKey = whereClause ? toString(whereClause) : '';\n\n const computeSnapshot = useCallback((): Snapshot<RowType> => {\n const table = client.db[\n tableName as keyof typeof client.db\n ] as unknown as TableCache<RowType>;\n const result: readonly RowType[] = whereClause\n ? table.iter().filter(row => evaluate(whereClause, row))\n : table.iter();\n return {\n rows: result,\n state: subscribeApplied ? 'ready' : 'loading',\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [client, tableName, whereKey, subscribeApplied]);\n\n useEffect(() => {\n const onConnect = () => {\n setIsActive(client.isActive);\n };\n const onDisconnect = () => {\n setIsActive(client.isActive);\n };\n const onConnectError = () => {\n setIsActive(client.isActive);\n };\n client['on']('connect', onConnect);\n client['on']('disconnect', onDisconnect);\n client['on']('connectError', onConnectError);\n return () => {\n client['off']('connect', onConnect);\n client['off']('disconnect', onDisconnect);\n client['off']('connectError', onConnectError);\n };\n }, [client]);\n\n useEffect(() => {\n if (isActive) {\n const cancel = client\n .subscriptionBuilder()\n .onApplied(() => {\n setSubscribeApplied(true);\n })\n .subscribe(query);\n return () => {\n cancel.unsubscribe();\n };\n }\n }, [query, isActive, client]);\n\n const subscribe = useCallback(\n (onStoreChange: () => void) => {\n const onInsert = (ctx: any, row: RowType) => {\n if (whereClause && !evaluate(whereClause, row)) {\n return;\n }\n if (tableName === 'message') {\n console.log('onInsert for messages table:', row);\n }\n callbacks?.onInsert?.(row);\n if (\n ctx.event !== latestTransactionEvent.current ||\n !latestTransactionEvent.current\n ) {\n latestTransactionEvent.current = ctx.event;\n lastSnapshotRef.current = computeSnapshot();\n onStoreChange();\n }\n };\n\n const onDelete = (ctx: any, row: RowType) => {\n if (whereClause && !evaluate(whereClause, row)) {\n return;\n }\n if (tableName === 'message') {\n console.log('onDelete for messages table:', row);\n }\n callbacks?.onDelete?.(row);\n if (\n ctx.event !== latestTransactionEvent.current ||\n !latestTransactionEvent.current\n ) {\n latestTransactionEvent.current = ctx.event;\n lastSnapshotRef.current = computeSnapshot();\n onStoreChange();\n }\n };\n\n const onUpdate = (ctx: any, oldRow: RowType, newRow: RowType) => {\n const change = classifyMembership(whereClause, oldRow, newRow);\n\n switch (change) {\n case 'leave':\n callbacks?.onDelete?.(oldRow);\n break;\n case 'enter':\n callbacks?.onInsert?.(newRow);\n break;\n case 'stayIn':\n callbacks?.onUpdate?.(oldRow, newRow);\n break;\n case 'stayOut':\n return; // no-op\n }\n\n if (\n ctx.event !== latestTransactionEvent.current ||\n !latestTransactionEvent.current\n ) {\n latestTransactionEvent.current = ctx.event;\n lastSnapshotRef.current = computeSnapshot();\n onStoreChange();\n }\n };\n\n const table = client.db[\n tableName as keyof typeof client.db\n ] as unknown as TableCache<RowType>;\n table.onInsert(onInsert);\n table.onDelete(onDelete);\n table.onUpdate?.(onUpdate);\n\n return () => {\n table.removeOnInsert(onInsert);\n table.removeOnDelete(onDelete);\n table.removeOnUpdate?.(onUpdate);\n };\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n client,\n tableName,\n whereKey,\n callbacks?.onDelete,\n callbacks?.onInsert,\n callbacks?.onUpdate,\n ]\n );\n\n const getSnapshot = useCallback((): Snapshot<RowType> => {\n if (!lastSnapshotRef.current) {\n lastSnapshotRef.current = computeSnapshot();\n }\n return lastSnapshotRef.current;\n }, [computeSnapshot]);\n\n // SSR fallback can be the same getter\n return useSyncExternalStore(subscribe, getSnapshot, getSnapshot);\n}\n"]}
1
+ {"version":3,"sources":["../../../src/react/useSpacetimeDB.ts","../../../src/react/SpacetimeDBProvider.ts","../../../src/react/useTable.ts"],"names":["where"],"mappings":"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","file":"index.mjs","sourcesContent":["import { createContext, useContext, type Context } from 'react';\nimport type { DbConnectionImpl } from '../sdk/db_connection_impl';\n\nexport const SpacetimeDBContext: Context<DbConnectionImpl | undefined> =\n createContext<DbConnectionImpl | undefined>(undefined);\n\n// Throws an error if used outside of a SpacetimeDBProvider\n// Error is caught by other hooks like useTable so they can provide better error messages\nexport function useSpacetimeDB<\n DbConnection extends DbConnectionImpl,\n>(): DbConnection {\n const context = useContext(SpacetimeDBContext) as DbConnection | undefined;\n if (!context) {\n throw new Error(\n 'useSpacetimeDB must be used within a SpacetimeDBProvider component. Did you forget to add a `SpacetimeDBProvider` to your component tree?'\n );\n }\n return context;\n}\n","import {\n DbConnectionBuilder,\n type DbConnectionImpl,\n} from '../sdk/db_connection_impl';\nimport * as React from 'react';\nimport { SpacetimeDBContext } from './useSpacetimeDB';\n\nexport interface SpacetimeDBProviderProps<\n DbConnection extends DbConnectionImpl,\n ErrorContext,\n SubscriptionEventContext,\n> {\n connectionBuilder: DbConnectionBuilder<\n DbConnection,\n ErrorContext,\n SubscriptionEventContext\n >;\n children?: React.ReactNode;\n}\n\nexport function SpacetimeDBProvider<\n DbConnection extends DbConnectionImpl,\n ErrorContext,\n SubscriptionEventContext,\n>({\n connectionBuilder,\n children,\n}: SpacetimeDBProviderProps<\n DbConnection,\n ErrorContext,\n SubscriptionEventContext\n>): React.JSX.Element {\n return React.createElement(\n SpacetimeDBContext.Provider,\n { value: connectionBuilder.build() }, // May need to modify this to do it lazily in server-side rendering\n children\n );\n}\n","import {\n useCallback,\n useEffect,\n useRef,\n useState,\n useSyncExternalStore,\n} from 'react';\nimport { useSpacetimeDB } from './useSpacetimeDB';\nimport { DbConnectionImpl, TableCache } from '../sdk/db_connection_impl';\n\nexport interface UseQueryCallbacks<RowType> {\n onInsert?: (row: RowType) => void;\n onDelete?: (row: RowType) => void;\n onUpdate?: (oldRow: RowType, newRow: RowType) => void;\n}\n\nexport type Value = string | number | boolean;\n\nexport type Expr<Column extends string> =\n | { type: 'eq'; key: Column; value: Value }\n | { type: 'and'; children: Expr<Column>[] }\n | { type: 'or'; children: Expr<Column>[] };\n\nexport const eq = <Column extends string>(\n key: Column,\n value: Value\n): Expr<Column> => ({ type: 'eq', key, value });\n\nexport const and = <Column extends string>(\n ...children: Expr<Column>[]\n): Expr<Column> => {\n const flat: Expr<Column>[] = [];\n for (const c of children) {\n if (!c) continue;\n if (c.type === 'and') flat.push(...c.children);\n else flat.push(c);\n }\n const pruned = flat.filter(Boolean);\n if (pruned.length === 0) return { type: 'and', children: [] };\n if (pruned.length === 1) return pruned[0];\n return { type: 'and', children: pruned };\n};\n\nexport const or = <Column extends string>(\n ...children: Expr<Column>[]\n): Expr<Column> => {\n const flat: Expr<Column>[] = [];\n for (const c of children) {\n if (!c) continue;\n if (c.type === 'or') flat.push(...c.children);\n else flat.push(c);\n }\n const pruned = flat.filter(Boolean);\n if (pruned.length === 0) return { type: 'or', children: [] };\n if (pruned.length === 1) return pruned[0];\n return { type: 'or', children: pruned };\n};\n\nexport const isEq = <Column extends string>(\n e: Expr<Column>\n): e is Extract<Expr<Column>, { type: 'eq' }> => e.type === 'eq';\nexport const isAnd = <Column extends string>(\n e: Expr<Column>\n): e is Extract<Expr<Column>, { type: 'and' }> => e.type === 'and';\nexport const isOr = <Column extends string>(\n e: Expr<Column>\n): e is Extract<Expr<Column>, { type: 'or' }> => e.type === 'or';\n\ntype RecordLike<Column extends string> = Record<Column, unknown>;\n\nexport function evaluate<Column extends string>(\n expr: Expr<Column>,\n row: RecordLike<Column>\n): boolean {\n switch (expr.type) {\n case 'eq': {\n const v = row[expr.key];\n if (\n typeof v === 'string' ||\n typeof v === 'number' ||\n typeof v === 'boolean'\n ) {\n return v === expr.value;\n }\n return false;\n }\n case 'and':\n return (\n expr.children.length === 0 || expr.children.every(c => evaluate(c, row))\n );\n case 'or':\n return (\n expr.children.length !== 0 && expr.children.some(c => evaluate(c, row))\n );\n }\n}\n\nfunction formatValue(v: Value): string {\n switch (typeof v) {\n case 'string':\n return `'${v.replace(/'/g, \"''\")}'`;\n case 'number':\n return Number.isFinite(v) ? String(v) : `'${String(v)}'`;\n case 'boolean':\n return v ? 'TRUE' : 'FALSE';\n }\n}\n\nfunction escapeIdent(id: string): string {\n if (/^[A-Za-z_][A-Za-z0-9_]*$/.test(id)) return id;\n return `\"${id.replace(/\"/g, '\"\"')}\"`;\n}\n\nfunction parenthesize(s: string): string {\n if (!s.includes(' AND ') && !s.includes(' OR ')) return s;\n return `(${s})`;\n}\n\nexport function toString<Column extends string>(expr: Expr<Column>): string {\n switch (expr.type) {\n case 'eq':\n return `${escapeIdent(expr.key)} = ${formatValue(expr.value)}`;\n case 'and':\n return parenthesize(expr.children.map(toString).join(' AND '));\n case 'or':\n return parenthesize(expr.children.map(toString).join(' OR '));\n }\n}\n\n/**\n * This is just the identity function to make things look like SQL.\n * @param expr\n * @returns\n */\nexport function where<Column extends string>(expr: Expr<Column>): Expr<Column> {\n return expr;\n}\n\ntype Snapshot<RowType> = {\n readonly rows: readonly RowType[];\n readonly state: 'loading' | 'ready';\n};\n\ntype MembershipChange = 'enter' | 'leave' | 'stayIn' | 'stayOut';\n\nfunction classifyMembership<\n Col extends string,\n R extends Record<string, unknown>,\n>(where: Expr<Col> | undefined, oldRow: R, newRow: R): MembershipChange {\n // No filter: everything is in, so updates are always \"stayIn\".\n if (!where) {\n return 'stayIn';\n }\n\n const oldIn = evaluate(where, oldRow);\n const newIn = evaluate(where, newRow);\n\n if (oldIn && !newIn) {\n return 'leave';\n }\n if (!oldIn && newIn) {\n return 'enter';\n }\n if (oldIn && newIn) {\n return 'stayIn';\n }\n return 'stayOut';\n}\n\n/**\n * Extracts the column names from a RowType whose values are of type Value.\n * Note that this will exclude columns that are of type object, array, etc.\n */\ntype ColumnsFromRow<R> = {\n [K in keyof R]-?: R[K] extends Value | undefined ? K : never;\n}[keyof R] &\n string;\n\n/**\n * React hook to subscribe to a table in SpacetimeDB and receive live updates as rows are inserted, updated, or deleted.\n *\n * This hook returns a snapshot of the table's rows, filtered by an optional `where` clause, and provides a loading state\n * until the initial subscription is applied. It also allows you to specify callbacks for row insertions, deletions, and updates.\n *\n * The hook must be used within a component tree wrapped by `SpacetimeDBProvider`.\n *\n * Overloads:\n * - `useTable(tableName, where, callbacks?)`: Subscribe to a table with a filter and optional callbacks.\n * - `useTable(tableName, callbacks?)`: Subscribe to a table without a filter, with optional callbacks.\n *\n * @template DbConnection The type of the SpacetimeDB connection.\n * @template RowType The type of the table row.\n * @template TableName The name of the table.\n *\n * @param tableName - The name of the table to subscribe to.\n * @param whereClauseOrCallbacks - (Optional) Either a filter expression (where clause) or the callbacks object.\n * @param callbacks - (Optional) Callbacks for row insert, delete, and update events.\n *\n * @returns A snapshot object containing the current rows and the subscription state (`'loading'` or `'ready'`).\n *\n * @throws Error if the hook is used outside of a `SpacetimeDBProvider`.\n *\n * @example\n * ```tsx\n * const { rows, state } = useTable('users', where(eq('isActive', true)), {\n * onInsert: (row) => console.log('Inserted:', row),\n * onDelete: (row) => console.log('Deleted:', row),\n * onUpdate: (oldRow, newRow) => console.log('Updated:', oldRow, newRow),\n * });\n * ```\n */\nexport function useTable<\n DbConnection extends DbConnectionImpl,\n RowType extends Record<string, any>,\n TableName extends keyof DbConnection['db'] &\n string = keyof DbConnection['db'] & string,\n>(\n tableName: TableName,\n where: Expr<ColumnsFromRow<RowType>>,\n callbacks?: UseQueryCallbacks<RowType>\n): Snapshot<RowType>;\n\n/**\n * React hook to subscribe to a table in SpacetimeDB and receive live updates as rows are inserted, updated, or deleted.\n *\n * This hook returns a snapshot of the table's rows, filtered by an optional `where` clause, and provides a loading state\n * until the initial subscription is applied. It also allows you to specify callbacks for row insertions, deletions, and updates.\n *\n * The hook must be used within a component tree wrapped by `SpacetimeDBProvider`.\n *\n * Overloads:\n * - `useTable(tableName, where, callbacks?)`: Subscribe to a table with a filter and optional callbacks.\n * - `useTable(tableName, callbacks?)`: Subscribe to a table without a filter, with optional callbacks.\n *\n * @template DbConnection The type of the SpacetimeDB connection.\n * @template RowType The type of the table row.\n * @template TableName The name of the table.\n *\n * @param tableName - The name of the table to subscribe to.\n * @param whereClauseOrCallbacks - (Optional) Either a filter expression (where clause) or the callbacks object.\n * @param callbacks - (Optional) Callbacks for row insert, delete, and update events.\n *\n * @returns A snapshot object containing the current rows and the subscription state (`'loading'` or `'ready'`).\n *\n * @throws Error if the hook is used outside of a `SpacetimeDBProvider`.\n *\n * @example\n * ```tsx\n * const { rows, state } = useTable('users', where(eq('isActive', true)), {\n * onInsert: (row) => console.log('Inserted:', row),\n * onDelete: (row) => console.log('Deleted:', row),\n * onUpdate: (oldRow, newRow) => console.log('Updated:', oldRow, newRow),\n * });\n * ```\n */\nexport function useTable<\n DbConnection extends DbConnectionImpl,\n RowType extends Record<string, any>,\n TableName extends keyof DbConnection['db'] &\n string = keyof DbConnection['db'] & string,\n>(\n tableName: TableName,\n callbacks?: UseQueryCallbacks<RowType>\n): Snapshot<RowType>;\n\nexport function useTable<\n DbConnection extends DbConnectionImpl,\n RowType extends Record<string, any>,\n TableName extends keyof DbConnection['db'] &\n string = keyof DbConnection['db'] & string,\n>(\n tableName: TableName,\n whereClauseOrCallbacks?:\n | Expr<ColumnsFromRow<RowType>>\n | UseQueryCallbacks<RowType>,\n callbacks?: UseQueryCallbacks<RowType>\n): Snapshot<RowType> {\n let whereClause: Expr<ColumnsFromRow<RowType>> | undefined;\n if (\n whereClauseOrCallbacks &&\n typeof whereClauseOrCallbacks === 'object' &&\n 'type' in whereClauseOrCallbacks\n ) {\n whereClause = whereClauseOrCallbacks as Expr<ColumnsFromRow<RowType>>;\n } else {\n callbacks = whereClauseOrCallbacks as\n | UseQueryCallbacks<RowType>\n | undefined;\n }\n const [subscribeApplied, setSubscribeApplied] = useState(false);\n const [isActive, setIsActive] = useState(false);\n let spacetime: DbConnection | undefined;\n try {\n spacetime = useSpacetimeDB<DbConnection>();\n } catch {\n throw new Error(\n 'Could not find SpacetimeDB client! Did you forget to add a ' +\n '`SpacetimeDBProvider`? `useTable` must be used in the React component tree ' +\n 'under a `SpacetimeDBProvider` component.'\n );\n }\n const client = spacetime;\n\n const query =\n `SELECT * FROM ${tableName}` +\n (whereClause ? ` WHERE ${toString(whereClause)}` : '');\n\n const latestTransactionEvent = useRef<any>(null);\n const lastSnapshotRef = useRef<Snapshot<RowType> | null>(null);\n\n const whereKey = whereClause ? toString(whereClause) : '';\n\n const computeSnapshot = useCallback((): Snapshot<RowType> => {\n const table = client.db[\n tableName as keyof typeof client.db\n ] as unknown as TableCache<RowType>;\n const result: readonly RowType[] = whereClause\n ? table.iter().filter(row => evaluate(whereClause, row))\n : table.iter();\n return {\n rows: result,\n state: subscribeApplied ? 'ready' : 'loading',\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [client, tableName, whereKey, subscribeApplied]);\n\n useEffect(() => {\n const onConnect = () => {\n setIsActive(client.isActive);\n };\n const onDisconnect = () => {\n setIsActive(client.isActive);\n };\n const onConnectError = () => {\n setIsActive(client.isActive);\n };\n client['on']('connect', onConnect);\n client['on']('disconnect', onDisconnect);\n client['on']('connectError', onConnectError);\n return () => {\n client['off']('connect', onConnect);\n client['off']('disconnect', onDisconnect);\n client['off']('connectError', onConnectError);\n };\n }, [client]);\n\n useEffect(() => {\n if (isActive) {\n const cancel = client\n .subscriptionBuilder()\n .onApplied(() => {\n setSubscribeApplied(true);\n })\n .subscribe(query);\n return () => {\n cancel.unsubscribe();\n };\n }\n }, [query, isActive, client]);\n\n const subscribe = useCallback(\n (onStoreChange: () => void) => {\n const onInsert = (ctx: any, row: RowType) => {\n if (whereClause && !evaluate(whereClause, row)) {\n return;\n }\n if (tableName === 'message') {\n console.log('onInsert for messages table:', row);\n }\n callbacks?.onInsert?.(row);\n if (\n ctx.event !== latestTransactionEvent.current ||\n !latestTransactionEvent.current\n ) {\n latestTransactionEvent.current = ctx.event;\n lastSnapshotRef.current = computeSnapshot();\n onStoreChange();\n }\n };\n\n const onDelete = (ctx: any, row: RowType) => {\n if (whereClause && !evaluate(whereClause, row)) {\n return;\n }\n if (tableName === 'message') {\n console.log('onDelete for messages table:', row);\n }\n callbacks?.onDelete?.(row);\n if (\n ctx.event !== latestTransactionEvent.current ||\n !latestTransactionEvent.current\n ) {\n latestTransactionEvent.current = ctx.event;\n lastSnapshotRef.current = computeSnapshot();\n onStoreChange();\n }\n };\n\n const onUpdate = (ctx: any, oldRow: RowType, newRow: RowType) => {\n const change = classifyMembership(whereClause, oldRow, newRow);\n\n switch (change) {\n case 'leave':\n callbacks?.onDelete?.(oldRow);\n break;\n case 'enter':\n callbacks?.onInsert?.(newRow);\n break;\n case 'stayIn':\n callbacks?.onUpdate?.(oldRow, newRow);\n break;\n case 'stayOut':\n return; // no-op\n }\n\n if (\n ctx.event !== latestTransactionEvent.current ||\n !latestTransactionEvent.current\n ) {\n latestTransactionEvent.current = ctx.event;\n lastSnapshotRef.current = computeSnapshot();\n onStoreChange();\n }\n };\n\n const table = client.db[\n tableName as keyof typeof client.db\n ] as unknown as TableCache<RowType>;\n table.onInsert(onInsert);\n table.onDelete(onDelete);\n table.onUpdate?.(onUpdate);\n\n return () => {\n table.removeOnInsert(onInsert);\n table.removeOnDelete(onDelete);\n table.removeOnUpdate?.(onUpdate);\n };\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n client,\n tableName,\n whereKey,\n callbacks?.onDelete,\n callbacks?.onInsert,\n callbacks?.onUpdate,\n ]\n );\n\n const getSnapshot = useCallback((): Snapshot<RowType> => {\n if (!lastSnapshotRef.current) {\n lastSnapshotRef.current = computeSnapshot();\n }\n return lastSnapshotRef.current;\n }, [computeSnapshot]);\n\n // SSR fallback can be the same getter\n return useSyncExternalStore(subscribe, getSnapshot, getSnapshot);\n}\n"]}
@@ -2894,6 +2894,23 @@ async function decompress(buffer, type, chunkSize = 128 * 1024) {
2894
2894
  return decompressedArray;
2895
2895
  }
2896
2896
 
2897
+ // src/sdk/ws.ts
2898
+ async function resolveWS() {
2899
+ if (typeof globalThis.WebSocket !== "undefined") {
2900
+ return globalThis.WebSocket;
2901
+ }
2902
+ const dynamicImport = new Function("m", "return import(m)");
2903
+ try {
2904
+ const { WebSocket: UndiciWS } = await dynamicImport("undici");
2905
+ return UndiciWS;
2906
+ } catch (err) {
2907
+ console.warn(
2908
+ "[spacetimedb-sdk] No global WebSocket found. On Node 18\u201321, please install `undici` (npm install undici) to enable WebSocket support."
2909
+ );
2910
+ throw err;
2911
+ }
2912
+ }
2913
+
2897
2914
  // src/sdk/websocket_decompress_adapter.ts
2898
2915
  var WebsocketDecompressAdapter = class _WebsocketDecompressAdapter {
2899
2916
  onclose;
@@ -2955,10 +2972,7 @@ var WebsocketDecompressAdapter = class _WebsocketDecompressAdapter {
2955
2972
  lightMode
2956
2973
  }) {
2957
2974
  const headers = new Headers();
2958
- let WS;
2959
- {
2960
- WS = WebSocket;
2961
- }
2975
+ const WS = await resolveWS();
2962
2976
  let temporaryAuthToken = void 0;
2963
2977
  if (authToken) {
2964
2978
  headers.set("Authorization", `Bearer ${authToken}`);