Dec 12, 2023 by
Brent Vatne
The SDK 50 beta period begins today and will last approximately one month. The beta is an opportunity for developers to test out to SDK and ensure that the new release does not introduce any regressions for their particular systems and app configurations. We’re also hosting office hours for those of you interested in helping test the release!
SDK 50 beta includes React Native 0.73. The full release notes for SDK 50 won’t be available until its generally available, but you can browse the changes in the expo/expo CHANGELOG to learn more about the scope of the release and any breaking changes.
expo-sqlite/next
: a complete re-write of our SQLite library, aimed to modernize the API and bring it towards parity with the mature equivalents that exist for web and Node.js. The API includes both sync and async methods, adds support for prepared statements, update callbacks, and the Blob data type, among other features! We’ve also updated the SQLite version to 3.42.0 on both platforms, rather than depending on the versions bundled with the operating system. This makes it possible to add support for SQLite extensions, such as CR-SQLite. We've also built a Knex dialect for expo-sqlite, for folks who like using query builders. SQLite is already an important building block and we believe that it will become increasingly more essential as patterns like local-first application architecture continue to grow, and we’ll continue to invest in this library accordingly. Learn more about the new API.expo-camera/next
: accessing the device camera is a fundamental capability of many mobile apps, and we believe that this should be both simple to do and reliable. So, we’ve taken one of our older and most popular libraries and brought it up to date with native platform best practices. For most use cases, we expect expo-camera/next
to fit like a glove. For more advanced use cases (such as frame processors), react-native-vision-camera is a fantastic option. Documentation coming soon, for now you can learn more about the new API in the type definition.import { CameraView } from 'expo-camera/next'; // Minimal example of using the new API, refer to types for more information on props export default function Camera() { return ( <CameraView style={{ flex: 1 }} /> ); }
@expo/fingerprint
and integration into expo-github-action
: the @expo/fingerprint
library is our answer to a common question for React Native developers: “how do I know if an app JavaScript bundle is compatible with a particular build of my app?”. We do this by generating a fingerprint that represents the unique native characteristics of a project, and if that fingerprint changes, then JavaScript that targeted the older fingerprint may be incompatible. Try it out through the CLI: npx @expo/fingerprint path/to/your/project
and learn more in the README, and in the expo-github-actions README. First class integration into EAS services will be coming in the future!expo-font
config plugin now supports natively adding fonts to your app: it can be useful to load fonts at runtime with Font.loadAsync
or useFonts
to avoid rebuilding your app binary, but fonts in an app typically don’t change very much and so embedding the font into the native project with a config plugin can help you to clean up some of the async loading code from your app startup when you’re ready to do a build. Learn more.expo-secure-store
gets a handful of new improvements. By popular demand, we’ve introduced synchronous getItem
and setItem
functions! We’ve also unified the behavior as much as possible across Android and iOS — other than different types of exceptions resulting from different native implementations, all of the functions now behave the same. This introduces a small breaking change — when fetching a value which doesn’t exist in a keychain expo-secure-store
will now always return null
. Previously, Android would throw an exception and iOS would return null
. Learn more about other changes in the changelog.expo-dev-client
now defaults to loading the most recently opened project when you boot up a development build. If the development server isn’t available, then it falls back to the launch screen. We’ve heard that this is what people typically want when they boot a development build, but if this isn’t your preference, then you can change this behavior with the config plugin:"launchModeExperimental": "launcher”
. Learn more.expo-updates
hook API. We’ve included the new useUpdates()
hook (teased during the August launch week) in the expo-updates
package to make it easy to track state and interact with the updates API. This API should give you ergonomic access to anything you’d like to know about the state of updates in your project — see the return type and the useUpdates()
docs for more information.import { useUpdates } from 'expo-updates'; export default function App() { const { currentlyRunning, availableUpdate, isUpdateAvailable, isUpdatePending, // and so on! } = useUpdates(); // etc.. }
npx expo run
command. Expo CLI will now prompt you to select a target platform if it’s not explicitly named in the command. This is a small quality of life improvement that aligns the npx expo run
UX with that of eas build:run
. You can also use npx expo run android
or npx expo run ios
as alternatives to run:android
and run:ios
.$ npx expo run ? Select the platform to run › - Use arrow-keys. Return to submit. ❯ Android iOS
npx expo install --fix
now upgrades the expo
package to the latest patch version. We have found that developers often keep up to date with Expo SDK patch versions released through an SDK cycle by running npx expo install --fix
, with the exception of the expo
package, which was not automatically updated with this command. We encourage developers to stay up to date with our latest patches, and so we now also update the expo
package with the --fix
flag.URL
and URLSearchParams
standards are built-in. It was previously necessary to polyfill the web standard URL
API (usually with the excellent react-native-url-polyfill
library) in order to use many cross-platform libraries available on npm, where developers tend to assume that the URL
API is available. We believe that URL
is an important enough primitive that it deserves to be built in to the Expo core runtime, and so we now ship our own implementation in the expo
package. Learn more.pnpm
or npm --install-mode=isolated
for local development builds. For other scenarios, we're working through a few remaining blocking issues and hope to have an update soon.sentry-expo
will be deprecated in favor of @sentry/react-native
. The sentry-expo
package will continue to work in SDK 50, but it will be deprecated and we recommend moving to @sentry/react-native
. This change allows us to deduplicate efforts and ensure a better, always up to date experience for folks that use Sentry in their projects. We’ll update this post with information about how to migrate soon.@expo/webpack-config
is deprecated in favor of Expo CLI’s Metro web. We’ll update the documentation throughout the SDK beta period. Learn more in migrating from Expo Webpack.tsconfigPaths
is now enabled in @expo/metro-config
by default: this means that all you need to do to add path aliases is configure the paths
property in your tsconfig.json. For example, "@/*": ["src/*"]
will allow you to write code like import Button from '@/components/Button';
anywhere in your codebase and have it resolve to the correct location within src
. Learn more.babel-preset-expo
: we made a variety of small quality of life improvements in our Babel preset: we removed transforms that aren’t necessary when targeting Hermes, we no longer alias react-native-vector-icons
to @expo/vector-icons
in the Babel preset (it’s now done in the Metro resolver instead), and we now add the Reanimated plugin by default when it’s installed (you don’t need to remove it from your babel.config.js, but you may want to).npx expo start
to run the Expo dev server.expo-updates
JavaScript APIs are no longer available in Expo Go or development builds using expo-dev-client
. The majority of the APIs exposed through the expo-updates
JavaScript interface (for example, checkForUpdateAsync
, fetchUpdateAsync
, etc.) are designed to be used in production builds. In development builds, Expo Go and expo-dev-client
control how updates are loaded in those environments.npx expo prebuild
no longer executes [npm|yarn|pnpm|bun] install
on each run by default. If no changes are made to the dependencies in the package.json (default when using the standard template) then the Node module installation step will be skipped. The only changes outside of the native directories will likely only be the package.json scripts now.@expo/vector-icons
has been updated to use react-native-vector-icons@10.0.0
: this adds support for FontAwesome6 and also changes to Ionicons and MaterialIcons. Most notably, the ios-
and md-
prefixed icon names in Ionicons have now dropped those prefixes. If you use TypeScript, you will be warned about any icon names that have changed when you update. Otherwise, be sure to verify that your icons are correct.Main*
classes: MainApplication.java/MainActivity.java are now MainApplication.kt/MainActivity.kt. If you depend on any config plugins that use dangerous modifications to change these files, they may need to be updated for SDK 50 support.ProgressBarAndroid
and ProgressViewIOS
components from React Native have been removed in 0.73, after a long period of deprecation.For years, Expo Go has supported multiple SDK versions in a single installation of the app (for example, Expo Go for SDK 49 supports SDK 47, 48, and 49 projects). We even have a patent for this approach: US Patent #11467854: “Method and apparatus for loading multiple differing versions of a native library into a native environment”. As you might imagine, there is a fair amount of work that goes into this for each SDK release — I’d go as far as to say that this is the single most tedious and difficult part of the release process.
At a time when development with Expo tooling was largely focused around Expo Go, this made a lot of sense for us to invest in. Expo Go was a stepping stone for us in our journey to building the Expo workflow as people know it today. The Expo Go app will continue to be a great sandbox to get started quickly and experiment with ideas, but we encourage adopting development builds for a flexible and powerful development environment suitable for real-world applications at scale.
We expect that including a single version of the Expo SDK in Expo Go will not have a large impact on most developers using Expo tools: Expo CLI will continue to install the appropriate version of Expo Go for the SDK that your project uses to any connected Android device/emulator or iOS simulator.
Let us know what you think about this upcoming change, and if you have any concerns about it: brent@expo.dev.
bun create expo-app --template blank@beta
npx create-expo-app --template blank@beta
yarn create expo-app --template blank@beta
create-expo-app
will install dependencies with the package manager that you are using. For example, with npm when npx
is used and yarn when yarn create
used.npm install expo@next
or yarn add expo@next
npx expo install --fix
i
or a
keyboard shortcut after running npx expo start
) and the updated version of Expo Go will be automatically installed.npm install expo@next
or yarn add expo@next
, then run npx expo install --fix
and consult the Native project upgrade helper and report any issues you encounter.npx expo prebuild --clean
and npm run ios
and npm run android
. Alternatively, try out npx expo run
. Any new issues? Please report them.Thank you for helping us with testing the release — we look forward to shipping it soon! 🚀