164 lines
6.2 KiB
Groovy
164 lines
6.2 KiB
Groovy
apply plugin: 'com.android.library'
|
|
apply plugin: 'maven-publish'
|
|
|
|
android {
|
|
compileSdkVersion rootProject.ext.compileSdkVersion
|
|
buildToolsVersion rootProject.ext.buildToolsVersion
|
|
|
|
defaultConfig {
|
|
minSdkVersion rootProject.ext.minSdkVersion
|
|
targetSdkVersion rootProject.ext.targetSdkVersion
|
|
}
|
|
|
|
buildTypes {
|
|
debug {}
|
|
release {
|
|
minifyEnabled false
|
|
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
|
}
|
|
}
|
|
}
|
|
|
|
dependencies {
|
|
compile fileTree(dir: 'libs', include: ['*.jar'])
|
|
|
|
compile 'com.android.support:appcompat-v7:25.4.0'
|
|
compile 'com.facebook.react:react-native:+'
|
|
|
|
compile project(':react-native-background-timer')
|
|
compile project(':react-native-fetch-blob')
|
|
compile project(':react-native-immersive')
|
|
compile project(':react-native-keep-awake')
|
|
compile project(':react-native-vector-icons')
|
|
compile project(':react-native-webrtc')
|
|
}
|
|
|
|
// Build process helpers
|
|
//
|
|
|
|
void runBefore(String dependentTaskName, Task task) {
|
|
Task dependentTask = tasks.findByPath(dependentTaskName);
|
|
if (dependentTask != null) {
|
|
dependentTask.dependsOn task
|
|
}
|
|
}
|
|
|
|
gradle.projectsEvaluated {
|
|
android.buildTypes.all { buildType ->
|
|
def buildNameCapitalized = "${buildType.name.capitalize()}"
|
|
def bundlePath = "${buildDir}/intermediates/bundles/${buildType.name}"
|
|
|
|
// Bundle fonts in react-native-vector-icons.
|
|
//
|
|
|
|
def currentFontTask = tasks.create(
|
|
name: "copy${buildNameCapitalized}Fonts",
|
|
type: Copy) {
|
|
from("${projectDir}/../../fonts/jitsi.ttf")
|
|
from("${projectDir}/../../node_modules/react-native-vector-icons/Fonts/")
|
|
into("${bundlePath}/assets/fonts")
|
|
}
|
|
|
|
currentFontTask.dependsOn("merge${buildNameCapitalized}Resources")
|
|
currentFontTask.dependsOn("merge${buildNameCapitalized}Assets")
|
|
|
|
runBefore("processArmeabi-v7a${buildNameCapitalized}Resources", currentFontTask)
|
|
runBefore("processX86${buildNameCapitalized}Resources", currentFontTask)
|
|
runBefore("processUniversal${buildNameCapitalized}Resources", currentFontTask)
|
|
runBefore("process${buildNameCapitalized}Resources", currentFontTask)
|
|
|
|
// Bundle JavaScript and React resources.
|
|
// (adapted from react-native/react.gradle)
|
|
//
|
|
|
|
// React JS bundle directories
|
|
def jsBundleDir = file("${bundlePath}/assets")
|
|
def resourcesDir = file("${bundlePath}/res/merged")
|
|
def jsBundleFile = file("${jsBundleDir}/index.android.bundle")
|
|
|
|
// Bundle task name for variant.
|
|
def bundleJsAndAssetsTaskName = "bundle${buildNameCapitalized}JsAndAssets"
|
|
|
|
def currentBundleTask = tasks.create(
|
|
name: bundleJsAndAssetsTaskName,
|
|
type: Exec) {
|
|
// Set up inputs and outputs so gradle can cache the result.
|
|
def reactRoot = file("${projectDir}/../../")
|
|
inputs.files fileTree(dir: reactRoot, excludes: ['android/**', 'ios/**'])
|
|
outputs.dir jsBundleDir
|
|
outputs.dir resourcesDir
|
|
|
|
// Set up the call to the react-native cli.
|
|
workingDir reactRoot
|
|
|
|
// Create JS bundle
|
|
def devEnabled = !buildNameCapitalized.toLowerCase().contains('release')
|
|
commandLine(
|
|
'node',
|
|
'node_modules/react-native/local-cli/cli.js',
|
|
'bundle',
|
|
'--assets-dest', resourcesDir,
|
|
'--bundle-output', jsBundleFile,
|
|
'--dev', "${devEnabled}",
|
|
'--entry-file', 'index.android.js',
|
|
'--platform', 'android',
|
|
'--reset-cache')
|
|
|
|
// Disable bundling on dev builds
|
|
enabled !devEnabled
|
|
}
|
|
|
|
// Hook bundle${productFlavor}${buildType}JsAndAssets into the android build process
|
|
currentBundleTask.dependsOn("merge${buildNameCapitalized}Resources")
|
|
currentBundleTask.dependsOn("merge${buildNameCapitalized}Assets")
|
|
|
|
runBefore("processArmeabi-v7a${buildNameCapitalized}Resources", currentBundleTask)
|
|
runBefore("processX86${buildNameCapitalized}Resources", currentBundleTask)
|
|
runBefore("processUniversal${buildNameCapitalized}Resources", currentBundleTask)
|
|
runBefore("process${buildNameCapitalized}Resources", currentBundleTask)
|
|
}
|
|
}
|
|
|
|
publishing {
|
|
publications {
|
|
aarArchive(MavenPublication) {
|
|
groupId 'org.jitsi.react'
|
|
artifactId 'jitsi-meet-sdk'
|
|
version '1.9.0'
|
|
|
|
artifact("${project.buildDir}/outputs/aar/${project.name}-release.aar") {
|
|
extension "aar"
|
|
}
|
|
pom.withXml {
|
|
def pomXml = asNode()
|
|
pomXml.appendNode('name', 'jitsi-meet-sdk')
|
|
pomXml.appendNode('description', 'Jitsi Meet SDK for Android')
|
|
def dependencies = pomXml.appendNode('dependencies')
|
|
configurations.getByName('releaseCompileClasspath').getResolvedConfiguration().getFirstLevelModuleDependencies().each {
|
|
// The (third-party) React Native modules that we depend on
|
|
// are in source code form and do not have groupId. That is
|
|
// why we have a dedicated groupId for them. But the other
|
|
// dependencies come through Maven and, consequently, have
|
|
// groupId.
|
|
def groupId = it.moduleGroup
|
|
def artifactId = it.moduleName
|
|
|
|
if (artifactId.startsWith('react-native-')
|
|
&& groupId.equals('jitsi-meet')) {
|
|
groupId = rootProject.ext.moduleGroupId
|
|
}
|
|
|
|
def dependency = dependencies.appendNode('dependency')
|
|
dependency.appendNode('groupId', groupId)
|
|
dependency.appendNode('artifactId', artifactId)
|
|
dependency.appendNode('version', it.moduleVersion)
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
repositories {
|
|
maven { url "file:${rootProject.projectDir}/../../../jitsi/jitsi-maven-repository/releases" }
|
|
}
|
|
}
|