From edbe7a19fe2e728adb5f36a0b131ef0ece0cc455 Mon Sep 17 00:00:00 2001 From: Michael Nabil Date: Fri, 19 Apr 2024 19:56:27 +0200 Subject: [PATCH 1/2] Update --- example/.metadata | 24 +- example/README.md | 298 +++++++++--------- example/analysis_options.yaml | 3 + example/android/.gitignore | 6 + example/android/app/build.gradle | 46 +-- .../android/app/src/debug/AndroidManifest.xml | 6 +- .../android/app/src/main/AndroidManifest.xml | 29 +- .../app/src/main/res/values-night/styles.xml | 4 +- .../app/src/main/res/values/styles.xml | 4 +- .../app/src/profile/AndroidManifest.xml | 6 +- example/android/build.gradle | 17 +- example/android/gradle.properties | 3 +- .../gradle/wrapper/gradle-wrapper.properties | 3 +- example/android/settings.gradle | 31 +- example/ios/.gitignore | 2 + example/ios/Flutter/.last_build_id | 1 - example/ios/Flutter/AppFrameworkInfo.plist | 4 +- example/ios/Flutter/Debug.xcconfig | 1 - example/ios/Flutter/Release.xcconfig | 1 - example/ios/Podfile | 5 +- example/ios/Runner.xcodeproj/project.pbxproj | 255 ++++++++------- .../xcshareddata/xcschemes/Runner.xcscheme | 21 +- .../contents.xcworkspacedata | 3 - .../AppIcon.appiconset/Icon-App-20x20@1x.png | Bin 564 -> 295 bytes .../AppIcon.appiconset/Icon-App-20x20@2x.png | Bin 1283 -> 406 bytes .../AppIcon.appiconset/Icon-App-20x20@3x.png | Bin 1588 -> 450 bytes .../AppIcon.appiconset/Icon-App-29x29@1x.png | Bin 1025 -> 282 bytes .../AppIcon.appiconset/Icon-App-29x29@2x.png | Bin 1716 -> 462 bytes .../AppIcon.appiconset/Icon-App-29x29@3x.png | Bin 1920 -> 704 bytes .../AppIcon.appiconset/Icon-App-40x40@1x.png | Bin 1283 -> 406 bytes .../AppIcon.appiconset/Icon-App-40x40@2x.png | Bin 1895 -> 586 bytes .../AppIcon.appiconset/Icon-App-40x40@3x.png | Bin 2665 -> 862 bytes .../AppIcon.appiconset/Icon-App-60x60@2x.png | Bin 2665 -> 862 bytes .../AppIcon.appiconset/Icon-App-60x60@3x.png | Bin 3831 -> 1674 bytes .../AppIcon.appiconset/Icon-App-76x76@1x.png | Bin 1888 -> 762 bytes .../AppIcon.appiconset/Icon-App-76x76@2x.png | Bin 3294 -> 1226 bytes .../Icon-App-83.5x83.5@2x.png | Bin 3612 -> 1418 bytes example/ios/Runner/Info.plist | 6 +- example/ios/Runner/Runner-Bridging-Header.h | 2 +- .../Runner/ar-DZ.lproj/LaunchScreen.strings | 1 - example/ios/Runner/ar-DZ.lproj/Main.strings | 1 - .../ios/Runner/ru.lproj/LaunchScreen.strings | 1 - example/ios/Runner/ru.lproj/Main.strings | 1 - example/{resources => }/langs/ar-DZ.json | 0 example/{resources => }/langs/ar-DZ.xml | 0 example/{resources => }/langs/ar-DZ.yaml | 0 example/{resources => }/langs/ar.json | 0 example/{resources => }/langs/de-DE.json | 0 example/{resources => }/langs/de-DE.xml | 0 example/{resources => }/langs/de-DE.yaml | 0 example/{resources => }/langs/de.json | 0 example/{resources => }/langs/en-US.json | 0 example/{resources => }/langs/en-US.xml | 0 example/{resources => }/langs/en-US.yaml | 0 example/{resources => }/langs/en.json | 0 example/{resources => }/langs/langs.csv | 0 example/{resources => }/langs/langs.xml | 0 example/{resources => }/langs/langs.yaml | 0 example/{resources => }/langs/ru-RU.json | 0 example/{resources => }/langs/ru-RU.xml | 0 example/{resources => }/langs/ru-RU.yaml | 0 example/{resources => }/langs/ru.json | 0 .../{lang_view.dart => language_view.dart} | 89 +++--- example/lib/main.dart | 114 +++---- example/linux/CMakeLists.txt | 53 +++- example/linux/flutter/CMakeLists.txt | 7 +- example/linux/my_application.cc | 39 ++- example/macos/.gitignore | 1 + example/macos/Flutter/Flutter-Debug.xcconfig | 1 - .../macos/Flutter/Flutter-Release.xcconfig | 1 - .../Flutter/GeneratedPluginRegistrant.swift | 2 - example/macos/Podfile | 82 ----- .../macos/Runner.xcodeproj/project.pbxproj | 175 ++++++++-- .../xcshareddata/xcschemes/Runner.xcscheme | 33 +- .../AppIcon.appiconset/app_icon_1024.png | Bin 32342 -> 102994 bytes .../AppIcon.appiconset/app_icon_128.png | Bin 2661 -> 5680 bytes .../AppIcon.appiconset/app_icon_16.png | Bin 1020 -> 520 bytes .../AppIcon.appiconset/app_icon_256.png | Bin 4377 -> 14142 bytes .../AppIcon.appiconset/app_icon_32.png | Bin 1243 -> 1066 bytes .../AppIcon.appiconset/app_icon_512.png | Bin 9926 -> 36406 bytes .../AppIcon.appiconset/app_icon_64.png | Bin 1874 -> 2218 bytes example/macos/Runner/Base.lproj/MainMenu.xib | 4 + example/macos/Runner/Configs/AppInfo.xcconfig | 2 +- example/macos/Runner/MainFlutterWindow.swift | 2 +- example/pubspec.yaml | 64 +--- example/resources/fonts/MyFlutterApp.ttf | Bin 2292 -> 0 bytes example/test/widget_test.dart | 30 -- example/web/favicon.png | Bin 651 -> 917 bytes example/web/icons/Icon-maskable-192.png | Bin 0 -> 5594 bytes example/web/icons/Icon-maskable-512.png | Bin 0 -> 20998 bytes example/web/index.html | 84 +++-- example/web/manifest.json | 16 +- example/windows/.gitignore | 17 + example/windows/CMakeLists.txt | 108 +++++++ example/windows/flutter/CMakeLists.txt | 109 +++++++ .../flutter/generated_plugin_registrant.cc | 11 + .../flutter/generated_plugin_registrant.h | 15 + .../windows/flutter/generated_plugins.cmake | 23 ++ example/windows/runner/CMakeLists.txt | 40 +++ example/windows/runner/Runner.rc | 121 +++++++ example/windows/runner/flutter_window.cpp | 71 +++++ example/windows/runner/flutter_window.h | 33 ++ example/windows/runner/main.cpp | 43 +++ example/windows/runner/resource.h | 16 + example/windows/runner/resources/app_icon.ico | Bin 0 -> 33772 bytes example/windows/runner/runner.exe.manifest | 20 ++ example/windows/runner/utils.cpp | 65 ++++ example/windows/runner/utils.h | 19 ++ example/windows/runner/win32_window.cpp | 288 +++++++++++++++++ example/windows/runner/win32_window.h | 102 ++++++ 110 files changed, 1925 insertions(+), 760 deletions(-) create mode 100644 example/analysis_options.yaml delete mode 100644 example/ios/Flutter/.last_build_id delete mode 100644 example/ios/Runner/ar-DZ.lproj/LaunchScreen.strings delete mode 100644 example/ios/Runner/ar-DZ.lproj/Main.strings delete mode 100644 example/ios/Runner/ru.lproj/LaunchScreen.strings delete mode 100644 example/ios/Runner/ru.lproj/Main.strings rename example/{resources => }/langs/ar-DZ.json (100%) rename example/{resources => }/langs/ar-DZ.xml (100%) rename example/{resources => }/langs/ar-DZ.yaml (100%) rename example/{resources => }/langs/ar.json (100%) rename example/{resources => }/langs/de-DE.json (100%) rename example/{resources => }/langs/de-DE.xml (100%) rename example/{resources => }/langs/de-DE.yaml (100%) rename example/{resources => }/langs/de.json (100%) rename example/{resources => }/langs/en-US.json (100%) rename example/{resources => }/langs/en-US.xml (100%) rename example/{resources => }/langs/en-US.yaml (100%) rename example/{resources => }/langs/en.json (100%) rename example/{resources => }/langs/langs.csv (100%) rename example/{resources => }/langs/langs.xml (100%) rename example/{resources => }/langs/langs.yaml (100%) rename example/{resources => }/langs/ru-RU.json (100%) rename example/{resources => }/langs/ru-RU.xml (100%) rename example/{resources => }/langs/ru-RU.yaml (100%) rename example/{resources => }/langs/ru.json (100%) rename example/lib/{lang_view.dart => language_view.dart} (55%) delete mode 100644 example/macos/Podfile delete mode 100644 example/resources/fonts/MyFlutterApp.ttf delete mode 100644 example/test/widget_test.dart create mode 100644 example/web/icons/Icon-maskable-192.png create mode 100644 example/web/icons/Icon-maskable-512.png create mode 100644 example/windows/.gitignore create mode 100644 example/windows/CMakeLists.txt create mode 100644 example/windows/flutter/CMakeLists.txt create mode 100644 example/windows/flutter/generated_plugin_registrant.cc create mode 100644 example/windows/flutter/generated_plugin_registrant.h create mode 100644 example/windows/flutter/generated_plugins.cmake create mode 100644 example/windows/runner/CMakeLists.txt create mode 100644 example/windows/runner/Runner.rc create mode 100644 example/windows/runner/flutter_window.cpp create mode 100644 example/windows/runner/flutter_window.h create mode 100644 example/windows/runner/main.cpp create mode 100644 example/windows/runner/resource.h create mode 100644 example/windows/runner/resources/app_icon.ico create mode 100644 example/windows/runner/runner.exe.manifest create mode 100644 example/windows/runner/utils.cpp create mode 100644 example/windows/runner/utils.h create mode 100644 example/windows/runner/win32_window.cpp create mode 100644 example/windows/runner/win32_window.h diff --git a/example/.metadata b/example/.metadata index b54ed7d9..c5984f8c 100644 --- a/example/.metadata +++ b/example/.metadata @@ -4,7 +4,27 @@ # This file should be version controlled and should not be manually edited. version: - revision: 37f9c541165c3516f727cd36bd502d411fdad3b8 - channel: dev + revision: "300451adae589accbece3490f4396f10bdf15e6e" + channel: "stable" project_type: app + +# Tracks metadata for the flutter migrate command +migration: + platforms: + - platform: root + create_revision: 300451adae589accbece3490f4396f10bdf15e6e + base_revision: 300451adae589accbece3490f4396f10bdf15e6e + - platform: ios + create_revision: 300451adae589accbece3490f4396f10bdf15e6e + base_revision: 300451adae589accbece3490f4396f10bdf15e6e + + # User provided section + + # List of Local paths (relative to this file) that should be + # ignored by the migrate tool. + # + # Files that are not part of the templates will be ignored by default. + unmanaged_files: + - 'lib/main.dart' + - 'ios/Runner.xcodeproj/project.pbxproj' diff --git a/example/README.md b/example/README.md index 8945d8e2..8c68e600 100644 --- a/example/README.md +++ b/example/README.md @@ -70,24 +70,27 @@ ### [example/lib/main.dart](https://github.com/aissat/easy_localization/blob/master/example/lib/main.dart) ```dart -import 'dart:developer'; - -import 'package:example/lang_view.dart'; -import 'package:example/my_flutter_app_icons.dart'; -import 'package:flutter/material.dart'; -import 'package:flutter_localizations/flutter_localizations.dart'; import 'package:easy_localization/easy_localization.dart'; +import 'package:flutter/material.dart'; -void main() async{ - - // WidgetsFlutterBinding.ensureInitialized(); +import 'generated/locale_keys.g.dart'; +import 'language_view.dart'; + +void main() async { + WidgetsFlutterBinding.ensureInitialized(); await EasyLocalization.ensureInitialized(); runApp(EasyLocalization( - child: MyApp(), - supportedLocales: [Locale('en', 'US'), Locale('ar', 'DZ')], + supportedLocales: [ + Locale('en', 'US'), + Locale('ar', 'DZ'), + Locale('de', 'DE'), + Locale('ru', 'RU') + ], path: 'resources/langs', + child: _MyApp(), // fallbackLocale: Locale('en', 'US'), + // startLocale: Locale('de', 'DE'), // saveLocale: false, // useOnlyLangCode: true, @@ -96,80 +99,62 @@ void main() async{ // assetLoader: RootBundleAssetLoader() // assetLoader: HttpAssetLoader() // assetLoader: FileAssetLoader() - assetLoader: CsvAssetLoader() + // assetLoader: CsvAssetLoader() // assetLoader: YamlAssetLoader() //multiple files // assetLoader: YamlSingleAssetLoader() //single file // assetLoader: XmlAssetLoader() //multiple files // assetLoader: XmlSingleAssetLoader() //single file - - // assetLoader: CodegenLoader() + // assetLoader: CodegenLoader() )); } -class MyApp extends StatelessWidget { +class _MyApp extends StatelessWidget { @override Widget build(BuildContext context) { - log( EasyLocalization.of(context).locale.toString(), name: this.toString()+"# locale" ); - log( Intl.defaultLocale.toString(), name: this.toString()+"# Intl.defaultLocale" ); return MaterialApp( - title: 'Flutter Demo', - localizationsDelegates: [ - GlobalMaterialLocalizations.delegate, - GlobalWidgetsLocalizations.delegate, - EasyLocalization.of(context).delegate, - ], - supportedLocales: EasyLocalization.of(context).supportedLocales, - locale: EasyLocalization.of(context).locale, - theme: ThemeData( - primarySwatch: Colors.blue, - ), - home: MyHomePage(title: 'Easy localization'), + localizationsDelegates: context.localizationDelegates, + supportedLocales: context.supportedLocales, + locale: context.locale, + theme: ThemeData(primarySwatch: Colors.blue), + home: _MyHomePage(), ); } } -class MyHomePage extends StatefulWidget { - MyHomePage({Key key, this.title}) : super(key: key); - - final String title; - +class _MyHomePage extends StatefulWidget { @override _MyHomePageState createState() => _MyHomePageState(); } -class _MyHomePageState extends State { +class _MyHomePageState extends State<_MyHomePage> { int counter = 0; + bool _gender = true; - incrementCounter() { - setState(() { - counter++; - }); - } + void _incrementCounter() => setState(() => counter++); - switchGender(bool val) { - setState(() { - _gender = val; - }); - } + void _switchGender(bool value) => setState(() => _gender = value); @override Widget build(BuildContext context) { - log(tr("title"), name: this.toString() ); return Scaffold( appBar: AppBar( - title: Text("title").tr(context: context), - //Text(AppLocalizations.of(context).tr('title')), + title: Text(LocaleKeys.title).tr(), actions: [ - FlatButton( - child: Icon(Icons.language), + TextButton( onPressed: () { Navigator.push( context, MaterialPageRoute( - builder: (_) => LanguageView(), fullscreenDialog: true), + builder: (_) => LanguageView(), + fullscreenDialog: true, + ), ); }, + child: Icon( + Icons.language, + color: Colors.white, + ), ), ], ), @@ -177,66 +162,69 @@ class _MyHomePageState extends State { child: Column( mainAxisAlignment: MainAxisAlignment.center, children: [ - Spacer( - flex: 1, - ), + Spacer(flex: 1), Text( - 'switch.with_arg', + LocaleKeys.gender_with_arg, style: TextStyle( - color: Colors.grey.shade600, - fontSize: 19, - fontWeight: FontWeight.bold), - ).tr(args: ["aissat"], gender: _gender ? "female" : "male"), + color: Colors.grey.shade600, + fontSize: 19, + fontWeight: FontWeight.bold, + ), + ).tr(args: ['aissat'], gender: _gender ? 'female' : 'male'), Text( - tr('switch', gender: _gender ? "female" : "male"), + tr(LocaleKeys.gender, gender: _gender ? 'female' : 'male'), style: TextStyle( - color: Colors.grey.shade600, - fontSize: 15, - fontWeight: FontWeight.bold), + color: Colors.grey.shade600, + fontSize: 15, + fontWeight: FontWeight.bold, + ), ), Row( mainAxisAlignment: MainAxisAlignment.center, children: [ - Icon(MyFlutterApp.male_1), - Switch(value: _gender, onChanged: switchGender), - Icon(MyFlutterApp.female_1), + Icon(Icons.male), + Switch(value: _gender, onChanged: _switchGender), + Icon(Icons.female), ], ), - Spacer( - flex: 1, - ), - Text('msg').tr(args: ['aissat', 'Flutter']), - Text('clicked').plural(counter), - FlatButton( - onPressed: () { - incrementCounter(); - }, - child: Text('clickMe').tr(), + Spacer(flex: 1), + Text(LocaleKeys.msg).tr(args: ['aissat', 'Flutter']), + Text(LocaleKeys.msg_named).tr( + namedArgs: {'lang': 'Dart'}, + args: ['Easy localization'], ), - SizedBox( - height: 15, + Text(LocaleKeys.clicked).plural(counter), + TextButton( + onPressed: () => _incrementCounter(), + child: Text(LocaleKeys.clickMe).tr(), ), + SizedBox(height: 15), Text( - plural('amount', counter, - format: NumberFormat.currency( - locale: Intl.defaultLocale, - symbol: "€")), - style: TextStyle( - color: Colors.grey.shade900, - fontSize: 18, - fontWeight: FontWeight.bold)), - SizedBox( - height: 20, + plural( + LocaleKeys.amount, + counter, + format: NumberFormat.currency( + locale: Intl.defaultLocale, + symbol: '€', + ), + ), + style: TextStyle( + color: Colors.grey.shade900, + fontSize: 18, + fontWeight: FontWeight.bold, + ), ), - Text('profile.reset_password.title').tr(), - Spacer( - flex: 2, + SizedBox(height: 20), + ElevatedButton( + onPressed: () => context.resetLocale(), + child: Text(LocaleKeys.reset_locale).tr(), ), + Spacer(flex: 1), ], ), ), floatingActionButton: FloatingActionButton( - onPressed: incrementCounter, + onPressed: _incrementCounter, child: Text('+1'), ), ); @@ -245,7 +233,7 @@ class _MyHomePageState extends State { ``` -### [example/lib/lang_view.dart](https://github.com/aissat/easy_localization/blob/master/example/lib/lang_view.dart) +### [example/lib/lang_view.dart](https://github.com/aissat/easy_localization/blob/master/example/lib/language_view.dart) ```dart import 'dart:developer'; @@ -258,12 +246,7 @@ class LanguageView extends StatelessWidget { Widget build(BuildContext context) { return Scaffold( appBar: AppBar( - title: Text( - "", - style: TextStyle(color: Colors.black), - ), backgroundColor: Colors.white, - iconTheme: IconThemeData(color: Colors.black), elevation: 0, ), body: Container( @@ -277,73 +260,90 @@ class LanguageView extends StatelessWidget { horizontal: 24, ), child: Text( - "Language Menu", + 'Choose language', style: TextStyle( - color: Color.fromARGB(255, 166, 166, 166), - fontFamily: "Montserrat", + color: Colors.blue, + fontFamily: 'Montserrat', fontWeight: FontWeight.w700, - fontSize: 10, + fontSize: 18, ), ), ), - Container( - padding: EdgeInsets.only(top: 10, bottom: 25), - margin: EdgeInsets.symmetric( - horizontal: 24, - ), - child: Text( - "language", - ), + _SwitchListTileMenuItem( + title: 'عربي', + subtitle: 'عربي', + locale: context.supportedLocales[1], + ), + _Divider(), + _SwitchListTileMenuItem( + title: 'English', + subtitle: 'English', + locale: context.supportedLocales[0], ), - buildDivider(), - buildSwitchListTileMenuItem( - context: context, - title: "عربي", - subtitle: "عربي", - locale: Locale("ar", "DZ")), - buildDivider(), - buildSwitchListTileMenuItem( - context: context, - title: "English", - subtitle: "English", - locale: Locale("en", "US")), - buildDivider(), + _Divider(), + _SwitchListTileMenuItem( + title: 'German', + subtitle: 'German', + locale: context.supportedLocales[2], + ), + _Divider(), + _SwitchListTileMenuItem( + title: 'Русский', + subtitle: 'Русский', + locale: context.supportedLocales[3], + ), + _Divider(), ], ), ), ); } +} - Container buildDivider() => Container( - margin: EdgeInsets.symmetric( - horizontal: 24, - ), - child: Divider( - color: Colors.grey, - ), - ); +class _Divider extends StatelessWidget { + @override + Widget build(BuildContext context) { + return Container( + margin: EdgeInsets.symmetric(horizontal: 24), + child: Divider(color: Colors.grey), + ); + } +} + +class _SwitchListTileMenuItem extends StatelessWidget { + final String title; + + final String subtitle; - Container buildSwitchListTileMenuItem( - {BuildContext context, String title, String subtitle, Locale locale}) { + final Locale locale; + + const _SwitchListTileMenuItem({ + required this.title, + required this.subtitle, + required this.locale, + }); + + @override + Widget build(BuildContext context) { return Container( - margin: EdgeInsets.only( - left: 10, - right: 10, - top: 5, + margin: EdgeInsets.only(left: 10, right: 10, top: 5), + decoration: BoxDecoration( + border: locale == context.locale + ? Border.all(color: Colors.blueAccent) + : null, ), child: ListTile( - dense: true, - // isThreeLine: true, - title: Text( - title, - ), - subtitle: Text( - subtitle, - ), - onTap: () { - log(locale.toString(), name: this.toString()); - EasyLocalization.of(context).locale = locale; - }), + dense: true, + title: Text(title), + subtitle: Text(subtitle), + onTap: () async { + log(locale.toString(), name: toString()); + + await context.setLocale(locale); + + Navigator.pop(context); + }, + ), ); } } diff --git a/example/analysis_options.yaml b/example/analysis_options.yaml new file mode 100644 index 00000000..57346b58 --- /dev/null +++ b/example/analysis_options.yaml @@ -0,0 +1,3 @@ +include: package:flutter_lints/flutter.yaml +linter: + rules: diff --git a/example/android/.gitignore b/example/android/.gitignore index bc2100d8..6f568019 100644 --- a/example/android/.gitignore +++ b/example/android/.gitignore @@ -5,3 +5,9 @@ gradle-wrapper.jar /gradlew.bat /local.properties GeneratedPluginRegistrant.java + +# Remember to never publicly share your keystore. +# See https://flutter.dev/docs/deployment/android#reference-the-keystore-from-the-app +key.properties +**/*.keystore +**/*.jks diff --git a/example/android/app/build.gradle b/example/android/app/build.gradle index 8b817b74..c5ddca44 100644 --- a/example/android/app/build.gradle +++ b/example/android/app/build.gradle @@ -1,3 +1,9 @@ +plugins { + id "com.android.application" + id "kotlin-android" + id "dev.flutter.flutter-gradle-plugin" +} + def localProperties = new Properties() def localPropertiesFile = rootProject.file('local.properties') if (localPropertiesFile.exists()) { @@ -6,11 +12,6 @@ if (localPropertiesFile.exists()) { } } -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' @@ -21,29 +22,33 @@ if (flutterVersionName == null) { flutterVersionName = '1.0' } -apply plugin: 'com.android.application' -apply plugin: 'kotlin-android' -apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle" - android { - compileSdkVersion 28 + namespace "io.aissat.example.example" + compileSdk flutter.compileSdkVersion + ndkVersion flutter.ndkVersion - sourceSets { - main.java.srcDirs += 'src/main/kotlin' + compileOptions { + sourceCompatibility JavaVersion.VERSION_1_8 + targetCompatibility JavaVersion.VERSION_1_8 + } + + kotlinOptions { + jvmTarget = '1.8' } - lintOptions { - disable 'InvalidPackage' + sourceSets { + main.java.srcDirs += 'src/main/kotlin' } defaultConfig { // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). applicationId "io.aissat.example.example" - minSdkVersion 16 - targetSdkVersion 28 + // 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. + minSdkVersion flutter.minSdkVersion + targetSdkVersion flutter.targetSdkVersion versionCode flutterVersionCode.toInteger() versionName flutterVersionName - testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" } buildTypes { @@ -59,9 +64,4 @@ flutter { source '../..' } -dependencies { - implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version" - testImplementation 'junit:junit:4.12' - androidTestImplementation 'androidx.test:runner:1.1.1' - androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1' -} +dependencies {} diff --git a/example/android/app/src/debug/AndroidManifest.xml b/example/android/app/src/debug/AndroidManifest.xml index b3af0227..399f6981 100644 --- a/example/android/app/src/debug/AndroidManifest.xml +++ b/example/android/app/src/debug/AndroidManifest.xml @@ -1,6 +1,6 @@ - - diff --git a/example/android/app/src/main/AndroidManifest.xml b/example/android/app/src/main/AndroidManifest.xml index f8891d42..aff7dec7 100644 --- a/example/android/app/src/main/AndroidManifest.xml +++ b/example/android/app/src/main/AndroidManifest.xml @@ -1,10 +1,11 @@ - - + - - @@ -38,4 +30,15 @@ android:name="flutterEmbedding" android:value="2" /> + + + + + + + diff --git a/example/android/app/src/main/res/values-night/styles.xml b/example/android/app/src/main/res/values-night/styles.xml index 449a9f93..06952be7 100644 --- a/example/android/app/src/main/res/values-night/styles.xml +++ b/example/android/app/src/main/res/values-night/styles.xml @@ -3,14 +3,14 @@