React Native module for PhotoEditor SDK
Check out our video tutorial for a step-by-step integration guide which also details advanced SDK features, such as serializing and reusing previously applied editing operations.
System requirements
- React Native: 0.60
- iOS: 13
- Android: 5 (SDK 21)
Getting started
Known Issues
With version 2.13.0
, we recommend using compileSdkVersion
not lower than 31
for Android. However, this might interfere with your application's Android Gradle Plugin version if this is set to 4.x
.
If you don't use a newer Android Gradle Plugin version, e.g., by updating at least to RN 0.68.0, you'll most likely encounter a build error similar to:
FAILURE: Build failed with an exception.
* What went wrong:
A problem occurred configuring project ':react-native-photoeditorsdk'.
> com.android.builder.errors.EvalIssueException: Installed Build Tools revision 31.0.0 is corrupted. Remove and install again using the SDK Manager.
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.
* Get more help at https://help.gradle.org
As a workaround you can create the following symlinks:
- Inside
/Users/YOUR-USERNAME/Library/Android/sdk/build-tools/31.0.0/
: Create adx
symlink for thed8
file withln -s d8 dx
. - From there, go to
./lib/
and create adx.jar
symlink for thed8.jar
file withln -s d8.jar dx.jar
.
Expo CLI
Limitations
This module can not be used in the Expo Go
application because it uses custom native libraries.
Usage
In order to use this module with the Expo CLI you can make use of our integrated Expo config plugin:
-
Add our module to your Expo application:
expo install react-native-photoeditorsdk
This will automatically install
react-native-imglysdk
which you can use to configure your application with our Expo config plugin. -
Inside your app's
app.json
orapp.config.js
add our config plugin:{ "plugins": ["react-native-imglysdk"] }
If needed, you can also use a specific version of our native library for Android as well as define explicitly the included modules. By default, all modules for both PhotoEditor SDK and VideoEditor SDK are included. Furthermore, you can configure the
buildToolsVersion
,minSdkVersion
,compileSdkVersion
,targetSdkVersion
, andkotlinGradlePluginVersion
.{ "plugins": [ [ "react-native-imglysdk", { "android": { "version": "10.4.1", "modules": [ "ui:core", "ui:transform", "ui:filter", "assets:filter-basic" ], "buildToolsVersion": "31.0.0", "minSdkVersion": "21", "compileSdkVersion": "31", "targetSdkVersion": "30", "kotlinGradlePluginVersion": "1.5.32" } } ] ] }
For further information on the available modules, please refer to step 4 of the React Native CLI Android guide below.
Please note that the
react-native-imglysdk
module manages both VideoEditor SDK as well as PhotoEditor SDK so you only need to add the Expo config plugin once even when using both SDKs. -
From version
2.15.0
the iOS deployment target needs to be set to at least iOS 13. You can use theexpo-build-properties
config plugin for this. Please refer to the official Expo docs. -
The changes will be applied on
expo prebuild
or during the prebuild phase ofeas build
.
For further information on how to integrate Expo config plugins please also refer to the official docs.
React Native CLI
Install the React Native module in your project as follows:
yarn add react-native-photoeditorsdk
In general, we highly recommend using React Native 0.60 or newer. If you cannot avoid using an older React Native version you need to link the native dependencies with:
yarn react-native link
before you continue with the platform-specific guides below.
iOS
For React Native 0.60 and newer autolinking is used and PhotoEditor SDK for iOS should be automatically installed:
cd ios && pod install && cd ..
and updated:
cd ios && pod update && cd ..
with CocoaPods.
For older React Native versions autolinking is not available and PhotoEditor SDK for iOS needs to be manually integrated in your Xcode project if you don't use CocoaPods to manage your dependencies. Make sure to put ImglyKit.framework
and PhotoEditorSDK.framework
in the ios/
directory of your project.
Android
-
Add the img.ly repository and plugin by opening the
android/build.gradle
file (notandroid/app/build.gradle
) and adding these lines at the top:buildscript { repositories { mavenCentral() maven { url "https://artifactory.img.ly/artifactory/imgly" } } dependencies { classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.5.32" classpath 'ly.img.android.sdk:plugin:10.4.1' } }
In order to update PhotoEditor SDK for Android replace the version string
10.4.1
with a newer release. -
Still in the
android/build.gradle
file (notandroid/app/build.gradle
), add these lines at the bottom:allprojects { repositories { maven { url 'https://artifactory.img.ly/artifactory/imgly' } } }
-
In the same file, you will need to modify the
minSdkVersion
to at least21
. We also recommend to update thebuildToolsVersion
to31.0.0
or higher as well as thecompileSdkVersion
to31
or higher:buildscript { ext { - buildToolsVersion = "30.0.2" + buildToolsVersion = "31.0.0" - minSdkVersion = 19 + minSdkVersion = 21 - compileSdkVersion = 30 + compileSdkVersion = 31 targetSdkVersion = 30 } }
-
Configure PhotoEditor SDK for Android by opening the
android/app/build.gradle
file (notandroid/build.gradle
) and adding the following lines underapply plugin: "com.android.application"
:apply plugin: 'ly.img.android.sdk' apply plugin: 'kotlin-android' // Comment out the modules you don't need, to save size. imglyConfig { modules { include 'ui:text' include 'ui:focus' include 'ui:frame' include 'ui:brush' include 'ui:filter' include 'ui:sticker' include 'ui:overlay' include 'ui:transform' include 'ui:adjustment' include 'ui:text-design' // This module is big, remove the serializer if you don't need that feature. include 'backend:serializer' // Remove the asset packs you don't need, these are also big in size. include 'assets:font-basic' include 'assets:frame-basic' include 'assets:filter-basic' include 'assets:overlay-basic' include 'assets:sticker-shapes' include 'assets:sticker-emoticons' include 'backend:sticker-smart' include 'backend:background-removal' } }
Usage
Import the module in your App.js
:
import {
PESDK,
PhotoEditorModal,
Configuration,
} from "react-native-photoeditorsdk";
Each platform requires a separate license file. Unlock PhotoEditor SDK with a single line of code for both platforms via platform-specific file extensions:
PESDK.unlockWithLicense(require("./pesdk_license"));
Open the editor with an image:
PESDK.openEditor(require("./image.jpg"));
Or use the component to open the editor:
<PhotoEditorModal visible={true} image={require("./image.jpg")} />
Please see the code documentation for more details and additional customization and configuration options.
For configuring and customizing PhotoEditor SDK beyond these options exposed to JavaScript the iOS bridge provides an interface for native customization. Please refer to our documentation for more details on native customization.
Example
Please see our example project which demonstrates how to use the React Native module for PhotoEditor SDK.
License Terms
Make sure you have a commercial license for PhotoEditor SDK before releasing your app. A commercial license is required for any app or service that has any form of monetization: This includes free apps with in-app purchases or ad supported applications. Please contact us if you want to purchase the commercial license.
Support and License
Use our service desk for bug reports or support requests. To request a commercial license, please use the license request form on our website.