![Oracle Drags Its Feet in the JavaScript Trademark Dispute](https://cdn.sanity.io/images/cgdhsj6q/production/919c3b22c24f93884c548d60cbb338e819ff2435-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Oracle Drags Its Feet in the JavaScript Trademark Dispute
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
@powersync/react-native
Advanced tools
PowerSync - sync Postgres with SQLite in your React Native app for offline-first and real-time data
PowerSync is a sync engine for building local-first apps with instantly-responsive UI/UX and simplified state transfer. Syncs between SQLite on the client-side and Postgres, MongoDB or MySQL on the server-side.
This package (packages/react-native
) is the PowerSync SDK for React Native clients. It is an extension of packages/common
.
See a summary of features here.
npx expo install @powersync/react-native
By default, this SDK requires @journeyapps/react-native-quick-sqlite
as a peer dependency. Alternatively, you can install OP-SQLite from the PowerSync OP-SQLite package (currently in alpha).
Install it in your app with:
npx expo install @journeyapps/react-native-quick-sqlite
Watched queries can be used with either a callback response or Async Iterator response.
Watched queries using the Async Iterator response format require support for Async Iterators.
Expo apps currently require polyfill and Babel plugins in order to use this functionality.
npx expo install @azure/core-asynciterator-polyfill
Make sure to import the polyfill early in your application
// App.js
import '@azure/core-asynciterator-polyfill';
Install the async generator Babel plugin
pnpm add -D @babel/plugin-transform-async-generator-functions
Add the Babel plugin to your babel.config.js
file
module.exports = function (api) {
return {
presets: [...],
plugins: [
// ... Other plugins
'@babel/plugin-transform-async-generator-functions'
]
};
};
When using a bare React Native app without a framework like Expo, the @powersync/react-native
package does not work well with inline requires.
If you see the following error message
Super expression must either be null or a function
then you will need to add this to your metro.config.js
:
const config = {
transformer: {
getTransformOptions: async () => ({
transform: {
inlineRequires: {
blockList: {
[require.resolve("@powersync/react-native")]: true,
},
},
},
})
}
};
This package uses native libraries. Create native Android and iOS projects (if not created already) by running:
npx expo run:android
# OR
npx expo run:ios
Our SDK reference contains everything you need to know to get started implementing PowerSync in your project.
A changelog for this SDK is available here.
The full API reference for this SDK can be found here.
For example projects built with PowerSync and React Native, see our Demo Apps / Example Projects gallery. Most of these projects can also be found in the demos/
directory.
FAQs
PowerSync - sync Postgres with SQLite in your React Native app for offline-first and real-time data
The npm package @powersync/react-native receives a total of 635 weekly downloads. As such, @powersync/react-native popularity was classified as not popular.
We found that @powersync/react-native demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.