Using Hooks
A separatepowersync-react
package is available containing React hooks for PowerSync:
npm: @powersync/react
Using transactions to group changes
Read and write transactions present a context where multiple changes can be made then finally committed to the DB or rolled back. This ensures that either all the changes get persisted, or no change is made to the DB (in the case of a rollback or exception). PowerSyncDatabase.writeTransaction(callback) automatically commits changes after the transaction callback is completed if tx.rollback() has not explicitly been called. If an exception is thrown in the callback then changes are automatically rolled back.Subscribe to changes in data
Use PowerSyncDatabase.watch to watch for changes in source tables.Insert, update, and delete data in the local database
Use PowerSyncDatabase.execute to run INSERT, UPDATE or DELETE queries.Send changes in local data to your backend service
Override uploadData to send local updates to your backend service.Accessing PowerSync connection status information
Use PowerSyncDatabase.connected and register an event listener with PowerSyncDatabase.registerListener to listen for status changes to your PowerSync instance.Wait for the initial sync to complete
Use the hasSynced property (available since version 1.4.1 of the SDK) and register an event listener with PowerSyncDatabase.registerListener to indicate to the user whether the initial sync is in progress.Report sync download progress
You can show users a progress bar when data downloads using thedownloadProgress
property from the SyncStatus class. This is especially useful for long-running initial syncs. downloadProgress.downloadedFraction
gives you a value from 0.0 to 1.0 representing the total sync progress.
Example: