|
| 1 | +apply plugin: "com.android.application" |
| 2 | +apply plugin: "com.facebook.react" |
| 3 | + |
| 4 | +import com.android.build.OutputFile |
| 5 | + |
| 6 | +/** |
| 7 | + * This is the configuration block to customize your React Native Android app. |
| 8 | + * By default you don't need to apply any configuration, just uncomment the lines you need. |
| 9 | + */ |
| 10 | +react { |
| 11 | + /* Folders */ |
| 12 | + // The root of your project, i.e. where "package.json" lives. Default is '..' |
| 13 | + // root = file("../") |
| 14 | + // The folder where the react-native NPM package is. Default is ../node_modules/react-native |
| 15 | + // reactNativeDir = file("../node_modules/react-native") |
| 16 | + // The folder where the react-native Codegen package is. Default is ../node_modules/react-native-codegen |
| 17 | + // codegenDir = file("../node_modules/react-native-codegen") |
| 18 | + // The cli.js file which is the React Native CLI entrypoint. Default is ../node_modules/react-native/cli.js |
| 19 | + // cliFile = file("../node_modules/react-native/cli.js") |
| 20 | + |
| 21 | + /* Variants */ |
| 22 | + // The list of variants to that are debuggable. For those we're going to |
| 23 | + // skip the bundling of the JS bundle and the assets. By default is just 'debug'. |
| 24 | + // If you add flavors like lite, prod, etc. you'll have to list your debuggableVariants. |
| 25 | + // debuggableVariants = ["liteDebug", "prodDebug"] |
| 26 | + |
| 27 | + /* Bundling */ |
| 28 | + // A list containing the node command and its flags. Default is just 'node'. |
| 29 | + // nodeExecutableAndArgs = ["node"] |
| 30 | + // |
| 31 | + // The command to run when bundling. By default is 'bundle' |
| 32 | + // bundleCommand = "ram-bundle" |
| 33 | + // |
| 34 | + // The path to the CLI configuration file. Default is empty. |
| 35 | + // bundleConfig = file(../rn-cli.config.js) |
| 36 | + // |
| 37 | + // The name of the generated asset file containing your JS bundle |
| 38 | + // bundleAssetName = "MyApplication.android.bundle" |
| 39 | + // |
| 40 | + // The entry file for bundle generation. Default is 'index.android.js' or 'index.js' |
| 41 | + // entryFile = file("../js/MyApplication.android.js") |
| 42 | + // |
| 43 | + // A list of extra flags to pass to the 'bundle' commands. |
| 44 | + // See https://github.com/react-native-community/cli/blob/main/docs/commands.md#bundle |
| 45 | + // extraPackagerArgs = [] |
| 46 | + |
| 47 | + /* Hermes Commands */ |
| 48 | + // The hermes compiler command to run. By default it is 'hermesc' |
| 49 | + // hermesCommand = "$rootDir/my-custom-hermesc/bin/hermesc" |
| 50 | + // |
| 51 | + // The list of flags to pass to the Hermes compiler. By default is "-O", "-output-source-map" |
| 52 | + // hermesFlags = ["-O", "-output-source-map"] |
| 53 | +} |
| 54 | + |
| 55 | +/** |
| 56 | + * Set this to true to create four separate APKs instead of one, |
| 57 | + * one for each native architecture. This is useful if you don't |
| 58 | + * use App Bundles (https://developer.android.com/guide/app-bundle/) |
| 59 | + * and want to have separate APKs to upload to the Play Store. |
| 60 | + */ |
| 61 | +def enableSeparateBuildPerCPUArchitecture = false |
| 62 | + |
| 63 | +/** |
| 64 | + * Set this to true to Run Proguard on Release builds to minify the Java bytecode. |
| 65 | + */ |
| 66 | +def enableProguardInReleaseBuilds = false |
| 67 | + |
| 68 | +/** |
| 69 | + * The preferred build flavor of JavaScriptCore (JSC) |
| 70 | + * |
| 71 | + * For example, to use the international variant, you can use: |
| 72 | + * `def jscFlavor = 'org.webkit:android-jsc-intl:+'` |
| 73 | + * |
| 74 | + * The international variant includes ICU i18n library and necessary data |
| 75 | + * allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that |
| 76 | + * give correct results when using with locales other than en-US. Note that |
| 77 | + * this variant is about 6MiB larger per architecture than default. |
| 78 | + */ |
| 79 | +def jscFlavor = 'org.webkit:android-jsc:+' |
| 80 | + |
| 81 | +/** |
| 82 | + * Private function to get the list of Native Architectures you want to build. |
| 83 | + * This reads the value from reactNativeArchitectures in your gradle.properties |
| 84 | + * file and works together with the --active-arch-only flag of react-native run-android. |
| 85 | + */ |
| 86 | +def reactNativeArchitectures() { |
| 87 | + def value = project.getProperties().get("reactNativeArchitectures") |
| 88 | + return value ? value.split(",") : ["armeabi-v7a", "x86", "x86_64", "arm64-v8a"] |
| 89 | +} |
| 90 | + |
| 91 | +android { |
| 92 | + ndkVersion rootProject.ext.ndkVersion |
| 93 | + |
| 94 | + compileSdkVersion rootProject.ext.compileSdkVersion |
| 95 | + |
| 96 | + namespace "com.rndiffapp" |
| 97 | + defaultConfig { |
| 98 | + applicationId "com.rndiffapp" |
| 99 | + minSdkVersion rootProject.ext.minSdkVersion |
| 100 | + targetSdkVersion rootProject.ext.targetSdkVersion |
| 101 | + versionCode 1 |
| 102 | + versionName "1.0" |
| 103 | + } |
| 104 | + |
| 105 | + splits { |
| 106 | + abi { |
| 107 | + reset() |
| 108 | + enable enableSeparateBuildPerCPUArchitecture |
| 109 | + universalApk false // If true, also generate a universal APK |
| 110 | + include (*reactNativeArchitectures()) |
| 111 | + } |
| 112 | + } |
| 113 | + signingConfigs { |
| 114 | + debug { |
| 115 | + storeFile file('debug.keystore') |
| 116 | + storePassword 'android' |
| 117 | + keyAlias 'androiddebugkey' |
| 118 | + keyPassword 'android' |
| 119 | + } |
| 120 | + } |
| 121 | + buildTypes { |
| 122 | + debug { |
| 123 | + signingConfig signingConfigs.debug |
| 124 | + } |
| 125 | + release { |
| 126 | + // Caution! In production, you need to generate your own keystore file. |
| 127 | + // see https://reactnative.dev/docs/signed-apk-android. |
| 128 | + signingConfig signingConfigs.debug |
| 129 | + minifyEnabled enableProguardInReleaseBuilds |
| 130 | + proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" |
| 131 | + } |
| 132 | + } |
| 133 | + |
| 134 | + // applicationVariants are e.g. debug, release |
| 135 | + applicationVariants.all { variant -> |
| 136 | + variant.outputs.each { output -> |
| 137 | + // For each separate APK per architecture, set a unique version code as described here: |
| 138 | + // https://developer.android.com/studio/build/configure-apk-splits.html |
| 139 | + // Example: versionCode 1 will generate 1001 for armeabi-v7a, 1002 for x86, etc. |
| 140 | + def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4] |
| 141 | + def abi = output.getFilter(OutputFile.ABI) |
| 142 | + if (abi != null) { // null for the universal-debug, universal-release variants |
| 143 | + output.versionCodeOverride = |
| 144 | + defaultConfig.versionCode * 1000 + versionCodes.get(abi) |
| 145 | + } |
| 146 | + |
| 147 | + } |
| 148 | + } |
| 149 | +} |
| 150 | + |
| 151 | +dependencies { |
| 152 | + // The version of react-native is set by the React Native Gradle Plugin |
| 153 | + implementation("com.facebook.react:react-android") |
| 154 | + |
| 155 | + implementation("androidx.swiperefreshlayout:swiperefreshlayout:1.0.0") |
| 156 | + implementation 'com.google.android.material:material:1.7.0' |
| 157 | + |
| 158 | + debugImplementation("com.facebook.flipper:flipper:${FLIPPER_VERSION}") |
| 159 | + debugImplementation("com.facebook.flipper:flipper-network-plugin:${FLIPPER_VERSION}") { |
| 160 | + exclude group:'com.squareup.okhttp3', module:'okhttp' |
| 161 | + } |
| 162 | + |
| 163 | + debugImplementation("com.facebook.flipper:flipper-fresco-plugin:${FLIPPER_VERSION}") |
| 164 | + if (hermesEnabled.toBoolean()) { |
| 165 | + implementation("com.facebook.react:hermes-android") |
| 166 | + } else { |
| 167 | + implementation jscFlavor |
| 168 | + } |
| 169 | +} |
| 170 | + |
| 171 | +apply plugin: 'org.jetbrains.kotlin.android' |
| 172 | +apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project) |
0 commit comments