From d99d39a306ac5127cc22304d2bdd02d1a0e2bc1e Mon Sep 17 00:00:00 2001 From: Nick Fisher Date: Wed, 5 Jun 2024 22:30:42 +0800 Subject: [PATCH] update android example project --- .../example/android/.gitignore | 2 - .../example/android/app/build.gradle | 83 +++++------------- .../example/android/app/proguard-rules.pro | 9 -- .../android/app/src/debug/AndroidManifest.xml | 6 +- .../android/app/src/main/AndroidManifest.xml | 37 ++++---- .../app/polyvox/example/MainActivity.kt | 5 ++ .../flutter_filament_example/MainActivity.kt | 10 --- .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 544 -> 128 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 442 -> 128 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 721 -> 128 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 1031 -> 129 bytes .../main/res/mipmap-xxxhdpi/ic_launcher.png | Bin 1443 -> 129 bytes .../app/src/main/res/values-night/styles.xml | 4 +- .../app/src/main/res/values/styles.xml | 12 ++- .../app/src/profile/AndroidManifest.xml | 6 +- .../example/android/build.gradle | 20 +---- .../example/android/gradle.properties | 8 +- .../gradle/wrapper/gradle-wrapper.properties | 2 +- .../example/android/settings.gradle | 32 ++++--- 19 files changed, 91 insertions(+), 145 deletions(-) delete mode 100644 flutter_filament_federated/flutter_filament/example/android/app/proguard-rules.pro create mode 100644 flutter_filament_federated/flutter_filament/example/android/app/src/main/kotlin/app/polyvox/example/MainActivity.kt delete mode 100644 flutter_filament_federated/flutter_filament/example/android/app/src/main/kotlin/app/polyvox/flutter_filament_example/MainActivity.kt diff --git a/flutter_filament_federated/flutter_filament/example/android/.gitignore b/flutter_filament_federated/flutter_filament/example/android/.gitignore index 473d8bd3..6f568019 100644 --- a/flutter_filament_federated/flutter_filament/example/android/.gitignore +++ b/flutter_filament_federated/flutter_filament/example/android/.gitignore @@ -6,8 +6,6 @@ gradle-wrapper.jar /local.properties GeneratedPluginRegistrant.java -.cxx/ - # Remember to never publicly share your keystore. # See https://flutter.dev/docs/deployment/android#reference-the-keystore-from-the-app key.properties diff --git a/flutter_filament_federated/flutter_filament/example/android/app/build.gradle b/flutter_filament_federated/flutter_filament/example/android/app/build.gradle index f5e12798..6402c23f 100644 --- a/flutter_filament_federated/flutter_filament/example/android/app/build.gradle +++ b/flutter_filament_federated/flutter_filament/example/android/app/build.gradle @@ -1,81 +1,44 @@ -def localProperties = new Properties() -def localPropertiesFile = rootProject.file('local.properties') -if (localPropertiesFile.exists()) { - localPropertiesFile.withReader('UTF-8') { reader -> - localProperties.load(reader) - } +plugins { + id "com.android.application" + id "kotlin-android" + // The Flutter Gradle Plugin must be applied after the Android and Kotlin Gradle plugins. + id "dev.flutter.flutter-gradle-plugin" } -def flutterRoot = localProperties.getProperty('flutter.sdk') -if (flutterRoot == null) { - throw new GradleException("Flutter SDK not found. Define location with flutter.sdk in the local.properties file.") -} - -def flutterVersionCode = localProperties.getProperty('flutter.versionCode') -if (flutterVersionCode == null) { - flutterVersionCode = '1' -} - -def flutterVersionName = localProperties.getProperty('flutter.versionName') -if (flutterVersionName == null) { - flutterVersionName = '1.0' -} - -apply plugin: 'com.android.application' -apply plugin: 'kotlin-android' -apply plugin: 'kotlin-android-extensions' - -apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle" - android { - compileSdkVersion 34 - ndkVersion "25.2.9519653" + namespace = "app.polyvox.example" + compileSdk = flutter.compileSdkVersion + ndkVersion = flutter.ndkVersion compileOptions { - sourceCompatibility JavaVersion.VERSION_1_8 - targetCompatibility JavaVersion.VERSION_1_8 + sourceCompatibility = JavaVersion.VERSION_1_8 + targetCompatibility = JavaVersion.VERSION_1_8 } kotlinOptions { - jvmTarget = '1.8' - } - - sourceSets { - main.java.srcDirs += 'src/main/kotlin' + jvmTarget = JavaVersion.VERSION_1_8 } defaultConfig { - applicationId "app.polyvox.flutter_filament_example" - minSdkVersion 22 - targetSdkVersion 31 - versionCode flutterVersionCode.toInteger() - versionName flutterVersionName - ndk { - abiFilters 'arm64-v8a' // 'x86_64' 'armeabi-v7a' - } + // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). + applicationId = "app.polyvox.example" + // You can update the following values to match your application needs. + // For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-gradle-build-configuration. + minSdk = flutter.minSdkVersion + targetSdk = flutter.targetSdkVersion + versionCode = flutter.versionCode + versionName = flutter.versionName } buildTypes { release { - signingConfig signingConfigs.debug - minifyEnabled true - shrinkResources true - proguardFiles getDefaultProguardFile( - 'proguard-android-optimize.txt'), - 'proguard-rules.pro' + // TODO: Add your own signing config for the release build. + // Signing with the debug keys for now, so `flutter run --release` works. + signingConfig = signingConfigs.debug } } } flutter { - source '../..' -} - -dependencies { - implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version" - implementation "org.jetbrains.kotlinx:kotlinx-coroutines-core:1.5.2" - implementation "org.jetbrains.kotlinx:kotlinx-coroutines-android:1.5.2" - implementation "androidx.annotation:annotation:1.3.0" - implementation "androidx.core:core:1.7.0" - implementation 'net.java.dev.jna:jna:5.10.0@aar' + source = "../.." } diff --git a/flutter_filament_federated/flutter_filament/example/android/app/proguard-rules.pro b/flutter_filament_federated/flutter_filament/example/android/app/proguard-rules.pro deleted file mode 100644 index f67c58ea..00000000 --- a/flutter_filament_federated/flutter_filament/example/android/app/proguard-rules.pro +++ /dev/null @@ -1,9 +0,0 @@ --keep class io.flutter.app.** { *; } --keep class io.flutter.plugin.** { *; } --keep class io.flutter.util.** { *; } --keep class io.flutter.view.** { *; } --keep class io.flutter.** { *; } --keep class io.flutter.plugins.** { *; } --dontwarn java.awt.* --keep class com.sun.jna.* { *; } --keepclassmembers class * extends com.sun.jna.* { public *; } \ No newline at end of file diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/debug/AndroidManifest.xml b/flutter_filament_federated/flutter_filament/example/android/app/src/debug/AndroidManifest.xml index 3fac46b6..399f6981 100644 --- a/flutter_filament_federated/flutter_filament/example/android/app/src/debug/AndroidManifest.xml +++ b/flutter_filament_federated/flutter_filament/example/android/app/src/debug/AndroidManifest.xml @@ -1,6 +1,6 @@ - - diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/main/AndroidManifest.xml b/flutter_filament_federated/flutter_filament/example/android/app/src/main/AndroidManifest.xml index 10e1b0cb..74a78b93 100644 --- a/flutter_filament_federated/flutter_filament/example/android/app/src/main/AndroidManifest.xml +++ b/flutter_filament_federated/flutter_filament/example/android/app/src/main/AndroidManifest.xml @@ -1,20 +1,17 @@ - - - + + android:icon="@mipmap/ic_launcher"> + android:windowSoftInputMode="adjustResize"> - @@ -43,4 +31,15 @@ android:name="flutterEmbedding" android:value="2" /> + + + + + + + diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/main/kotlin/app/polyvox/example/MainActivity.kt b/flutter_filament_federated/flutter_filament/example/android/app/src/main/kotlin/app/polyvox/example/MainActivity.kt new file mode 100644 index 00000000..c546a613 --- /dev/null +++ b/flutter_filament_federated/flutter_filament/example/android/app/src/main/kotlin/app/polyvox/example/MainActivity.kt @@ -0,0 +1,5 @@ +package app.polyvox.example + +import io.flutter.embedding.android.FlutterActivity + +class MainActivity: FlutterActivity() diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/main/kotlin/app/polyvox/flutter_filament_example/MainActivity.kt b/flutter_filament_federated/flutter_filament/example/android/app/src/main/kotlin/app/polyvox/flutter_filament_example/MainActivity.kt deleted file mode 100644 index fbdcbc30..00000000 --- a/flutter_filament_federated/flutter_filament/example/android/app/src/main/kotlin/app/polyvox/flutter_filament_example/MainActivity.kt +++ /dev/null @@ -1,10 +0,0 @@ -package app.polyvox.flutter_filament_example - -import io.flutter.embedding.android.FlutterActivity -import io.flutter.embedding.android.TransparencyMode - -class MainActivity: FlutterActivity() { - override fun getTransparencyMode(): TransparencyMode { - return TransparencyMode.transparent - } -} diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/mipmap-hdpi/ic_launcher.png b/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/mipmap-hdpi/ic_launcher.png index db77bb4b7b0906d62b1847e87f15cdcacf6a4f29..1be8cfe844b15e05c9de3599e39fc8ece41ecb5d 100644 GIT binary patch literal 128 zcmWN?OA^8$3;@tQr{Dq>NFasYrhFpIsB}#2!qe;9ysN!s%$M%xdB|qWeVn%k%ksZ} z@>1s0$kB?qoSLI*={p44XkSZYTUUz>DT1?+6A^H9h!y||ysgNQ31iNfTtmp56WI{B Lv6As^I(V;sV+|%5 literal 544 zcmeAS@N?(olHy`uVBq!ia0vp^9w5xY3?!3`olAj~WQl7;NpOBzNqJ&XDuZK6ep0G} zXKrG8YEWuoN@d~6R2!h8bpbvhu0Wd6uZuB!w&u2PAxD2eNXD>P5D~Wn-+_Wa#27Xc zC?Zj|6r#X(-D3u$NCt}(Ms06KgJ4FxJVv{GM)!I~&n8Bnc94O7-Hd)cjDZswgC;Qs zO=b+9!WcT8F?0rF7!Uys2bs@gozCP?z~o%U|N3vA*22NaGQG zlg@K`O_XuxvZ&Ks^m&R!`&1=spLvfx7oGDKDwpwW`#iqdw@AL`7MR}m`rwr|mZgU`8P7SBkL78fFf!WnuYWm$5Z0 zNXhDbCv&49sM544K|?c)WrFfiZvCi9h0O)B3Pgg&ebxsLQ05GG~ AQ2+n{ diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/mipmap-mdpi/ic_launcher.png b/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/mipmap-mdpi/ic_launcher.png index 17987b79bb8a35cc66c3c1fd44f5a5526c1b78be..87515b2d645d212f2e45a76da6f549df4ed15f3c 100644 GIT binary patch literal 128 zcmWN?%MpVh5CG6SRnS0$#pP!=ur7g_Bsc**r26^98Bs0(c3OZO~$&7JZaJpBA{jD)g;tF4k+gR&U%Yk8;9&uNoi*pfB zP2drbID<_#qf;rPZx^FqH)F_D#*k@@q03KywUtLX8Ua?`H+NMzkczFPK3lFz@i_kW%1NOn0|D2I9n9wzH8m|-tHjsw|9>@K=iMBhxvkv6m8Y-l zytQ?X=U+MF$@3 zt`~i=@j|6y)RWMK--}M|=T`o&^Ni>IoWKHEbBXz7?A@mgWoL>!*SXo`SZH-*HSdS+ yn*9;$7;m`l>wYBC5bq;=U}IMqLzqbYCidGC!)_gkIk_C@Uy!y&wkt5C($~2D>~)O*cj@FGjOCM)M>_ixfudOh)?xMu#Fs z#}Y=@YDTwOM)x{K_j*Q;dPdJ?Mz0n|pLRx{4n|)f>SXlmV)XB04CrSJn#dS5nK2lM zrZ9#~WelCp7&e13Y$jvaEXHskn$2V!!DN-nWS__6T*l;H&Fopn?A6HZ-6WRLFP=R` zqG+CE#d4|IbyAI+rJJ`&x9*T`+a=p|0O(+s{UBcyZdkhj=yS1>AirP+0R;mf2uMgM zC}@~JfByORAh4SyRgi&!(cja>F(l*O+nd+@4m$|6K6KDn_&uvCpV23&>G9HJp{xgg zoq1^2_p9@|WEo z*X_Uko@K)qYYv~>43eQGMdbiGbo>E~Q& zrYBH{QP^@Sti!`2)uG{irBBq@y*$B zi#&(U-*=fp74j)RyIw49+0MRPMRU)+a2r*PJ$L5roHt2$UjExCTZSbq%V!HeS7J$N zdG@vOZB4v_lF7Plrx+hxo7(fCV&}fHq)$ diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png index d5f1c8d34e7a88e3f88bea192c3a370d44689c3c..7172d5a93bb1db937dda60ff09b182d0ca16657c 100644 GIT binary patch literal 129 zcmWN?%MrpL5CG6SRnUNeMV3#xfn5-0R5C(xuzG!$ca_iV<1O1-$J~{A^mTjIx&3cv z-e|nkJPN4`#ON$%O9tI;*?OI;F^mMBgDp&0gF$c%IfVqIBVr`>4ye@Zqp87htY|V? MEoT1~3HlD=2h5!(WB>pF literal 1031 zcmeAS@N?(olHy`uVBq!ia0vp^6F``Q8Ax83A=Cw=BuiW)N`mv#O3D+9QW+dm@{>{( zJaZG%Q-e|yQz{EjrrIztFa`(sgt!6~Yi|1%a`XoT0ojZ}lNrNjb9xjc(B0U1_% zz5^97Xt*%oq$rQy4?0GKNfJ44uvxI)gC`h-NZ|&0-7(qS@?b!5r36oQ}zyZrNO3 zMO=Or+<~>+A&uN&E!^Sl+>xE!QC-|oJv`ApDhqC^EWD|@=#J`=d#Xzxs4ah}w&Jnc z$|q_opQ^2TrnVZ0o~wh<3t%W&flvYGe#$xqda2bR_R zvPYgMcHgjZ5nSA^lJr%;<&0do;O^tDDh~=pIxA#coaCY>&N%M2^tq^U%3DB@ynvKo}b?yu-bFc-u0JHzced$sg7S3zqI(2 z#Km{dPr7I=pQ5>FuK#)QwK?Y`E`B?nP+}U)I#c1+FM*1kNvWG|a(TpksZQ3B@sD~b zpQ2)*V*TdwjFOtHvV|;OsiDqHi=6%)o4b!)x$)%9pGTsE z-JL={-Ffv+T87W(Xpooq<`r*VzWQcgBN$$`u}f>-ZQI1BB8ykN*=e4rIsJx9>z}*o zo~|9I;xof diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png b/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png index 4d6372eebdb28e45604e46eeda8dd24651419bc0..4183fcce1c2d121a39442793d55184f26e14e50d 100644 GIT binary patch literal 129 zcmWN?%MrpL5CG6SRnUMT!17Bsuq?uiO2)+;tX|*cUG(NLU$U=t@}bmytlOjU_P>A1 zhV!ZTBvh9cb5zMa8|M#;7DzXfV%;%Ow%}X^UyCmxxP;MYogq;o^aN16bqyWHP+I{V McfsRJQUh4=1Hi#2L;wH) literal 1443 zcmb`G{WsKk6vsdJTdFg%tJav9_E4vzrOaqkWF|A724Nly!y+?N9`YV6wZ}5(X(D_N(?!*n3`|_r0Hc?=PQw&*vnU?QTFY zB_MsH|!j$PP;I}?dppoE_gA(4uc!jV&0!l7_;&p2^pxNo>PEcNJv za5_RT$o2Mf!<+r?&EbHH6nMoTsDOa;mN(wv8RNsHpG)`^ymG-S5By8=l9iVXzN_eG%Xg2@Xeq76tTZ*dGh~Lo9vl;Zfs+W#BydUw zCkZ$o1LqWQO$FC9aKlLl*7x9^0q%0}$OMlp@Kk_jHXOjofdePND+j!A{q!8~Jn+s3 z?~~w@4?egS02}8NuulUA=L~QQfm;MzCGd)XhiftT;+zFO&JVyp2mBww?;QByS_1w! zrQlx%{^cMj0|Bo1FjwY@Q8?Hx0cIPF*@-ZRFpPc#bBw{5@tD(5%sClzIfl8WU~V#u zm5Q;_F!wa$BSpqhN>W@2De?TKWR*!ujY;Yylk_X5#~V!L*Gw~;$%4Q8~Mad z@`-kG?yb$a9cHIApZDVZ^U6Xkp<*4rU82O7%}0jjHlK{id@?-wpN*fCHXyXh(bLt* zPc}H-x0e4E&nQ>y%B-(EL=9}RyC%MyX=upHuFhAk&MLbsF0LP-q`XnH78@fT+pKPW zu72MW`|?8ht^tz$iC}ZwLp4tB;Q49K!QCF3@!iB1qOI=?w z7In!}F~ij(18UYUjnbmC!qKhPo%24?8U1x{7o(+?^Zu0Hx81|FuS?bJ0jgBhEMzf< zCgUq7r2OCB(`XkKcN-TL>u5y#dD6D!)5W?`O5)V^>jb)P)GBdy%t$uUMpf$SNV31$ zb||OojAbvMP?T@$h_ZiFLFVHDmbyMhJF|-_)HX3%m=CDI+ID$0^C>kzxprBW)hw(v zr!Gmda);ICoQyhV_oP5+C%?jcG8v+D@9f?Dk*!BxY}dazmrT@64UrP3hlslANK)bq z$67n83eh}OeW&SV@HG95P|bjfqJ7gw$e+`Hxo!4cx`jdK1bJ>YDSpGKLPZ^1cv$ek zIB?0S<#tX?SJCLWdMd{-ME?$hc7A$zBOdIJ)4!KcAwb=VMov)nK;9z>x~rfT1>dS+ zZ6#`2v@`jgbqq)P22H)Tx2CpmM^o1$B+xT6`(v%5xJ(?j#>Q$+rx_R|7TzDZe{J6q zG1*EcU%tE?!kO%^M;3aM6JN*LAKUVb^xz8-Pxo#jR5(-KBeLJvA@-gxNHx0M-ZJLl z;#JwQoh~9V?`UVo#}{6ka@II>++D@%KqGpMdlQ}?9E*wFcf5(#XQnP$Dk5~%iX^>f z%$y;?M0BLp{O3a(-4A?ewryHrrD%cx#Q^%KY1H zNre$ve+vceSLZcNY4U(RBX&)oZn*Py()h)XkE?PL$!bNb{N5FVI2Y%LKEm%yvpyTP z(1P?z~7YxD~Rf<(a@_y` diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/values-night/styles.xml b/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/values-night/styles.xml index 449a9f93..06952be7 100644 --- a/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/values-night/styles.xml +++ b/flutter_filament_federated/flutter_filament/example/android/app/src/main/res/values-night/styles.xml @@ -3,14 +3,14 @@ + diff --git a/flutter_filament_federated/flutter_filament/example/android/app/src/profile/AndroidManifest.xml b/flutter_filament_federated/flutter_filament/example/android/app/src/profile/AndroidManifest.xml index 3fac46b6..399f6981 100644 --- a/flutter_filament_federated/flutter_filament/example/android/app/src/profile/AndroidManifest.xml +++ b/flutter_filament_federated/flutter_filament/example/android/app/src/profile/AndroidManifest.xml @@ -1,6 +1,6 @@ - - diff --git a/flutter_filament_federated/flutter_filament/example/android/build.gradle b/flutter_filament_federated/flutter_filament/example/android/build.gradle index 2f76fefa..d2ffbffa 100644 --- a/flutter_filament_federated/flutter_filament/example/android/build.gradle +++ b/flutter_filament_federated/flutter_filament/example/android/build.gradle @@ -1,17 +1,3 @@ -buildscript { - ext.kotlin_version = '1.6.0' - repositories { - google() - mavenCentral() - } - - dependencies { - classpath 'com.android.tools.build:gradle:4.1.0' - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - - } -} - allprojects { repositories { google() @@ -19,10 +5,12 @@ allprojects { } } -rootProject.buildDir = '../build' +rootProject.buildDir = "../build" subprojects { project.buildDir = "${rootProject.buildDir}/${project.name}" - project.evaluationDependsOn(':app') +} +subprojects { + project.evaluationDependsOn(":app") } tasks.register("clean", Delete) { diff --git a/flutter_filament_federated/flutter_filament/example/android/gradle.properties b/flutter_filament_federated/flutter_filament/example/android/gradle.properties index 0387ff25..25971708 100644 --- a/flutter_filament_federated/flutter_filament/example/android/gradle.properties +++ b/flutter_filament_federated/flutter_filament/example/android/gradle.properties @@ -1,9 +1,3 @@ -org.gradle.jvmargs=-Xmx1536M \ ---add-exports=java.base/sun.nio.ch=ALL-UNNAMED \ ---add-opens=java.base/java.lang=ALL-UNNAMED \ ---add-opens=java.base/java.lang.reflect=ALL-UNNAMED \ ---add-opens=java.base/java.io=ALL-UNNAMED \ ---add-exports=jdk.unsupported/sun.misc=ALL-UNNAMED +org.gradle.jvmargs=-Xmx4G -XX:MaxMetaspaceSize=2G -XX:+HeapDumpOnOutOfMemoryError android.useAndroidX=true android.enableJetifier=true - diff --git a/flutter_filament_federated/flutter_filament/example/android/gradle/wrapper/gradle-wrapper.properties b/flutter_filament_federated/flutter_filament/example/android/gradle/wrapper/gradle-wrapper.properties index 8048ce64..e1ca574e 100644 --- a/flutter_filament_federated/flutter_filament/example/android/gradle/wrapper/gradle-wrapper.properties +++ b/flutter_filament_federated/flutter_filament/example/android/gradle/wrapper/gradle-wrapper.properties @@ -2,4 +2,4 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-7.6.3-all.zip \ No newline at end of file +distributionUrl=https\://services.gradle.org/distributions/gradle-7.6.3-all.zip diff --git a/flutter_filament_federated/flutter_filament/example/android/settings.gradle b/flutter_filament_federated/flutter_filament/example/android/settings.gradle index 121d30d8..536165d3 100644 --- a/flutter_filament_federated/flutter_filament/example/android/settings.gradle +++ b/flutter_filament_federated/flutter_filament/example/android/settings.gradle @@ -1,15 +1,25 @@ -include ':app' +pluginManagement { + def flutterSdkPath = { + def properties = new Properties() + file("local.properties").withInputStream { properties.load(it) } + def flutterSdkPath = properties.getProperty("flutter.sdk") + assert flutterSdkPath != null, "flutter.sdk not set in local.properties" + return flutterSdkPath + }() -def flutterProjectRoot = rootProject.projectDir.parentFile.toPath() + includeBuild("$flutterSdkPath/packages/flutter_tools/gradle") -def plugins = new Properties() -def pluginsFile = new File(flutterProjectRoot.toFile(), '.flutter-plugins') -if (pluginsFile.exists()) { - pluginsFile.withReader('UTF-8') { reader -> plugins.load(reader) } + repositories { + google() + mavenCentral() + gradlePluginPortal() + } } -plugins.each { name, path -> - def pluginDirectory = flutterProjectRoot.resolve(path).resolve('android').toFile() - include ":$name" - project(":$name").projectDir = pluginDirectory -} \ No newline at end of file +plugins { + id "dev.flutter.flutter-plugin-loader" version "1.0.0" + id "com.android.application" version "7.3.0" apply false + id "org.jetbrains.kotlin.android" version "1.7.10" apply false +} + +include ":app"