Showing
91 changed files
with
40 additions
and
2429 deletions
@@ -24,7 +24,7 @@ | @@ -24,7 +24,7 @@ | ||
24 | ```dart | 24 | ```dart |
25 | void main() => runApp(GetMaterialApp(home: Home())); | 25 | void main() => runApp(GetMaterialApp(home: Home())); |
26 | // Create your business logic class and place all variables, methods and controllers inside it. | 26 | // Create your business logic class and place all variables, methods and controllers inside it. |
27 | -class Controller { | 27 | +class Controller extends RxController{ |
28 | // ".obs" turns any object into an observable one. | 28 | // ".obs" turns any object into an observable one. |
29 | var count = 0.obs; | 29 | var count = 0.obs; |
30 | increment() => count.value++; | 30 | increment() => count.value++; |
@@ -55,23 +55,29 @@ class Other extends StatelessWidget { | @@ -55,23 +55,29 @@ class Other extends StatelessWidget { | ||
55 | 55 | ||
56 | This is a simple project but it already makes clear how powerful Get is. As your project grows, this difference will become more significant. Get was designed to work with teams, but it makes the job of an individual developer simple. Improve your deadlines, deliver everything on time without losing performance. Get is not for everyone, but if you identified with that phrase, Get is for you! | 56 | This is a simple project but it already makes clear how powerful Get is. As your project grows, this difference will become more significant. Get was designed to work with teams, but it makes the job of an individual developer simple. Improve your deadlines, deliver everything on time without losing performance. Get is not for everyone, but if you identified with that phrase, Get is for you! |
57 | 57 | ||
58 | -- **[Navigating without named routes](#navigating-without-named-routes)** | ||
59 | -- **[SnackBars](#snackBars)** | ||
60 | -- **[Dialogs](#dialogs)** | ||
61 | -- **[BottomSheets](#bottomsheets)** | ||
62 | -- **[Simple State Manager](#simple-state-manager)** | ||
63 | -- **[Reactive State Manager](#reactive-state-manager)** | ||
64 | -- **[Bindings](#bindings)** | ||
65 | -- **[Workers](#workers)** | ||
66 | -- **[Navigate with named routes](#navigate-with-named-routes)** | ||
67 | -- **[Send data to named Routes](#send-data-to-named-Routes)** | ||
68 | -- **[Dynamic urls links](#dynamic-urls-links)** | ||
69 | -- **[Middleware](#middleware)** | ||
70 | -- **[Optional Global Settings](#optional-global-settings)** | ||
71 | -- **[Nested Navigators](#nested-navigators)** | ||
72 | -- **[Other Advanced APIs and Manual configurations](#other-advanced-apis-and-manual-configurations)** | ||
73 | - | ||
74 | - | 58 | +- [How to use?](#how-to-use) |
59 | +- [Navigating without named routes](#navigating-without-named-routes) | ||
60 | + - [SnackBars](#snackbars) | ||
61 | + - [Dialogs](#dialogs) | ||
62 | + - [BottomSheets](#bottomsheets) | ||
63 | +- [Simple State Manager](#simple-state-manager) | ||
64 | + - [Simple state manager usage](#simple-state-manager-usage) | ||
65 | + - [No StatefulWidget:](#no-statefulwidget) | ||
66 | + - [Forms of use:](#forms-of-use) | ||
67 | +- [Reactive State Manager](#reactive-state-manager) | ||
68 | + - [GetX vs GetBuilder vs Obx vs MixinBuilder](#getx-vs-getbuilder-vs-obx-vs-mixinbuilder) | ||
69 | +- [Simple Instance Manager](#simple-instance-manager) | ||
70 | +- [Bindings](#bindings) | ||
71 | + - [To use this API you only need:](#to-use-this-api-you-only-need) | ||
72 | +- [Workers:](#workers) | ||
73 | +- [Navigate with named routes:](#navigate-with-named-routes) | ||
74 | + - [Send data to named Routes:](#send-data-to-named-routes) | ||
75 | + - [Dynamic urls links](#dynamic-urls-links) | ||
76 | + - [Middleware](#middleware) | ||
77 | + - [Change Theme](#change-theme) | ||
78 | + - [Optional Global Settings](#optional-global-settings) | ||
79 | + - [Nested Navigators](#nested-navigators) | ||
80 | + - [Other Advanced APIs and Manual configurations](#other-advanced-apis-and-manual-configurations) | ||
75 | 81 | ||
76 | #### Want to contribute to the project? We will be proud to highlight you as one of our collaborators. Here are some points where you can contribute and make Get (and Flutter) even better. | 82 | #### Want to contribute to the project? We will be proud to highlight you as one of our collaborators. Here are some points where you can contribute and make Get (and Flutter) even better. |
77 | 83 | ||
@@ -414,21 +420,21 @@ GetBuilder<Controller>( | @@ -414,21 +420,21 @@ GetBuilder<Controller>( | ||
414 | ), | 420 | ), |
415 | ``` | 421 | ``` |
416 | 422 | ||
417 | -A much better approach than this is to use the onStart() and onClose() method directly from your controller. | 423 | +A much better approach than this is to use the onInit() and onClose() method directly from your controller. |
418 | 424 | ||
419 | ```dart | 425 | ```dart |
420 | @override | 426 | @override |
421 | -void onStart() { | 427 | +void onInit() { |
422 | fetchApi(); | 428 | fetchApi(); |
423 | - super.onStart(); | 429 | + super.onInit(); |
424 | } | 430 | } |
425 | ``` | 431 | ``` |
426 | 432 | ||
427 | -- NOTE: If you want to start a method at the moment the controller is called for the first time, you DON'T NEED to use constructors for this, in fact, using a performance-oriented package like Get, this borders on bad practice, because it deviates from the logic in which the controllers are created or allocated (if you create an instance of this controller, the constructor will be called immediately, you will be populating a controller before it is even used, you are allocating memory without it being in use, this definitely hurts the principles of this library). The onStart() methods; and onClose(); were created for this, they will be called when the Controller is created, or used for the first time, depending on whether you are using Get.lazyPut or not. If you want, for example, to make a call to your API to populate data, you can forget about the old-fashioned method of initState/dispose, just start your call to the api in onInit, and if you need to execute any command like closing streams, use the onClose() for that. | 433 | +- NOTE: If you want to start a method at the moment the controller is called for the first time, you DON'T NEED to use constructors for this, in fact, using a performance-oriented package like Get, this borders on bad practice, because it deviates from the logic in which the controllers are created or allocated (if you create an instance of this controller, the constructor will be called immediately, you will be populating a controller before it is even used, you are allocating memory without it being in use, this definitely hurts the principles of this library). The onInit() methods; and onClose(); were created for this, they will be called when the Controller is created, or used for the first time, depending on whether you are using Get.lazyPut or not. If you want, for example, to make a call to your API to populate data, you can forget about the old-fashioned method of initState/dispose, just start your call to the api in onInit, and if you need to execute any command like closing streams, use the onClose() for that. |
428 | The purpose of this package is precisely to give you a complete solution for navigation of routes, management of dependencies and states, using the least possible dependencies, with a high degree of decoupling. Get engages all high and low level Flutter APIs within itself, to ensure that you work with the least possible coupling. We centralize everything in a single package, to ensure that you don't have any kind of coupling in your project. That way, you can put only widgets in your view, and leave the part of your team that works with the business logic free, to work with the business logic without depending on any element of the View. This provides a much cleaner working environment, so that part of your team works only with widgets, without worrying about sending data to your controller, and part of your team works only with the business logic in its breadth, without depending on no element of the view. | 434 | The purpose of this package is precisely to give you a complete solution for navigation of routes, management of dependencies and states, using the least possible dependencies, with a high degree of decoupling. Get engages all high and low level Flutter APIs within itself, to ensure that you work with the least possible coupling. We centralize everything in a single package, to ensure that you don't have any kind of coupling in your project. That way, you can put only widgets in your view, and leave the part of your team that works with the business logic free, to work with the business logic without depending on any element of the View. This provides a much cleaner working environment, so that part of your team works only with widgets, without worrying about sending data to your controller, and part of your team works only with the business logic in its breadth, without depending on no element of the view. |
429 | 435 | ||
430 | So to simplify this: | 436 | So to simplify this: |
431 | -You don't need to call methods in initState and send them by parameter to your controller, nor use your controller constructor for that, you have the onStart() method that is called at the right time for you to start your services. | 437 | +You don't need to call methods in initState and send them by parameter to your controller, nor use your controller constructor for that, you have the onInit() method that is called at the right time for you to start your services. |
432 | You do not need to call the device, you have the onClose() method that will be called at the exact moment when your controller is no longer needed and will be removed from memory. That way, leave views for widgets only, refrain from any kind of business logic from it. | 438 | You do not need to call the device, you have the onClose() method that will be called at the exact moment when your controller is no longer needed and will be removed from memory. That way, leave views for widgets only, refrain from any kind of business logic from it. |
433 | 439 | ||
434 | Do not call a dispose method inside GetController, it will not do anything, remember that the controller is not a Widget, you should not "dispose" it, and it will be automatically and intelligently removed from memory by Get. If you used any stream on it and want to close it, just insert it into the close method. Example: | 440 | Do not call a dispose method inside GetController, it will not do anything, remember that the controller is not a Widget, you should not "dispose" it, and it will be automatically and intelligently removed from memory by Get. If you used any stream on it and want to close it, just insert it into the close method. Example: |
@@ -448,7 +454,7 @@ class Controller extends GetController { | @@ -448,7 +454,7 @@ class Controller extends GetController { | ||
448 | } | 454 | } |
449 | ``` | 455 | ``` |
450 | Controller life cycle: | 456 | Controller life cycle: |
451 | -- onStart() where it is created. | 457 | +- onInit() where it is created. |
452 | - onClose() where it is closed to make any changes in preparation for the delete method | 458 | - onClose() where it is closed to make any changes in preparation for the delete method |
453 | - deleted: you do not have access to this API because it is literally removing the controller from memory. It is literally deleted, without leaving any trace. | 459 | - deleted: you do not have access to this API because it is literally removing the controller from memory. It is literally deleted, without leaving any trace. |
454 | 460 | ||
@@ -681,7 +687,7 @@ Finally, some people opened a resource request, as they wanted to use only one t | @@ -681,7 +687,7 @@ Finally, some people opened a resource request, as they wanted to use only one t | ||
681 | 687 | ||
682 | - Note: To use GetBuilder and MixinBuilder you must use GetController. To use GetX and Obx you must use RxController. | 688 | - Note: To use GetBuilder and MixinBuilder you must use GetController. To use GetX and Obx you must use RxController. |
683 | Probably using a GetController using GetX and Obx will work, but it will not be possible to use an RxController on a GetBuilder. | 689 | Probably using a GetController using GetX and Obx will work, but it will not be possible to use an RxController on a GetBuilder. |
684 | -Extending these controllers is important, as they have life cycles, and can "start" and "end" events in their onStart() and onClose() methods. | 690 | +Extending these controllers is important, as they have life cycles, and can "start" and "end" events in their onInit() and onClose() methods. |
685 | 691 | ||
686 | ## Simple Instance Manager | 692 | ## Simple Instance Manager |
687 | - Note: If you are using Get's State Manager, you don't have to worry about that, just read for information, but pay more attention to the bindings api, which will do all of this automatically for you. | 693 | - Note: If you are using Get's State Manager, you don't have to worry about that, just read for information, but pay more attention to the bindings api, which will do all of this automatically for you. |
@@ -785,15 +791,19 @@ The Binding class is called when a route is called, you can create an "initialBi | @@ -785,15 +791,19 @@ The Binding class is called when a route is called, you can create an "initialBi | ||
785 | ```dart | 791 | ```dart |
786 | GetMaterialApp( | 792 | GetMaterialApp( |
787 | initialBinding: SampleBind(), | 793 | initialBinding: SampleBind(), |
788 | - home: Home(); | 794 | + home: Home(), |
789 | ); | 795 | ); |
790 | ``` | 796 | ``` |
791 | 797 | ||
792 | -If you want to use your initializations in one place, you can use SmartManagement.keepfactory to allow this, and although using keepfactory should be the exception, as it is the softest SmartManagement out there. | ||
793 | - | ||
794 | -I always prefer the standard SmartManagement (full). It can be annoying at times, and eliminate something you don't want, as it has refined controls that remove memory dependency even if there is a flaw, and a widget is not arranged properly. It is safe enough with StatelessWidget, since even if there is no page available, it will still remove the controller from memory. But there are some use cases, which this restriction can be bothersome. For these situations you can use SmartManagement.onlyBuilders, which will depend on the effective removal of widgets that use the controller from the tree to remove the controller. | 798 | +Always prefer to use standard SmartManagement (full), you do not need to configure anything for that, Get already gives it to you by default. It will surely eliminate all your disused controllers from memory, as its refined control removes the dependency, even if a failure occurs and a widget that uses it is not properly disposed. |
799 | +The "full" mode is also safe enough to be used with StatelessWidget, as it has numerous security callbacks that will prevent a controller from remaining in memory if it is not being used by any widget, and disposition is not important here. However, if you are bothered by the default behavior, or just don't want it to happen, Get offers other, more lenient options for intelligent memory management, such as SmartManagement.onlyBuilders, which will depend on the effective removal of widgets using the controller. tree to remove it, and you can prevent a controller from being deployed using "autoRemove: false" in your GetBuilder/GetX. | ||
800 | +With this option, only controllers started in "init:" or loaded into a Binding with "Get.lazyPut" will be disposed, if you use Get.put or any other approach, SmartManagement will not have permissions to exclude this dependency. | ||
801 | +With the default behavior, even widgets instantiated with "Get.put" will be removed, unlike SmartManagement.onlyBuilders. | ||
802 | +SmartManagement.keepFactory is like SmartManagement.full, with one difference. SmartManagement.full purges the factories from the premises, so that Get.lazyPut() will only be able to be called once and your factory and references will be self-destructing. SmartManagement.keepFactory will remove its dependencies when necessary, however, it will keep the "shape" of these, to make an equal one if you need an instance of that again. | ||
803 | +Instead of using SmartManagement.keepFactory you can use Bindings. | ||
804 | +Bindings creates transitory factories, which are created the moment you click to go to another screen, and will be destroyed as soon as the screen-changing animation happens. It is so little time that the analyzer will not even be able to register it. When you navigate to this screen again, a new temporary factory will be called, so this is preferable to using SmartManagement.keepFactory, but if you don't want to create Bindings, or want to keep all your dependencies on the same Binding, it will certainly help you . Factories take up little memory, they don't hold instances, but a function with the "shape" of that class you want. This is very little, but since the purpose of this lib is to get the maximum performance possible using the minimum resources, Get removes even the factories by default. Use whichever is most convenient for you. | ||
795 | 805 | ||
796 | -- NOTE: DO NOT USE SmartManagement.keepFactory if you are using multiple Bindings. It was designed to be used without Bindings, or with a single Binding linked in the GetBaterialApp's initialBinding. | 806 | +- NOTE: DO NOT USE SmartManagement.keepFactory if you are using multiple Bindings. It was designed to be used without Bindings, or with a single Binding linked in the GetMaterialApp's initialBinding. |
797 | 807 | ||
798 | - NOTE2: Using Bindings is completely optional, you can use Get.put() and Get.find() on classes that use a given controller without any problem. | 808 | - NOTE2: Using Bindings is completely optional, you can use Get.put() and Get.find() on classes that use a given controller without any problem. |
799 | However, if you work with Services or any other abstraction, I recommend using Bindings for a larger organization. | 809 | However, if you work with Services or any other abstraction, I recommend using Bindings for a larger organization. |
android/app/build.gradle
deleted
100644 → 0
1 | -def localProperties = new Properties() | ||
2 | -def localPropertiesFile = rootProject.file('local.properties') | ||
3 | -if (localPropertiesFile.exists()) { | ||
4 | - localPropertiesFile.withReader('UTF-8') { reader -> | ||
5 | - localProperties.load(reader) | ||
6 | - } | ||
7 | -} | ||
8 | - | ||
9 | -def flutterRoot = localProperties.getProperty('flutter.sdk') | ||
10 | -if (flutterRoot == null) { | ||
11 | - throw new GradleException("Flutter SDK not found. Define location with flutter.sdk in the local.properties file.") | ||
12 | -} | ||
13 | - | ||
14 | -apply plugin: 'com.android.application' | ||
15 | -apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle" | ||
16 | - | ||
17 | -android { | ||
18 | - compileSdkVersion 29 | ||
19 | - | ||
20 | - lintOptions { | ||
21 | - disable 'InvalidPackage' | ||
22 | - } | ||
23 | - | ||
24 | - defaultConfig { | ||
25 | - // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). | ||
26 | - applicationId "de.udos.flutterstatemanagement" | ||
27 | - minSdkVersion 16 | ||
28 | - targetSdkVersion 29 | ||
29 | - versionCode 1 | ||
30 | - versionName "1.0" | ||
31 | - testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" | ||
32 | - } | ||
33 | - | ||
34 | - buildTypes { | ||
35 | - release { | ||
36 | - // TODO: Add your own signing config for the release build. | ||
37 | - // Signing with the debug keys for now, so `flutter run --release` works. | ||
38 | - signingConfig signingConfigs.debug | ||
39 | - } | ||
40 | - } | ||
41 | -} | ||
42 | - | ||
43 | -flutter { | ||
44 | - source '../..' | ||
45 | -} | ||
46 | - | ||
47 | -dependencies { | ||
48 | - testImplementation 'junit:junit:4.12' | ||
49 | - androidTestImplementation 'androidx.test.ext:junit:1.1.1' | ||
50 | - androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0' | ||
51 | -} |
1 | -<manifest xmlns:android="http://schemas.android.com/apk/res/android" | ||
2 | - package="de.udos.benchmarks"> | ||
3 | - <!-- Flutter needs it to communicate with the running application | ||
4 | - to allow setting breakpoints, to provide hot reload, etc. | ||
5 | - --> | ||
6 | - <uses-permission android:name="android.permission.INTERNET"/> | ||
7 | -</manifest> |
1 | -<manifest xmlns:android="http://schemas.android.com/apk/res/android" | ||
2 | - package="de.udos.benchmarks"> | ||
3 | - | ||
4 | - <!-- The INTERNET permission is required for development. Specifically, | ||
5 | - flutter needs it to communicate with the running application | ||
6 | - to allow setting breakpoints, to provide hot reload, etc. | ||
7 | - --> | ||
8 | - <uses-permission android:name="android.permission.INTERNET"/> | ||
9 | - | ||
10 | - <!-- io.flutter.app.FlutterApplication is an android.app.Application that | ||
11 | - calls FlutterMain.startInitialization(this); in its onCreate method. | ||
12 | - In most cases you can leave this as-is, but you if you want to provide | ||
13 | - additional functionality it is fine to subclass or reimplement | ||
14 | - FlutterApplication and put your custom class here. --> | ||
15 | - <application | ||
16 | - android:name="io.flutter.app.FlutterApplication" | ||
17 | - android:label="benckmark" | ||
18 | - android:icon="@mipmap/ic_launcher"> | ||
19 | - <activity | ||
20 | - android:name=".MainActivity" | ||
21 | - android:launchMode="singleTop" | ||
22 | - android:theme="@style/LaunchTheme" | ||
23 | - android:configChanges="orientation|keyboardHidden|keyboard|screenSize|locale|layoutDirection|fontScale|screenLayout|density" | ||
24 | - android:hardwareAccelerated="true" | ||
25 | - android:windowSoftInputMode="adjustResize"> | ||
26 | - <!-- This keeps the window background of the activity showing | ||
27 | - until Flutter renders its first frame. It can be removed if | ||
28 | - there is no splash screen (such as the default splash screen | ||
29 | - defined in @style/LaunchTheme). --> | ||
30 | - <meta-data | ||
31 | - android:name="io.flutter.app.android.SplashScreenUntilFirstFrame" | ||
32 | - android:value="true" /> | ||
33 | - <intent-filter> | ||
34 | - <action android:name="android.intent.action.MAIN"/> | ||
35 | - <category android:name="android.intent.category.LAUNCHER"/> | ||
36 | - </intent-filter> | ||
37 | - </activity> | ||
38 | - </application> | ||
39 | -</manifest> |
1 | -package de.udos.benchmarks; | ||
2 | - | ||
3 | -import android.os.Bundle; | ||
4 | -import io.flutter.app.FlutterActivity; | ||
5 | -import io.flutter.plugins.GeneratedPluginRegistrant; | ||
6 | - | ||
7 | -public class MainActivity extends FlutterActivity { | ||
8 | - @Override | ||
9 | - protected void onCreate(Bundle savedInstanceState) { | ||
10 | - super.onCreate(savedInstanceState); | ||
11 | - GeneratedPluginRegistrant.registerWith(this); | ||
12 | - } | ||
13 | -} |
1 | -package io.flutter.plugins; | ||
2 | - | ||
3 | -import io.flutter.plugin.common.PluginRegistry; | ||
4 | - | ||
5 | -/** | ||
6 | - * Generated file. Do not edit. | ||
7 | - */ | ||
8 | -public final class GeneratedPluginRegistrant { | ||
9 | - public static void registerWith(PluginRegistry registry) { | ||
10 | - if (alreadyRegisteredWith(registry)) { | ||
11 | - return; | ||
12 | - } | ||
13 | - } | ||
14 | - | ||
15 | - private static boolean alreadyRegisteredWith(PluginRegistry registry) { | ||
16 | - final String key = GeneratedPluginRegistrant.class.getCanonicalName(); | ||
17 | - if (registry.hasPlugin(key)) { | ||
18 | - return true; | ||
19 | - } | ||
20 | - registry.registrarFor(key); | ||
21 | - return false; | ||
22 | - } | ||
23 | -} |
1 | -<?xml version="1.0" encoding="utf-8"?> | ||
2 | -<!-- Modify this file to customize your launch splash screen --> | ||
3 | -<layer-list xmlns:android="http://schemas.android.com/apk/res/android"> | ||
4 | - <item android:drawable="@android:color/white" /> | ||
5 | - | ||
6 | - <!-- You can insert your own image assets here --> | ||
7 | - <!-- <item> | ||
8 | - <bitmap | ||
9 | - android:gravity="center" | ||
10 | - android:src="@mipmap/launch_image" /> | ||
11 | - </item> --> | ||
12 | -</layer-list> |

544 Bytes

442 Bytes

721 Bytes

1.01 KB

1.41 KB
1 | -<?xml version="1.0" encoding="utf-8"?> | ||
2 | -<resources> | ||
3 | - <style name="LaunchTheme" parent="@android:style/Theme.Black.NoTitleBar"> | ||
4 | - <!-- Show a splash screen on the activity. Automatically removed when | ||
5 | - Flutter draws its first frame --> | ||
6 | - <item name="android:windowBackground">@drawable/launch_background</item> | ||
7 | - </style> | ||
8 | -</resources> |
1 | -<manifest xmlns:android="http://schemas.android.com/apk/res/android" | ||
2 | - package="de.udos.benchmarks"> | ||
3 | - <!-- Flutter needs it to communicate with the running application | ||
4 | - to allow setting breakpoints, to provide hot reload, etc. | ||
5 | - --> | ||
6 | - <uses-permission android:name="android.permission.INTERNET"/> | ||
7 | -</manifest> |
android/benchmarks_android.iml
deleted
100644 → 0
1 | -<?xml version="1.0" encoding="UTF-8"?> | ||
2 | -<module type="JAVA_MODULE" version="4"> | ||
3 | - <component name="FacetManager"> | ||
4 | - <facet type="android" name="Android"> | ||
5 | - <configuration> | ||
6 | - <option name="ALLOW_USER_CONFIGURATION" value="false" /> | ||
7 | - <option name="MANIFEST_FILE_RELATIVE_PATH" value="/app/src/main/AndroidManifest.xml" /> | ||
8 | - <option name="RES_FOLDER_RELATIVE_PATH" value="/app/src/main/res" /> | ||
9 | - <option name="ASSETS_FOLDER_RELATIVE_PATH" value="/app/src/main/assets" /> | ||
10 | - <option name="LIBS_FOLDER_RELATIVE_PATH" value="/app/src/main/libs" /> | ||
11 | - <option name="PROGUARD_LOGS_FOLDER_RELATIVE_PATH" value="/app/src/main/proguard_logs" /> | ||
12 | - </configuration> | ||
13 | - </facet> | ||
14 | - </component> | ||
15 | - <component name="NewModuleRootManager" inherit-compiler-output="true"> | ||
16 | - <exclude-output /> | ||
17 | - <content url="file://$MODULE_DIR$"> | ||
18 | - <sourceFolder url="file://$MODULE_DIR$/app/src/main/java" isTestSource="false" /> | ||
19 | - <sourceFolder url="file://$MODULE_DIR$/app/src/main/kotlin" isTestSource="false" /> | ||
20 | - <sourceFolder url="file://$MODULE_DIR$/gen" isTestSource="false" generated="true" /> | ||
21 | - </content> | ||
22 | - <orderEntry type="jdk" jdkName="Android API 25 Platform" jdkType="Android SDK" /> | ||
23 | - <orderEntry type="sourceFolder" forTests="false" /> | ||
24 | - <orderEntry type="library" name="Flutter for Android" level="project" /> | ||
25 | - <orderEntry type="library" name="KotlinJavaRuntime" level="project" /> | ||
26 | - </component> | ||
27 | -</module> |
android/benchs_android.iml
deleted
100644 → 0
1 | -<?xml version="1.0" encoding="UTF-8"?> | ||
2 | -<module type="JAVA_MODULE" version="4"> | ||
3 | - <component name="FacetManager"> | ||
4 | - <facet type="android" name="Android"> | ||
5 | - <configuration> | ||
6 | - <option name="ALLOW_USER_CONFIGURATION" value="false" /> | ||
7 | - <option name="GEN_FOLDER_RELATIVE_PATH_APT" value="/gen" /> | ||
8 | - <option name="GEN_FOLDER_RELATIVE_PATH_AIDL" value="/gen" /> | ||
9 | - <option name="MANIFEST_FILE_RELATIVE_PATH" value="/app/src/main/AndroidManifest.xml" /> | ||
10 | - <option name="RES_FOLDER_RELATIVE_PATH" value="/app/src/main/res" /> | ||
11 | - <option name="ASSETS_FOLDER_RELATIVE_PATH" value="/app/src/main/assets" /> | ||
12 | - <option name="LIBS_FOLDER_RELATIVE_PATH" value="/app/src/main/libs" /> | ||
13 | - <option name="PROGUARD_LOGS_FOLDER_RELATIVE_PATH" value="/app/src/main/proguard_logs" /> | ||
14 | - </configuration> | ||
15 | - </facet> | ||
16 | - </component> | ||
17 | - <component name="NewModuleRootManager" inherit-compiler-output="true"> | ||
18 | - <exclude-output /> | ||
19 | - <content url="file://$MODULE_DIR$"> | ||
20 | - <sourceFolder url="file://$MODULE_DIR$/app/src/main/java" isTestSource="false" /> | ||
21 | - <sourceFolder url="file://$MODULE_DIR$/app/src/main/kotlin" isTestSource="false" /> | ||
22 | - <sourceFolder url="file://$MODULE_DIR$/gen" isTestSource="false" generated="true" /> | ||
23 | - </content> | ||
24 | - <orderEntry type="jdk" jdkName="Android API 25 Platform" jdkType="Android SDK" /> | ||
25 | - <orderEntry type="sourceFolder" forTests="false" /> | ||
26 | - <orderEntry type="library" name="Flutter for Android" level="project" /> | ||
27 | - <orderEntry type="library" name="KotlinJavaRuntime" level="project" /> | ||
28 | - </component> | ||
29 | -</module> |
android/build.gradle
deleted
100644 → 0
1 | -buildscript { | ||
2 | - repositories { | ||
3 | - google() | ||
4 | - jcenter() | ||
5 | - } | ||
6 | - | ||
7 | - dependencies { | ||
8 | - classpath 'com.android.tools.build:gradle:3.5.3' | ||
9 | - } | ||
10 | -} | ||
11 | - | ||
12 | -allprojects { | ||
13 | - repositories { | ||
14 | - google() | ||
15 | - jcenter() | ||
16 | - } | ||
17 | -} | ||
18 | - | ||
19 | -rootProject.buildDir = '../build' | ||
20 | -subprojects { | ||
21 | - project.buildDir = "${rootProject.buildDir}/${project.name}" | ||
22 | -} | ||
23 | -subprojects { | ||
24 | - project.evaluationDependsOn(':app') | ||
25 | -} | ||
26 | - | ||
27 | -task clean(type: Delete) { | ||
28 | - delete rootProject.buildDir | ||
29 | -} |
android/gradle.properties
deleted
100644 → 0
No preview for this file type
android/gradlew
deleted
100644 → 0
1 | -#!/usr/bin/env bash | ||
2 | - | ||
3 | -############################################################################## | ||
4 | -## | ||
5 | -## Gradle start up script for UN*X | ||
6 | -## | ||
7 | -############################################################################## | ||
8 | - | ||
9 | -# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
10 | -DEFAULT_JVM_OPTS="" | ||
11 | - | ||
12 | -APP_NAME="Gradle" | ||
13 | -APP_BASE_NAME=`basename "$0"` | ||
14 | - | ||
15 | -# Use the maximum available, or set MAX_FD != -1 to use that value. | ||
16 | -MAX_FD="maximum" | ||
17 | - | ||
18 | -warn ( ) { | ||
19 | - echo "$*" | ||
20 | -} | ||
21 | - | ||
22 | -die ( ) { | ||
23 | - echo | ||
24 | - echo "$*" | ||
25 | - echo | ||
26 | - exit 1 | ||
27 | -} | ||
28 | - | ||
29 | -# OS specific support (must be 'true' or 'false'). | ||
30 | -cygwin=false | ||
31 | -msys=false | ||
32 | -darwin=false | ||
33 | -case "`uname`" in | ||
34 | - CYGWIN* ) | ||
35 | - cygwin=true | ||
36 | - ;; | ||
37 | - Darwin* ) | ||
38 | - darwin=true | ||
39 | - ;; | ||
40 | - MINGW* ) | ||
41 | - msys=true | ||
42 | - ;; | ||
43 | -esac | ||
44 | - | ||
45 | -# Attempt to set APP_HOME | ||
46 | -# Resolve links: $0 may be a link | ||
47 | -PRG="$0" | ||
48 | -# Need this for relative symlinks. | ||
49 | -while [ -h "$PRG" ] ; do | ||
50 | - ls=`ls -ld "$PRG"` | ||
51 | - link=`expr "$ls" : '.*-> \(.*\)$'` | ||
52 | - if expr "$link" : '/.*' > /dev/null; then | ||
53 | - PRG="$link" | ||
54 | - else | ||
55 | - PRG=`dirname "$PRG"`"/$link" | ||
56 | - fi | ||
57 | -done | ||
58 | -SAVED="`pwd`" | ||
59 | -cd "`dirname \"$PRG\"`/" >/dev/null | ||
60 | -APP_HOME="`pwd -P`" | ||
61 | -cd "$SAVED" >/dev/null | ||
62 | - | ||
63 | -CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||
64 | - | ||
65 | -# Determine the Java command to use to start the JVM. | ||
66 | -if [ -n "$JAVA_HOME" ] ; then | ||
67 | - if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||
68 | - # IBM's JDK on AIX uses strange locations for the executables | ||
69 | - JAVACMD="$JAVA_HOME/jre/sh/java" | ||
70 | - else | ||
71 | - JAVACMD="$JAVA_HOME/bin/java" | ||
72 | - fi | ||
73 | - if [ ! -x "$JAVACMD" ] ; then | ||
74 | - die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||
75 | - | ||
76 | -Please set the JAVA_HOME variable in your environment to match the | ||
77 | -location of your Java installation." | ||
78 | - fi | ||
79 | -else | ||
80 | - JAVACMD="java" | ||
81 | - which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
82 | - | ||
83 | -Please set the JAVA_HOME variable in your environment to match the | ||
84 | -location of your Java installation." | ||
85 | -fi | ||
86 | - | ||
87 | -# Increase the maximum file descriptors if we can. | ||
88 | -if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then | ||
89 | - MAX_FD_LIMIT=`ulimit -H -n` | ||
90 | - if [ $? -eq 0 ] ; then | ||
91 | - if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then | ||
92 | - MAX_FD="$MAX_FD_LIMIT" | ||
93 | - fi | ||
94 | - ulimit -n $MAX_FD | ||
95 | - if [ $? -ne 0 ] ; then | ||
96 | - warn "Could not set maximum file descriptor limit: $MAX_FD" | ||
97 | - fi | ||
98 | - else | ||
99 | - warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" | ||
100 | - fi | ||
101 | -fi | ||
102 | - | ||
103 | -# For Darwin, add options to specify how the application appears in the dock | ||
104 | -if $darwin; then | ||
105 | - GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" | ||
106 | -fi | ||
107 | - | ||
108 | -# For Cygwin, switch paths to Windows format before running java | ||
109 | -if $cygwin ; then | ||
110 | - APP_HOME=`cygpath --path --mixed "$APP_HOME"` | ||
111 | - CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` | ||
112 | - JAVACMD=`cygpath --unix "$JAVACMD"` | ||
113 | - | ||
114 | - # We build the pattern for arguments to be converted via cygpath | ||
115 | - ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` | ||
116 | - SEP="" | ||
117 | - for dir in $ROOTDIRSRAW ; do | ||
118 | - ROOTDIRS="$ROOTDIRS$SEP$dir" | ||
119 | - SEP="|" | ||
120 | - done | ||
121 | - OURCYGPATTERN="(^($ROOTDIRS))" | ||
122 | - # Add a user-defined pattern to the cygpath arguments | ||
123 | - if [ "$GRADLE_CYGPATTERN" != "" ] ; then | ||
124 | - OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" | ||
125 | - fi | ||
126 | - # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||
127 | - i=0 | ||
128 | - for arg in "$@" ; do | ||
129 | - CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` | ||
130 | - CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option | ||
131 | - | ||
132 | - if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition | ||
133 | - eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` | ||
134 | - else | ||
135 | - eval `echo args$i`="\"$arg\"" | ||
136 | - fi | ||
137 | - i=$((i+1)) | ||
138 | - done | ||
139 | - case $i in | ||
140 | - (0) set -- ;; | ||
141 | - (1) set -- "$args0" ;; | ||
142 | - (2) set -- "$args0" "$args1" ;; | ||
143 | - (3) set -- "$args0" "$args1" "$args2" ;; | ||
144 | - (4) set -- "$args0" "$args1" "$args2" "$args3" ;; | ||
145 | - (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; | ||
146 | - (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; | ||
147 | - (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; | ||
148 | - (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; | ||
149 | - (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; | ||
150 | - esac | ||
151 | -fi | ||
152 | - | ||
153 | -# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules | ||
154 | -function splitJvmOpts() { | ||
155 | - JVM_OPTS=("$@") | ||
156 | -} | ||
157 | -eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS | ||
158 | -JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" | ||
159 | - | ||
160 | -exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" |
android/gradlew.bat
deleted
100644 → 0
1 | -@if "%DEBUG%" == "" @echo off | ||
2 | -@rem ########################################################################## | ||
3 | -@rem | ||
4 | -@rem Gradle startup script for Windows | ||
5 | -@rem | ||
6 | -@rem ########################################################################## | ||
7 | - | ||
8 | -@rem Set local scope for the variables with windows NT shell | ||
9 | -if "%OS%"=="Windows_NT" setlocal | ||
10 | - | ||
11 | -@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
12 | -set DEFAULT_JVM_OPTS= | ||
13 | - | ||
14 | -set DIRNAME=%~dp0 | ||
15 | -if "%DIRNAME%" == "" set DIRNAME=. | ||
16 | -set APP_BASE_NAME=%~n0 | ||
17 | -set APP_HOME=%DIRNAME% | ||
18 | - | ||
19 | -@rem Find java.exe | ||
20 | -if defined JAVA_HOME goto findJavaFromJavaHome | ||
21 | - | ||
22 | -set JAVA_EXE=java.exe | ||
23 | -%JAVA_EXE% -version >NUL 2>&1 | ||
24 | -if "%ERRORLEVEL%" == "0" goto init | ||
25 | - | ||
26 | -echo. | ||
27 | -echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
28 | -echo. | ||
29 | -echo Please set the JAVA_HOME variable in your environment to match the | ||
30 | -echo location of your Java installation. | ||
31 | - | ||
32 | -goto fail | ||
33 | - | ||
34 | -:findJavaFromJavaHome | ||
35 | -set JAVA_HOME=%JAVA_HOME:"=% | ||
36 | -set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||
37 | - | ||
38 | -if exist "%JAVA_EXE%" goto init | ||
39 | - | ||
40 | -echo. | ||
41 | -echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||
42 | -echo. | ||
43 | -echo Please set the JAVA_HOME variable in your environment to match the | ||
44 | -echo location of your Java installation. | ||
45 | - | ||
46 | -goto fail | ||
47 | - | ||
48 | -:init | ||
49 | -@rem Get command-line arguments, handling Windowz variants | ||
50 | - | ||
51 | -if not "%OS%" == "Windows_NT" goto win9xME_args | ||
52 | -if "%@eval[2+2]" == "4" goto 4NT_args | ||
53 | - | ||
54 | -:win9xME_args | ||
55 | -@rem Slurp the command line arguments. | ||
56 | -set CMD_LINE_ARGS= | ||
57 | -set _SKIP=2 | ||
58 | - | ||
59 | -:win9xME_args_slurp | ||
60 | -if "x%~1" == "x" goto execute | ||
61 | - | ||
62 | -set CMD_LINE_ARGS=%* | ||
63 | -goto execute | ||
64 | - | ||
65 | -:4NT_args | ||
66 | -@rem Get arguments from the 4NT Shell from JP Software | ||
67 | -set CMD_LINE_ARGS=%$ | ||
68 | - | ||
69 | -:execute | ||
70 | -@rem Setup the command line | ||
71 | - | ||
72 | -set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||
73 | - | ||
74 | -@rem Execute Gradle | ||
75 | -"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | ||
76 | - | ||
77 | -:end | ||
78 | -@rem End local scope for the variables with windows NT shell | ||
79 | -if "%ERRORLEVEL%"=="0" goto mainEnd | ||
80 | - | ||
81 | -:fail | ||
82 | -rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||
83 | -rem the _cmd.exe /c_ return code! | ||
84 | -if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | ||
85 | -exit /b 1 | ||
86 | - | ||
87 | -:mainEnd | ||
88 | -if "%OS%"=="Windows_NT" endlocal | ||
89 | - | ||
90 | -:omega |
android/local.properties
deleted
100644 → 0
android/settings.gradle
deleted
100644 → 0
1 | -include ':app' | ||
2 | - | ||
3 | -def flutterProjectRoot = rootProject.projectDir.parentFile.toPath() | ||
4 | - | ||
5 | -def plugins = new Properties() | ||
6 | -def pluginsFile = new File(flutterProjectRoot.toFile(), '.flutter-plugins') | ||
7 | -if (pluginsFile.exists()) { | ||
8 | - pluginsFile.withReader('UTF-8') { reader -> plugins.load(reader) } | ||
9 | -} | ||
10 | - | ||
11 | -plugins.each { name, path -> | ||
12 | - def pluginDirectory = flutterProjectRoot.resolve(path).resolve('android').toFile() | ||
13 | - include ":$name" | ||
14 | - project(":$name").projectDir = pluginDirectory | ||
15 | -} |
ios/Flutter/AppFrameworkInfo.plist
deleted
100644 → 0
1 | -<?xml version="1.0" encoding="UTF-8"?> | ||
2 | -<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> | ||
3 | -<plist version="1.0"> | ||
4 | -<dict> | ||
5 | - <key>CFBundleDevelopmentRegion</key> | ||
6 | - <string>en</string> | ||
7 | - <key>CFBundleExecutable</key> | ||
8 | - <string>App</string> | ||
9 | - <key>CFBundleIdentifier</key> | ||
10 | - <string>io.flutter.flutter.app</string> | ||
11 | - <key>CFBundleInfoDictionaryVersion</key> | ||
12 | - <string>6.0</string> | ||
13 | - <key>CFBundleName</key> | ||
14 | - <string>App</string> | ||
15 | - <key>CFBundlePackageType</key> | ||
16 | - <string>FMWK</string> | ||
17 | - <key>CFBundleShortVersionString</key> | ||
18 | - <string>1.0</string> | ||
19 | - <key>CFBundleSignature</key> | ||
20 | - <string>????</string> | ||
21 | - <key>CFBundleVersion</key> | ||
22 | - <string>1.0</string> | ||
23 | - <key>MinimumOSVersion</key> | ||
24 | - <string>8.0</string> | ||
25 | -</dict> | ||
26 | -</plist> |
ios/Flutter/Debug.xcconfig
deleted
100644 → 0
1 | -#include "Generated.xcconfig" |
ios/Flutter/Release.xcconfig
deleted
100644 → 0
1 | -#include "Generated.xcconfig" |
ios/Runner.xcodeproj/project.pbxproj
deleted
100644 → 0
1 | -// !$*UTF8*$! | ||
2 | -{ | ||
3 | - archiveVersion = 1; | ||
4 | - classes = { | ||
5 | - }; | ||
6 | - objectVersion = 46; | ||
7 | - objects = { | ||
8 | - | ||
9 | -/* Begin PBXBuildFile section */ | ||
10 | - 1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; }; | ||
11 | - 2D5378261FAA1A9400D5DBA9 /* flutter_assets in Resources */ = {isa = PBXBuildFile; fileRef = 2D5378251FAA1A9400D5DBA9 /* flutter_assets */; }; | ||
12 | - 3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; }; | ||
13 | - 3B80C3941E831B6300D905FE /* App.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3B80C3931E831B6300D905FE /* App.framework */; }; | ||
14 | - 3B80C3951E831B6300D905FE /* App.framework in Embed Frameworks */ = {isa = PBXBuildFile; fileRef = 3B80C3931E831B6300D905FE /* App.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; }; | ||
15 | - 9705A1C61CF904A100538489 /* Flutter.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9740EEBA1CF902C7004384FC /* Flutter.framework */; }; | ||
16 | - 9705A1C71CF904A300538489 /* Flutter.framework in Embed Frameworks */ = {isa = PBXBuildFile; fileRef = 9740EEBA1CF902C7004384FC /* Flutter.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; }; | ||
17 | - 9740EEB41CF90195004384FC /* Debug.xcconfig in Resources */ = {isa = PBXBuildFile; fileRef = 9740EEB21CF90195004384FC /* Debug.xcconfig */; }; | ||
18 | - 9740EEB51CF90195004384FC /* Generated.xcconfig in Resources */ = {isa = PBXBuildFile; fileRef = 9740EEB31CF90195004384FC /* Generated.xcconfig */; }; | ||
19 | - 978B8F6F1D3862AE00F588F7 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 7AFFD8EE1D35381100E5BB4D /* AppDelegate.m */; }; | ||
20 | - 97C146F31CF9000F007C117D /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 97C146F21CF9000F007C117D /* main.m */; }; | ||
21 | - 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; }; | ||
22 | - 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; }; | ||
23 | - 97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; }; | ||
24 | -/* End PBXBuildFile section */ | ||
25 | - | ||
26 | -/* Begin PBXCopyFilesBuildPhase section */ | ||
27 | - 9705A1C41CF9048500538489 /* Embed Frameworks */ = { | ||
28 | - isa = PBXCopyFilesBuildPhase; | ||
29 | - buildActionMask = 2147483647; | ||
30 | - dstPath = ""; | ||
31 | - dstSubfolderSpec = 10; | ||
32 | - files = ( | ||
33 | - 3B80C3951E831B6300D905FE /* App.framework in Embed Frameworks */, | ||
34 | - 9705A1C71CF904A300538489 /* Flutter.framework in Embed Frameworks */, | ||
35 | - ); | ||
36 | - name = "Embed Frameworks"; | ||
37 | - runOnlyForDeploymentPostprocessing = 0; | ||
38 | - }; | ||
39 | -/* End PBXCopyFilesBuildPhase section */ | ||
40 | - | ||
41 | -/* Begin PBXFileReference section */ | ||
42 | - 1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = "<group>"; }; | ||
43 | - 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = "<group>"; }; | ||
44 | - 2D5378251FAA1A9400D5DBA9 /* flutter_assets */ = {isa = PBXFileReference; lastKnownFileType = folder; name = flutter_assets; path = Flutter/flutter_assets; sourceTree = SOURCE_ROOT; }; | ||
45 | - 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; }; | ||
46 | - 3B80C3931E831B6300D905FE /* App.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = App.framework; path = Flutter/App.framework; sourceTree = "<group>"; }; | ||
47 | - 7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = "<group>"; }; | ||
48 | - 7AFFD8ED1D35381100E5BB4D /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AppDelegate.h; sourceTree = "<group>"; }; | ||
49 | - 7AFFD8EE1D35381100E5BB4D /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = AppDelegate.m; sourceTree = "<group>"; }; | ||
50 | - 9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = "<group>"; }; | ||
51 | - 9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = "<group>"; }; | ||
52 | - 9740EEBA1CF902C7004384FC /* Flutter.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Flutter.framework; path = Flutter/Flutter.framework; sourceTree = "<group>"; }; | ||
53 | - 97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; }; | ||
54 | - 97C146F21CF9000F007C117D /* main.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = main.m; sourceTree = "<group>"; }; | ||
55 | - 97C146FB1CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = "<group>"; }; | ||
56 | - 97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; }; | ||
57 | - 97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; }; | ||
58 | - 97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; }; | ||
59 | -/* End PBXFileReference section */ | ||
60 | - | ||
61 | -/* Begin PBXFrameworksBuildPhase section */ | ||
62 | - 97C146EB1CF9000F007C117D /* Frameworks */ = { | ||
63 | - isa = PBXFrameworksBuildPhase; | ||
64 | - buildActionMask = 2147483647; | ||
65 | - files = ( | ||
66 | - 9705A1C61CF904A100538489 /* Flutter.framework in Frameworks */, | ||
67 | - 3B80C3941E831B6300D905FE /* App.framework in Frameworks */, | ||
68 | - ); | ||
69 | - runOnlyForDeploymentPostprocessing = 0; | ||
70 | - }; | ||
71 | -/* End PBXFrameworksBuildPhase section */ | ||
72 | - | ||
73 | -/* Begin PBXGroup section */ | ||
74 | - 9740EEB11CF90186004384FC /* Flutter */ = { | ||
75 | - isa = PBXGroup; | ||
76 | - children = ( | ||
77 | - 2D5378251FAA1A9400D5DBA9 /* flutter_assets */, | ||
78 | - 3B80C3931E831B6300D905FE /* App.framework */, | ||
79 | - 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */, | ||
80 | - 9740EEBA1CF902C7004384FC /* Flutter.framework */, | ||
81 | - 9740EEB21CF90195004384FC /* Debug.xcconfig */, | ||
82 | - 7AFA3C8E1D35360C0083082E /* Release.xcconfig */, | ||
83 | - 9740EEB31CF90195004384FC /* Generated.xcconfig */, | ||
84 | - ); | ||
85 | - name = Flutter; | ||
86 | - sourceTree = "<group>"; | ||
87 | - }; | ||
88 | - 97C146E51CF9000F007C117D = { | ||
89 | - isa = PBXGroup; | ||
90 | - children = ( | ||
91 | - 9740EEB11CF90186004384FC /* Flutter */, | ||
92 | - 97C146F01CF9000F007C117D /* Runner */, | ||
93 | - 97C146EF1CF9000F007C117D /* Products */, | ||
94 | - CF3B75C9A7D2FA2A4C99F110 /* Frameworks */, | ||
95 | - ); | ||
96 | - sourceTree = "<group>"; | ||
97 | - }; | ||
98 | - 97C146EF1CF9000F007C117D /* Products */ = { | ||
99 | - isa = PBXGroup; | ||
100 | - children = ( | ||
101 | - 97C146EE1CF9000F007C117D /* Runner.app */, | ||
102 | - ); | ||
103 | - name = Products; | ||
104 | - sourceTree = "<group>"; | ||
105 | - }; | ||
106 | - 97C146F01CF9000F007C117D /* Runner */ = { | ||
107 | - isa = PBXGroup; | ||
108 | - children = ( | ||
109 | - 7AFFD8ED1D35381100E5BB4D /* AppDelegate.h */, | ||
110 | - 7AFFD8EE1D35381100E5BB4D /* AppDelegate.m */, | ||
111 | - 97C146FA1CF9000F007C117D /* Main.storyboard */, | ||
112 | - 97C146FD1CF9000F007C117D /* Assets.xcassets */, | ||
113 | - 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */, | ||
114 | - 97C147021CF9000F007C117D /* Info.plist */, | ||
115 | - 97C146F11CF9000F007C117D /* Supporting Files */, | ||
116 | - 1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */, | ||
117 | - 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */, | ||
118 | - ); | ||
119 | - path = Runner; | ||
120 | - sourceTree = "<group>"; | ||
121 | - }; | ||
122 | - 97C146F11CF9000F007C117D /* Supporting Files */ = { | ||
123 | - isa = PBXGroup; | ||
124 | - children = ( | ||
125 | - 97C146F21CF9000F007C117D /* main.m */, | ||
126 | - ); | ||
127 | - name = "Supporting Files"; | ||
128 | - sourceTree = "<group>"; | ||
129 | - }; | ||
130 | -/* End PBXGroup section */ | ||
131 | - | ||
132 | -/* Begin PBXNativeTarget section */ | ||
133 | - 97C146ED1CF9000F007C117D /* Runner */ = { | ||
134 | - isa = PBXNativeTarget; | ||
135 | - buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */; | ||
136 | - buildPhases = ( | ||
137 | - 9740EEB61CF901F6004384FC /* Run Script */, | ||
138 | - 97C146EA1CF9000F007C117D /* Sources */, | ||
139 | - 97C146EB1CF9000F007C117D /* Frameworks */, | ||
140 | - 97C146EC1CF9000F007C117D /* Resources */, | ||
141 | - 9705A1C41CF9048500538489 /* Embed Frameworks */, | ||
142 | - 3B06AD1E1E4923F5004D2608 /* Thin Binary */, | ||
143 | - ); | ||
144 | - buildRules = ( | ||
145 | - ); | ||
146 | - dependencies = ( | ||
147 | - ); | ||
148 | - name = Runner; | ||
149 | - productName = Runner; | ||
150 | - productReference = 97C146EE1CF9000F007C117D /* Runner.app */; | ||
151 | - productType = "com.apple.product-type.application"; | ||
152 | - }; | ||
153 | -/* End PBXNativeTarget section */ | ||
154 | - | ||
155 | -/* Begin PBXProject section */ | ||
156 | - 97C146E61CF9000F007C117D /* Project object */ = { | ||
157 | - isa = PBXProject; | ||
158 | - attributes = { | ||
159 | - LastUpgradeCheck = 0910; | ||
160 | - ORGANIZATIONNAME = "The Chromium Authors"; | ||
161 | - TargetAttributes = { | ||
162 | - 97C146ED1CF9000F007C117D = { | ||
163 | - CreatedOnToolsVersion = 7.3.1; | ||
164 | - }; | ||
165 | - }; | ||
166 | - }; | ||
167 | - buildConfigurationList = 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */; | ||
168 | - compatibilityVersion = "Xcode 3.2"; | ||
169 | - developmentRegion = English; | ||
170 | - hasScannedForEncodings = 0; | ||
171 | - knownRegions = ( | ||
172 | - en, | ||
173 | - Base, | ||
174 | - ); | ||
175 | - mainGroup = 97C146E51CF9000F007C117D; | ||
176 | - productRefGroup = 97C146EF1CF9000F007C117D /* Products */; | ||
177 | - projectDirPath = ""; | ||
178 | - projectRoot = ""; | ||
179 | - targets = ( | ||
180 | - 97C146ED1CF9000F007C117D /* Runner */, | ||
181 | - ); | ||
182 | - }; | ||
183 | -/* End PBXProject section */ | ||
184 | - | ||
185 | -/* Begin PBXResourcesBuildPhase section */ | ||
186 | - 97C146EC1CF9000F007C117D /* Resources */ = { | ||
187 | - isa = PBXResourcesBuildPhase; | ||
188 | - buildActionMask = 2147483647; | ||
189 | - files = ( | ||
190 | - 97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */, | ||
191 | - 9740EEB51CF90195004384FC /* Generated.xcconfig in Resources */, | ||
192 | - 3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */, | ||
193 | - 9740EEB41CF90195004384FC /* Debug.xcconfig in Resources */, | ||
194 | - 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */, | ||
195 | - 2D5378261FAA1A9400D5DBA9 /* flutter_assets in Resources */, | ||
196 | - 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */, | ||
197 | - ); | ||
198 | - runOnlyForDeploymentPostprocessing = 0; | ||
199 | - }; | ||
200 | -/* End PBXResourcesBuildPhase section */ | ||
201 | - | ||
202 | -/* Begin PBXShellScriptBuildPhase section */ | ||
203 | - 3B06AD1E1E4923F5004D2608 /* Thin Binary */ = { | ||
204 | - isa = PBXShellScriptBuildPhase; | ||
205 | - buildActionMask = 2147483647; | ||
206 | - files = ( | ||
207 | - ); | ||
208 | - inputPaths = ( | ||
209 | - ); | ||
210 | - name = "Thin Binary"; | ||
211 | - outputPaths = ( | ||
212 | - ); | ||
213 | - runOnlyForDeploymentPostprocessing = 0; | ||
214 | - shellPath = /bin/sh; | ||
215 | - shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" thin"; | ||
216 | - }; | ||
217 | - 9740EEB61CF901F6004384FC /* Run Script */ = { | ||
218 | - isa = PBXShellScriptBuildPhase; | ||
219 | - buildActionMask = 2147483647; | ||
220 | - files = ( | ||
221 | - ); | ||
222 | - inputPaths = ( | ||
223 | - ); | ||
224 | - name = "Run Script"; | ||
225 | - outputPaths = ( | ||
226 | - ); | ||
227 | - runOnlyForDeploymentPostprocessing = 0; | ||
228 | - shellPath = /bin/sh; | ||
229 | - shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build"; | ||
230 | - }; | ||
231 | -/* End PBXShellScriptBuildPhase section */ | ||
232 | - | ||
233 | -/* Begin PBXSourcesBuildPhase section */ | ||
234 | - 97C146EA1CF9000F007C117D /* Sources */ = { | ||
235 | - isa = PBXSourcesBuildPhase; | ||
236 | - buildActionMask = 2147483647; | ||
237 | - files = ( | ||
238 | - 978B8F6F1D3862AE00F588F7 /* AppDelegate.m in Sources */, | ||
239 | - 97C146F31CF9000F007C117D /* main.m in Sources */, | ||
240 | - 1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */, | ||
241 | - ); | ||
242 | - runOnlyForDeploymentPostprocessing = 0; | ||
243 | - }; | ||
244 | -/* End PBXSourcesBuildPhase section */ | ||
245 | - | ||
246 | -/* Begin PBXVariantGroup section */ | ||
247 | - 97C146FA1CF9000F007C117D /* Main.storyboard */ = { | ||
248 | - isa = PBXVariantGroup; | ||
249 | - children = ( | ||
250 | - 97C146FB1CF9000F007C117D /* Base */, | ||
251 | - ); | ||
252 | - name = Main.storyboard; | ||
253 | - sourceTree = "<group>"; | ||
254 | - }; | ||
255 | - 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */ = { | ||
256 | - isa = PBXVariantGroup; | ||
257 | - children = ( | ||
258 | - 97C147001CF9000F007C117D /* Base */, | ||
259 | - ); | ||
260 | - name = LaunchScreen.storyboard; | ||
261 | - sourceTree = "<group>"; | ||
262 | - }; | ||
263 | -/* End PBXVariantGroup section */ | ||
264 | - | ||
265 | -/* Begin XCBuildConfiguration section */ | ||
266 | - 97C147031CF9000F007C117D /* Debug */ = { | ||
267 | - isa = XCBuildConfiguration; | ||
268 | - baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */; | ||
269 | - buildSettings = { | ||
270 | - ALWAYS_SEARCH_USER_PATHS = NO; | ||
271 | - CLANG_ANALYZER_NONNULL = YES; | ||
272 | - CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; | ||
273 | - CLANG_CXX_LIBRARY = "libc++"; | ||
274 | - CLANG_ENABLE_MODULES = YES; | ||
275 | - CLANG_ENABLE_OBJC_ARC = YES; | ||
276 | - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; | ||
277 | - CLANG_WARN_BOOL_CONVERSION = YES; | ||
278 | - CLANG_WARN_COMMA = YES; | ||
279 | - CLANG_WARN_CONSTANT_CONVERSION = YES; | ||
280 | - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; | ||
281 | - CLANG_WARN_EMPTY_BODY = YES; | ||
282 | - CLANG_WARN_ENUM_CONVERSION = YES; | ||
283 | - CLANG_WARN_INFINITE_RECURSION = YES; | ||
284 | - CLANG_WARN_INT_CONVERSION = YES; | ||
285 | - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; | ||
286 | - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; | ||
287 | - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; | ||
288 | - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; | ||
289 | - CLANG_WARN_STRICT_PROTOTYPES = YES; | ||
290 | - CLANG_WARN_SUSPICIOUS_MOVE = YES; | ||
291 | - CLANG_WARN_UNREACHABLE_CODE = YES; | ||
292 | - CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; | ||
293 | - "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; | ||
294 | - COPY_PHASE_STRIP = NO; | ||
295 | - DEBUG_INFORMATION_FORMAT = dwarf; | ||
296 | - ENABLE_STRICT_OBJC_MSGSEND = YES; | ||
297 | - ENABLE_TESTABILITY = YES; | ||
298 | - GCC_C_LANGUAGE_STANDARD = gnu99; | ||
299 | - GCC_DYNAMIC_NO_PIC = NO; | ||
300 | - GCC_NO_COMMON_BLOCKS = YES; | ||
301 | - GCC_OPTIMIZATION_LEVEL = 0; | ||
302 | - GCC_PREPROCESSOR_DEFINITIONS = ( | ||
303 | - "DEBUG=1", | ||
304 | - "$(inherited)", | ||
305 | - ); | ||
306 | - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; | ||
307 | - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; | ||
308 | - GCC_WARN_UNDECLARED_SELECTOR = YES; | ||
309 | - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; | ||
310 | - GCC_WARN_UNUSED_FUNCTION = YES; | ||
311 | - GCC_WARN_UNUSED_VARIABLE = YES; | ||
312 | - IPHONEOS_DEPLOYMENT_TARGET = 8.0; | ||
313 | - MTL_ENABLE_DEBUG_INFO = YES; | ||
314 | - ONLY_ACTIVE_ARCH = YES; | ||
315 | - SDKROOT = iphoneos; | ||
316 | - TARGETED_DEVICE_FAMILY = "1,2"; | ||
317 | - }; | ||
318 | - name = Debug; | ||
319 | - }; | ||
320 | - 97C147041CF9000F007C117D /* Release */ = { | ||
321 | - isa = XCBuildConfiguration; | ||
322 | - baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */; | ||
323 | - buildSettings = { | ||
324 | - ALWAYS_SEARCH_USER_PATHS = NO; | ||
325 | - CLANG_ANALYZER_NONNULL = YES; | ||
326 | - CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; | ||
327 | - CLANG_CXX_LIBRARY = "libc++"; | ||
328 | - CLANG_ENABLE_MODULES = YES; | ||
329 | - CLANG_ENABLE_OBJC_ARC = YES; | ||
330 | - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; | ||
331 | - CLANG_WARN_BOOL_CONVERSION = YES; | ||
332 | - CLANG_WARN_COMMA = YES; | ||
333 | - CLANG_WARN_CONSTANT_CONVERSION = YES; | ||
334 | - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; | ||
335 | - CLANG_WARN_EMPTY_BODY = YES; | ||
336 | - CLANG_WARN_ENUM_CONVERSION = YES; | ||
337 | - CLANG_WARN_INFINITE_RECURSION = YES; | ||
338 | - CLANG_WARN_INT_CONVERSION = YES; | ||
339 | - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; | ||
340 | - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; | ||
341 | - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; | ||
342 | - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; | ||
343 | - CLANG_WARN_STRICT_PROTOTYPES = YES; | ||
344 | - CLANG_WARN_SUSPICIOUS_MOVE = YES; | ||
345 | - CLANG_WARN_UNREACHABLE_CODE = YES; | ||
346 | - CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; | ||
347 | - "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; | ||
348 | - COPY_PHASE_STRIP = NO; | ||
349 | - DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; | ||
350 | - ENABLE_NS_ASSERTIONS = NO; | ||
351 | - ENABLE_STRICT_OBJC_MSGSEND = YES; | ||
352 | - GCC_C_LANGUAGE_STANDARD = gnu99; | ||
353 | - GCC_NO_COMMON_BLOCKS = YES; | ||
354 | - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; | ||
355 | - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; | ||
356 | - GCC_WARN_UNDECLARED_SELECTOR = YES; | ||
357 | - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; | ||
358 | - GCC_WARN_UNUSED_FUNCTION = YES; | ||
359 | - GCC_WARN_UNUSED_VARIABLE = YES; | ||
360 | - IPHONEOS_DEPLOYMENT_TARGET = 8.0; | ||
361 | - MTL_ENABLE_DEBUG_INFO = NO; | ||
362 | - SDKROOT = iphoneos; | ||
363 | - TARGETED_DEVICE_FAMILY = "1,2"; | ||
364 | - VALIDATE_PRODUCT = YES; | ||
365 | - }; | ||
366 | - name = Release; | ||
367 | - }; | ||
368 | - 97C147061CF9000F007C117D /* Debug */ = { | ||
369 | - isa = XCBuildConfiguration; | ||
370 | - baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */; | ||
371 | - buildSettings = { | ||
372 | - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; | ||
373 | - CURRENT_PROJECT_VERSION = 1; | ||
374 | - ENABLE_BITCODE = NO; | ||
375 | - FRAMEWORK_SEARCH_PATHS = ( | ||
376 | - "$(inherited)", | ||
377 | - "$(PROJECT_DIR)/Flutter", | ||
378 | - ); | ||
379 | - INFOPLIST_FILE = Runner/Info.plist; | ||
380 | - LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; | ||
381 | - LIBRARY_SEARCH_PATHS = ( | ||
382 | - "$(inherited)", | ||
383 | - "$(PROJECT_DIR)/Flutter", | ||
384 | - ); | ||
385 | - PRODUCT_BUNDLE_IDENTIFIER = de.udos.flutterStateManagement; | ||
386 | - PRODUCT_NAME = "$(TARGET_NAME)"; | ||
387 | - VERSIONING_SYSTEM = "apple-generic"; | ||
388 | - }; | ||
389 | - name = Debug; | ||
390 | - }; | ||
391 | - 97C147071CF9000F007C117D /* Release */ = { | ||
392 | - isa = XCBuildConfiguration; | ||
393 | - baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */; | ||
394 | - buildSettings = { | ||
395 | - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; | ||
396 | - CURRENT_PROJECT_VERSION = 1; | ||
397 | - ENABLE_BITCODE = NO; | ||
398 | - FRAMEWORK_SEARCH_PATHS = ( | ||
399 | - "$(inherited)", | ||
400 | - "$(PROJECT_DIR)/Flutter", | ||
401 | - ); | ||
402 | - INFOPLIST_FILE = Runner/Info.plist; | ||
403 | - LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; | ||
404 | - LIBRARY_SEARCH_PATHS = ( | ||
405 | - "$(inherited)", | ||
406 | - "$(PROJECT_DIR)/Flutter", | ||
407 | - ); | ||
408 | - PRODUCT_BUNDLE_IDENTIFIER = de.udos.flutterStateManagement; | ||
409 | - PRODUCT_NAME = "$(TARGET_NAME)"; | ||
410 | - VERSIONING_SYSTEM = "apple-generic"; | ||
411 | - }; | ||
412 | - name = Release; | ||
413 | - }; | ||
414 | -/* End XCBuildConfiguration section */ | ||
415 | - | ||
416 | -/* Begin XCConfigurationList section */ | ||
417 | - 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */ = { | ||
418 | - isa = XCConfigurationList; | ||
419 | - buildConfigurations = ( | ||
420 | - 97C147031CF9000F007C117D /* Debug */, | ||
421 | - 97C147041CF9000F007C117D /* Release */, | ||
422 | - ); | ||
423 | - defaultConfigurationIsVisible = 0; | ||
424 | - defaultConfigurationName = Release; | ||
425 | - }; | ||
426 | - 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */ = { | ||
427 | - isa = XCConfigurationList; | ||
428 | - buildConfigurations = ( | ||
429 | - 97C147061CF9000F007C117D /* Debug */, | ||
430 | - 97C147071CF9000F007C117D /* Release */, | ||
431 | - ); | ||
432 | - defaultConfigurationIsVisible = 0; | ||
433 | - defaultConfigurationName = Release; | ||
434 | - }; | ||
435 | -/* End XCConfigurationList section */ | ||
436 | - }; | ||
437 | - rootObject = 97C146E61CF9000F007C117D /* Project object */; | ||
438 | -} |
1 | -<?xml version="1.0" encoding="UTF-8"?> | ||
2 | -<Scheme | ||
3 | - LastUpgradeVersion = "0910" | ||
4 | - version = "1.3"> | ||
5 | - <BuildAction | ||
6 | - parallelizeBuildables = "YES" | ||
7 | - buildImplicitDependencies = "YES"> | ||
8 | - <BuildActionEntries> | ||
9 | - <BuildActionEntry | ||
10 | - buildForTesting = "YES" | ||
11 | - buildForRunning = "YES" | ||
12 | - buildForProfiling = "YES" | ||
13 | - buildForArchiving = "YES" | ||
14 | - buildForAnalyzing = "YES"> | ||
15 | - <BuildableReference | ||
16 | - BuildableIdentifier = "primary" | ||
17 | - BlueprintIdentifier = "97C146ED1CF9000F007C117D" | ||
18 | - BuildableName = "Runner.app" | ||
19 | - BlueprintName = "Runner" | ||
20 | - ReferencedContainer = "container:Runner.xcodeproj"> | ||
21 | - </BuildableReference> | ||
22 | - </BuildActionEntry> | ||
23 | - </BuildActionEntries> | ||
24 | - </BuildAction> | ||
25 | - <TestAction | ||
26 | - buildConfiguration = "Debug" | ||
27 | - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" | ||
28 | - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" | ||
29 | - language = "" | ||
30 | - shouldUseLaunchSchemeArgsEnv = "YES"> | ||
31 | - <Testables> | ||
32 | - </Testables> | ||
33 | - <MacroExpansion> | ||
34 | - <BuildableReference | ||
35 | - BuildableIdentifier = "primary" | ||
36 | - BlueprintIdentifier = "97C146ED1CF9000F007C117D" | ||
37 | - BuildableName = "Runner.app" | ||
38 | - BlueprintName = "Runner" | ||
39 | - ReferencedContainer = "container:Runner.xcodeproj"> | ||
40 | - </BuildableReference> | ||
41 | - </MacroExpansion> | ||
42 | - <AdditionalOptions> | ||
43 | - </AdditionalOptions> | ||
44 | - </TestAction> | ||
45 | - <LaunchAction | ||
46 | - buildConfiguration = "Debug" | ||
47 | - selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" | ||
48 | - selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" | ||
49 | - language = "" | ||
50 | - launchStyle = "0" | ||
51 | - useCustomWorkingDirectory = "NO" | ||
52 | - ignoresPersistentStateOnLaunch = "NO" | ||
53 | - debugDocumentVersioning = "YES" | ||
54 | - debugServiceExtension = "internal" | ||
55 | - allowLocationSimulation = "YES"> | ||
56 | - <BuildableProductRunnable | ||
57 | - runnableDebuggingMode = "0"> | ||
58 | - <BuildableReference | ||
59 | - BuildableIdentifier = "primary" | ||
60 | - BlueprintIdentifier = "97C146ED1CF9000F007C117D" | ||
61 | - BuildableName = "Runner.app" | ||
62 | - BlueprintName = "Runner" | ||
63 | - ReferencedContainer = "container:Runner.xcodeproj"> | ||
64 | - </BuildableReference> | ||
65 | - </BuildableProductRunnable> | ||
66 | - <AdditionalOptions> | ||
67 | - </AdditionalOptions> | ||
68 | - </LaunchAction> | ||
69 | - <ProfileAction | ||
70 | - buildConfiguration = "Release" | ||
71 | - shouldUseLaunchSchemeArgsEnv = "YES" | ||
72 | - savedToolIdentifier = "" | ||
73 | - useCustomWorkingDirectory = "NO" | ||
74 | - debugDocumentVersioning = "YES"> | ||
75 | - <BuildableProductRunnable | ||
76 | - runnableDebuggingMode = "0"> | ||
77 | - <BuildableReference | ||
78 | - BuildableIdentifier = "primary" | ||
79 | - BlueprintIdentifier = "97C146ED1CF9000F007C117D" | ||
80 | - BuildableName = "Runner.app" | ||
81 | - BlueprintName = "Runner" | ||
82 | - ReferencedContainer = "container:Runner.xcodeproj"> | ||
83 | - </BuildableReference> | ||
84 | - </BuildableProductRunnable> | ||
85 | - </ProfileAction> | ||
86 | - <AnalyzeAction | ||
87 | - buildConfiguration = "Debug"> | ||
88 | - </AnalyzeAction> | ||
89 | - <ArchiveAction | ||
90 | - buildConfiguration = "Release" | ||
91 | - revealArchiveInOrganizer = "YES"> | ||
92 | - </ArchiveAction> | ||
93 | -</Scheme> |
ios/Runner/AppDelegate.h
deleted
100644 → 0
ios/Runner/AppDelegate.m
deleted
100644 → 0
1 | -#include "AppDelegate.h" | ||
2 | -#include "GeneratedPluginRegistrant.h" | ||
3 | - | ||
4 | -@implementation AppDelegate | ||
5 | - | ||
6 | -- (BOOL)application:(UIApplication *)application | ||
7 | - didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { | ||
8 | - [GeneratedPluginRegistrant registerWithRegistry:self]; | ||
9 | - // Override point for customization after application launch. | ||
10 | - return [super application:application didFinishLaunchingWithOptions:launchOptions]; | ||
11 | -} | ||
12 | - | ||
13 | -@end |
ios/Runner/AppDelegate.swift
deleted
100644 → 0
1 | -import UIKit | ||
2 | -import Flutter | ||
3 | - | ||
4 | -@UIApplicationMain | ||
5 | -@objc class AppDelegate: FlutterAppDelegate { | ||
6 | - override func application( | ||
7 | - _ application: UIApplication, | ||
8 | - didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]? | ||
9 | - ) -> Bool { | ||
10 | - GeneratedPluginRegistrant.register(with: self) | ||
11 | - return super.application(application, didFinishLaunchingWithOptions: launchOptions) | ||
12 | - } | ||
13 | -} |
1 | -{ | ||
2 | - "images" : [ | ||
3 | - { | ||
4 | - "size" : "20x20", | ||
5 | - "idiom" : "iphone", | ||
6 | - "filename" : "Icon-App-20x20@2x.png", | ||
7 | - "scale" : "2x" | ||
8 | - }, | ||
9 | - { | ||
10 | - "size" : "20x20", | ||
11 | - "idiom" : "iphone", | ||
12 | - "filename" : "Icon-App-20x20@3x.png", | ||
13 | - "scale" : "3x" | ||
14 | - }, | ||
15 | - { | ||
16 | - "size" : "29x29", | ||
17 | - "idiom" : "iphone", | ||
18 | - "filename" : "Icon-App-29x29@1x.png", | ||
19 | - "scale" : "1x" | ||
20 | - }, | ||
21 | - { | ||
22 | - "size" : "29x29", | ||
23 | - "idiom" : "iphone", | ||
24 | - "filename" : "Icon-App-29x29@2x.png", | ||
25 | - "scale" : "2x" | ||
26 | - }, | ||
27 | - { | ||
28 | - "size" : "29x29", | ||
29 | - "idiom" : "iphone", | ||
30 | - "filename" : "Icon-App-29x29@3x.png", | ||
31 | - "scale" : "3x" | ||
32 | - }, | ||
33 | - { | ||
34 | - "size" : "40x40", | ||
35 | - "idiom" : "iphone", | ||
36 | - "filename" : "Icon-App-40x40@2x.png", | ||
37 | - "scale" : "2x" | ||
38 | - }, | ||
39 | - { | ||
40 | - "size" : "40x40", | ||
41 | - "idiom" : "iphone", | ||
42 | - "filename" : "Icon-App-40x40@3x.png", | ||
43 | - "scale" : "3x" | ||
44 | - }, | ||
45 | - { | ||
46 | - "size" : "60x60", | ||
47 | - "idiom" : "iphone", | ||
48 | - "filename" : "Icon-App-60x60@2x.png", | ||
49 | - "scale" : "2x" | ||
50 | - }, | ||
51 | - { | ||
52 | - "size" : "60x60", | ||
53 | - "idiom" : "iphone", | ||
54 | - "filename" : "Icon-App-60x60@3x.png", | ||
55 | - "scale" : "3x" | ||
56 | - }, | ||
57 | - { | ||
58 | - "size" : "20x20", | ||
59 | - "idiom" : "ipad", | ||
60 | - "filename" : "Icon-App-20x20@1x.png", | ||
61 | - "scale" : "1x" | ||
62 | - }, | ||
63 | - { | ||
64 | - "size" : "20x20", | ||
65 | - "idiom" : "ipad", | ||
66 | - "filename" : "Icon-App-20x20@2x.png", | ||
67 | - "scale" : "2x" | ||
68 | - }, | ||
69 | - { | ||
70 | - "size" : "29x29", | ||
71 | - "idiom" : "ipad", | ||
72 | - "filename" : "Icon-App-29x29@1x.png", | ||
73 | - "scale" : "1x" | ||
74 | - }, | ||
75 | - { | ||
76 | - "size" : "29x29", | ||
77 | - "idiom" : "ipad", | ||
78 | - "filename" : "Icon-App-29x29@2x.png", | ||
79 | - "scale" : "2x" | ||
80 | - }, | ||
81 | - { | ||
82 | - "size" : "40x40", | ||
83 | - "idiom" : "ipad", | ||
84 | - "filename" : "Icon-App-40x40@1x.png", | ||
85 | - "scale" : "1x" | ||
86 | - }, | ||
87 | - { | ||
88 | - "size" : "40x40", | ||
89 | - "idiom" : "ipad", | ||
90 | - "filename" : "Icon-App-40x40@2x.png", | ||
91 | - "scale" : "2x" | ||
92 | - }, | ||
93 | - { | ||
94 | - "size" : "76x76", | ||
95 | - "idiom" : "ipad", | ||
96 | - "filename" : "Icon-App-76x76@1x.png", | ||
97 | - "scale" : "1x" | ||
98 | - }, | ||
99 | - { | ||
100 | - "size" : "76x76", | ||
101 | - "idiom" : "ipad", | ||
102 | - "filename" : "Icon-App-76x76@2x.png", | ||
103 | - "scale" : "2x" | ||
104 | - }, | ||
105 | - { | ||
106 | - "size" : "83.5x83.5", | ||
107 | - "idiom" : "ipad", | ||
108 | - "filename" : "Icon-App-83.5x83.5@2x.png", | ||
109 | - "scale" : "2x" | ||
110 | - }, | ||
111 | - { | ||
112 | - "size" : "1024x1024", | ||
113 | - "idiom" : "ios-marketing", | ||
114 | - "filename" : "Icon-App-1024x1024@1x.png", | ||
115 | - "scale" : "1x" | ||
116 | - } | ||
117 | - ], | ||
118 | - "info" : { | ||
119 | - "version" : 1, | ||
120 | - "author" : "xcode" | ||
121 | - } | ||
122 | -} |

564 Bytes

1.25 KB

1.55 KB

1.68 KB

1.88 KB

1.25 KB

1.85 KB

3.74 KB

1.84 KB

3.22 KB
1 | -{ | ||
2 | - "images" : [ | ||
3 | - { | ||
4 | - "idiom" : "universal", | ||
5 | - "filename" : "LaunchImage.png", | ||
6 | - "scale" : "1x" | ||
7 | - }, | ||
8 | - { | ||
9 | - "idiom" : "universal", | ||
10 | - "filename" : "LaunchImage@2x.png", | ||
11 | - "scale" : "2x" | ||
12 | - }, | ||
13 | - { | ||
14 | - "idiom" : "universal", | ||
15 | - "filename" : "LaunchImage@3x.png", | ||
16 | - "scale" : "3x" | ||
17 | - } | ||
18 | - ], | ||
19 | - "info" : { | ||
20 | - "version" : 1, | ||
21 | - "author" : "xcode" | ||
22 | - } | ||
23 | -} |

68 Bytes

68 Bytes

68 Bytes
1 | -# Launch Screen Assets | ||
2 | - | ||
3 | -You can customize the launch screen with your own desired assets by replacing the image files in this directory. | ||
4 | - | ||
5 | -You can also do it by opening your Flutter project's Xcode project with `open ios/Runner.xcworkspace`, selecting `Runner/Assets.xcassets` in the Project Navigator and dropping in the desired images. |
1 | -<?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||
2 | -<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="12121" systemVersion="16G29" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" colorMatched="YES" initialViewController="01J-lp-oVM"> | ||
3 | - <dependencies> | ||
4 | - <deployment identifier="iOS"/> | ||
5 | - <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="12089"/> | ||
6 | - </dependencies> | ||
7 | - <scenes> | ||
8 | - <!--View Controller--> | ||
9 | - <scene sceneID="EHf-IW-A2E"> | ||
10 | - <objects> | ||
11 | - <viewController id="01J-lp-oVM" sceneMemberID="viewController"> | ||
12 | - <layoutGuides> | ||
13 | - <viewControllerLayoutGuide type="top" id="Ydg-fD-yQy"/> | ||
14 | - <viewControllerLayoutGuide type="bottom" id="xbc-2k-c8Z"/> | ||
15 | - </layoutGuides> | ||
16 | - <view key="view" contentMode="scaleToFill" id="Ze5-6b-2t3"> | ||
17 | - <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/> | ||
18 | - <subviews> | ||
19 | - <imageView opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" image="LaunchImage" translatesAutoresizingMaskIntoConstraints="NO" id="YRO-k0-Ey4"> | ||
20 | - </imageView> | ||
21 | - </subviews> | ||
22 | - <color key="backgroundColor" red="1" green="1" blue="1" alpha="1" colorSpace="custom" customColorSpace="sRGB"/> | ||
23 | - <constraints> | ||
24 | - <constraint firstItem="YRO-k0-Ey4" firstAttribute="centerX" secondItem="Ze5-6b-2t3" secondAttribute="centerX" id="1a2-6s-vTC"/> | ||
25 | - <constraint firstItem="YRO-k0-Ey4" firstAttribute="centerY" secondItem="Ze5-6b-2t3" secondAttribute="centerY" id="4X2-HB-R7a"/> | ||
26 | - </constraints> | ||
27 | - </view> | ||
28 | - </viewController> | ||
29 | - <placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/> | ||
30 | - </objects> | ||
31 | - <point key="canvasLocation" x="53" y="375"/> | ||
32 | - </scene> | ||
33 | - </scenes> | ||
34 | - <resources> | ||
35 | - <image name="LaunchImage" width="168" height="185"/> | ||
36 | - </resources> | ||
37 | -</document> |
1 | -<?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||
2 | -<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="10117" systemVersion="15F34" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" initialViewController="BYZ-38-t0r"> | ||
3 | - <dependencies> | ||
4 | - <deployment identifier="iOS"/> | ||
5 | - <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="10085"/> | ||
6 | - </dependencies> | ||
7 | - <scenes> | ||
8 | - <!--Flutter View Controller--> | ||
9 | - <scene sceneID="tne-QT-ifu"> | ||
10 | - <objects> | ||
11 | - <viewController id="BYZ-38-t0r" customClass="FlutterViewController" sceneMemberID="viewController"> | ||
12 | - <layoutGuides> | ||
13 | - <viewControllerLayoutGuide type="top" id="y3c-jy-aDJ"/> | ||
14 | - <viewControllerLayoutGuide type="bottom" id="wfy-db-euE"/> | ||
15 | - </layoutGuides> | ||
16 | - <view key="view" contentMode="scaleToFill" id="8bC-Xf-vdC"> | ||
17 | - <rect key="frame" x="0.0" y="0.0" width="600" height="600"/> | ||
18 | - <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/> | ||
19 | - <color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="calibratedWhite"/> | ||
20 | - </view> | ||
21 | - </viewController> | ||
22 | - <placeholder placeholderIdentifier="IBFirstResponder" id="dkx-z0-nzr" sceneMemberID="firstResponder"/> | ||
23 | - </objects> | ||
24 | - </scene> | ||
25 | - </scenes> | ||
26 | -</document> |
1 | -// | ||
2 | -// Generated file. Do not edit. | ||
3 | -// | ||
4 | - | ||
5 | -#ifndef GeneratedPluginRegistrant_h | ||
6 | -#define GeneratedPluginRegistrant_h | ||
7 | - | ||
8 | -#import <Flutter/Flutter.h> | ||
9 | - | ||
10 | -NS_ASSUME_NONNULL_BEGIN | ||
11 | - | ||
12 | -@interface GeneratedPluginRegistrant : NSObject | ||
13 | -+ (void)registerWithRegistry:(NSObject<FlutterPluginRegistry>*)registry; | ||
14 | -@end | ||
15 | - | ||
16 | -NS_ASSUME_NONNULL_END | ||
17 | -#endif /* GeneratedPluginRegistrant_h */ |
ios/Runner/Info.plist
deleted
100644 → 0
1 | -<?xml version="1.0" encoding="UTF-8"?> | ||
2 | -<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> | ||
3 | -<plist version="1.0"> | ||
4 | -<dict> | ||
5 | - <key>CFBundleDevelopmentRegion</key> | ||
6 | - <string>en</string> | ||
7 | - <key>CFBundleExecutable</key> | ||
8 | - <string>$(EXECUTABLE_NAME)</string> | ||
9 | - <key>CFBundleIdentifier</key> | ||
10 | - <string>$(PRODUCT_BUNDLE_IDENTIFIER)</string> | ||
11 | - <key>CFBundleInfoDictionaryVersion</key> | ||
12 | - <string>6.0</string> | ||
13 | - <key>CFBundleName</key> | ||
14 | - <string>benckmark</string> | ||
15 | - <key>CFBundlePackageType</key> | ||
16 | - <string>APPL</string> | ||
17 | - <key>CFBundleShortVersionString</key> | ||
18 | - <string>1.0</string> | ||
19 | - <key>CFBundleSignature</key> | ||
20 | - <string>????</string> | ||
21 | - <key>CFBundleVersion</key> | ||
22 | - <string>1</string> | ||
23 | - <key>LSRequiresIPhoneOS</key> | ||
24 | - <true/> | ||
25 | - <key>UILaunchStoryboardName</key> | ||
26 | - <string>LaunchScreen</string> | ||
27 | - <key>UIMainStoryboardFile</key> | ||
28 | - <string>Main</string> | ||
29 | - <key>UISupportedInterfaceOrientations</key> | ||
30 | - <array> | ||
31 | - <string>UIInterfaceOrientationPortrait</string> | ||
32 | - <string>UIInterfaceOrientationLandscapeLeft</string> | ||
33 | - <string>UIInterfaceOrientationLandscapeRight</string> | ||
34 | - </array> | ||
35 | - <key>UISupportedInterfaceOrientations~ipad</key> | ||
36 | - <array> | ||
37 | - <string>UIInterfaceOrientationPortrait</string> | ||
38 | - <string>UIInterfaceOrientationPortraitUpsideDown</string> | ||
39 | - <string>UIInterfaceOrientationLandscapeLeft</string> | ||
40 | - <string>UIInterfaceOrientationLandscapeRight</string> | ||
41 | - </array> | ||
42 | - <key>UIViewControllerBasedStatusBarAppearance</key> | ||
43 | - <false/> | ||
44 | -</dict> | ||
45 | -</plist> |
ios/Runner/Runner-Bridging-Header.h
deleted
100644 → 0
1 | -#import "GeneratedPluginRegistrant.h" |
ios/Runner/main.m
deleted
100644 → 0
1 | -import 'package:benckmark/_bloc_lib/_shared/entitity.dart'; | ||
2 | -import 'package:benckmark/_bloc_lib/_shared/item.entity.dart'; | ||
3 | - | ||
4 | -import 'items.events.dart'; | ||
5 | -import 'items.state.dart'; | ||
6 | - | ||
7 | -class ItemsBloc extends EntityBloc<EntityEvent, ItemsState> { | ||
8 | - @override | ||
9 | - ItemsState get initialState => ItemsState(sampleItems); | ||
10 | - | ||
11 | - @override | ||
12 | - Stream<ItemsState> mapEventToState(EntityEvent event) async* { | ||
13 | - if (event is AddItemEvent) { | ||
14 | - final List<Item> items = List.from(state.entities)..add(event.item); | ||
15 | - | ||
16 | - yield ItemsState(items); | ||
17 | - } else if (event is AddItemsEvent) { | ||
18 | - final List<Item> items = List.from(state.entities)..addAll(event.items); | ||
19 | - | ||
20 | - yield ItemsState(items); | ||
21 | - } else if (event is RemoveItemsEvent) { | ||
22 | - final List<Item> items = List.from(state.entities); | ||
23 | - | ||
24 | - items.removeWhere((item) => event.itemIds.contains(item.id)); | ||
25 | - | ||
26 | - yield ItemsState(items); | ||
27 | - } | ||
28 | - } | ||
29 | -} |
1 | -import 'package:benckmark/_bloc_lib/_shared/entitity.dart'; | ||
2 | -import 'package:benckmark/_bloc_lib/_shared/item.entity.dart'; | ||
3 | - | ||
4 | -class AddItemEvent extends EntityEvent<Item> { | ||
5 | - final Item item; | ||
6 | - | ||
7 | - AddItemEvent(this.item); | ||
8 | - | ||
9 | - @override | ||
10 | - List<Object> get props => [item]; | ||
11 | -} | ||
12 | - | ||
13 | -class AddItemsEvent extends EntityEvent<Item> { | ||
14 | - final List<Item> items; | ||
15 | - | ||
16 | - AddItemsEvent(this.items); | ||
17 | - | ||
18 | - @override | ||
19 | - List<Object> get props => [items]; | ||
20 | -} | ||
21 | - | ||
22 | -class RemoveItemsEvent extends EntityEvent<Item> { | ||
23 | - final List<String> itemIds; | ||
24 | - | ||
25 | - RemoveItemsEvent(this.itemIds); | ||
26 | - | ||
27 | - @override | ||
28 | - List<Object> get props => [itemIds]; | ||
29 | -} |
lib/_bloc_lib/_shared/entitity.dart
deleted
100644 → 0
1 | -import 'package:bloc/bloc.dart'; | ||
2 | -import 'package:equatable/equatable.dart'; | ||
3 | -import 'package:meta/meta.dart'; | ||
4 | -import 'package:uuid/uuid.dart'; | ||
5 | - | ||
6 | -@immutable | ||
7 | -class Entity extends Equatable { | ||
8 | - final String id; | ||
9 | - | ||
10 | - Entity([String id]) : this.id = id ?? Uuid().v4(); | ||
11 | - | ||
12 | - @override | ||
13 | - List<Object> get props => [id]; | ||
14 | -} | ||
15 | - | ||
16 | -@immutable | ||
17 | -abstract class EntityEvent<E extends Entity> extends Equatable {} | ||
18 | - | ||
19 | -@immutable | ||
20 | -class EntityState<E extends Entity> extends Equatable { | ||
21 | - final Map<String, E> dictionary; | ||
22 | - final List<String> ids; | ||
23 | - final List<E> entities; | ||
24 | - | ||
25 | - EntityState([this.entities = const []]) | ||
26 | - : dictionary = Map.fromIterable(entities, | ||
27 | - key: (entity) => entity.id, value: (entity) => entity), | ||
28 | - ids = List.from(entities.map((entity) => entity.id)); | ||
29 | - | ||
30 | - @override | ||
31 | - List<Object> get props => [dictionary, ids, entities]; | ||
32 | -} | ||
33 | - | ||
34 | -abstract class EntityBloc<Event extends EntityEvent, State extends EntityState> | ||
35 | - extends Bloc<Event, State> {} |
1 | -import 'package:meta/meta.dart'; | ||
2 | - | ||
3 | -import 'entitity.dart'; | ||
4 | - | ||
5 | -@immutable | ||
6 | -class Item extends Entity { | ||
7 | - final String title; | ||
8 | - | ||
9 | - Item({String id, this.title}) : super(); | ||
10 | - | ||
11 | - @override | ||
12 | - List<Object> get props => super.props..addAll([id, title]); | ||
13 | -} | ||
14 | - | ||
15 | -final List<Item> sampleItems = [ | ||
16 | - Item(title: 'Item 1'), | ||
17 | - Item(title: 'Item 2'), | ||
18 | - Item(title: 'Item 3') | ||
19 | -]; |
lib/_bloc_lib/app.dart
deleted
100644 → 0
1 | -import 'package:flutter/material.dart'; | ||
2 | -import 'package:flutter_bloc/flutter_bloc.dart'; | ||
3 | -import 'package:benckmark/_bloc_lib/_blocs/items/items.bloc.dart'; | ||
4 | -import 'package:benckmark/_bloc_lib/_blocs/items/items.events.dart'; | ||
5 | -import 'package:benckmark/_bloc_lib/_blocs/items/items.state.dart'; | ||
6 | -import 'package:benckmark/_bloc_lib/_shared/item.entity.dart'; | ||
7 | - | ||
8 | -class App extends StatelessWidget { | ||
9 | - Widget build(BuildContext context) { | ||
10 | - return MultiBlocProvider( | ||
11 | - providers: [ | ||
12 | - BlocProvider<ItemsBloc>( | ||
13 | - create: (context) => ItemsBloc(), | ||
14 | - ), | ||
15 | - ], | ||
16 | - child: MaterialApp( | ||
17 | - title: 'BLoC Lib Sample', | ||
18 | - theme: ThemeData( | ||
19 | - primarySwatch: Colors.blue, | ||
20 | - ), | ||
21 | - home: Page( | ||
22 | - title: 'BLoC Lib Sample', | ||
23 | - ), | ||
24 | - ), | ||
25 | - ); | ||
26 | - } | ||
27 | -} | ||
28 | - | ||
29 | -class Page extends StatefulWidget { | ||
30 | - Page({ | ||
31 | - Key key, | ||
32 | - this.title, | ||
33 | - }) : super(key: key); | ||
34 | - | ||
35 | - final String title; | ||
36 | - | ||
37 | - @override | ||
38 | - _PageState createState() => _PageState(); | ||
39 | -} | ||
40 | - | ||
41 | -class _PageState extends State<Page> { | ||
42 | - @override | ||
43 | - void initState() { | ||
44 | - fill(); | ||
45 | - super.initState(); | ||
46 | - } | ||
47 | - | ||
48 | - fill() async { | ||
49 | - for (int i = 0; i < 10; i++) { | ||
50 | - await Future.delayed(Duration(milliseconds: 500)); | ||
51 | - BlocProvider.of<ItemsBloc>(context) | ||
52 | - .add(AddItemEvent(Item(title: DateTime.now().toString()))); | ||
53 | - } | ||
54 | - print("It's done. Print now!"); | ||
55 | - } | ||
56 | - | ||
57 | - @override | ||
58 | - Widget build(BuildContext context) { | ||
59 | - return Scaffold( | ||
60 | - appBar: AppBar( | ||
61 | - title: Text(widget.title), | ||
62 | - ), | ||
63 | - body: ListViewWidget(), | ||
64 | - ); | ||
65 | - } | ||
66 | -} | ||
67 | - | ||
68 | -class ListViewWidget extends StatelessWidget { | ||
69 | - @override | ||
70 | - Widget build(BuildContext context) { | ||
71 | - // ignore: close_sinks | ||
72 | - final _itemsBloc = BlocProvider.of<ItemsBloc>(context); | ||
73 | - | ||
74 | - return BlocBuilder<ItemsBloc, ItemsState>( | ||
75 | - bloc: _itemsBloc, | ||
76 | - builder: (context, entityState) { | ||
77 | - return ListView.builder( | ||
78 | - padding: EdgeInsets.fromLTRB(0.0, 8.0, 0.0, 8.0), | ||
79 | - itemCount: entityState.entities.length, | ||
80 | - itemBuilder: (context, index) { | ||
81 | - final item = entityState.entities[index]; | ||
82 | - | ||
83 | - return ListTile( | ||
84 | - title: Text(item.title), | ||
85 | - ); | ||
86 | - }, | ||
87 | - ); | ||
88 | - }, | ||
89 | - ); | ||
90 | - } | ||
91 | -} |
lib/_bloc_plain/_bloc.dart
deleted
100644 → 0
1 | -import 'dart:async'; | ||
2 | - | ||
3 | -import 'package:benckmark/item.dart'; | ||
4 | -import 'package:rxdart/rxdart.dart'; | ||
5 | - | ||
6 | -class AddItemEvent { | ||
7 | - final Item item; | ||
8 | - | ||
9 | - AddItemEvent(this.item); | ||
10 | -} | ||
11 | - | ||
12 | -class ItemsBloc { | ||
13 | - final StreamController<dynamic> _itemsEventController = StreamController(); | ||
14 | - | ||
15 | - StreamSink<dynamic> get _itemsEventSink => _itemsEventController.sink; | ||
16 | - | ||
17 | - final BehaviorSubject<List<Item>> _itemsStateSubject = | ||
18 | - BehaviorSubject.seeded(sampleItems); | ||
19 | - | ||
20 | - StreamSink<List<Item>> get _itemsStateSink => _itemsStateSubject.sink; | ||
21 | - | ||
22 | - ValueStream<List<Item>> get items => _itemsStateSubject.stream; | ||
23 | - | ||
24 | - List<StreamSubscription<dynamic>> _subscriptions; | ||
25 | - | ||
26 | - ItemsBloc() { | ||
27 | - _subscriptions = <StreamSubscription<dynamic>>[ | ||
28 | - _itemsEventController.stream.listen(_mapEventToState) | ||
29 | - ]; | ||
30 | - } | ||
31 | - | ||
32 | - dispose() { | ||
33 | - _subscriptions.forEach((subscription) => subscription.cancel()); | ||
34 | - _itemsStateSubject.close(); | ||
35 | - _itemsEventController.close(); | ||
36 | - } | ||
37 | - | ||
38 | - void addItem(Item item) { | ||
39 | - _itemsEventSink.add(AddItemEvent(item)); | ||
40 | - } | ||
41 | - | ||
42 | - void _mapEventToState(dynamic event) { | ||
43 | - if (event is AddItemEvent) { | ||
44 | - _itemsStateSink.add([...items.value, event.item]); | ||
45 | - } | ||
46 | - } | ||
47 | -} |
lib/_bloc_plain/_provider.dart
deleted
100644 → 0
1 | -import 'package:flutter/widgets.dart'; | ||
2 | - | ||
3 | -import '_bloc.dart'; | ||
4 | - | ||
5 | -class ItemsBlocProvider extends InheritedWidget { | ||
6 | - final ItemsBloc bloc; | ||
7 | - | ||
8 | - ItemsBlocProvider({ | ||
9 | - Key key, | ||
10 | - Widget child, | ||
11 | - @required this.bloc, | ||
12 | - }) : super(key: key, child: child); | ||
13 | - | ||
14 | - @override | ||
15 | - bool updateShouldNotify(InheritedWidget oldWidget) => true; | ||
16 | - | ||
17 | - static ItemsBloc of(BuildContext context) { | ||
18 | - final provider = | ||
19 | - context.dependOnInheritedWidgetOfExactType<ItemsBlocProvider>(); | ||
20 | - | ||
21 | - return provider.bloc; | ||
22 | - } | ||
23 | -} |
lib/_bloc_plain/app.dart
deleted
100644 → 0
1 | -import 'package:flutter/material.dart'; | ||
2 | -import 'package:flutter/scheduler.dart'; | ||
3 | -import 'package:benckmark/item.dart'; | ||
4 | - | ||
5 | -import '_bloc.dart'; | ||
6 | -import '_provider.dart'; | ||
7 | - | ||
8 | -class App extends StatelessWidget { | ||
9 | - final ItemsBloc itemsBloc = ItemsBloc(); | ||
10 | - | ||
11 | - @override | ||
12 | - Widget build(BuildContext context) { | ||
13 | - return ItemsBlocProvider( | ||
14 | - bloc: itemsBloc, | ||
15 | - child: MaterialApp( | ||
16 | - title: 'BLoC Sample', | ||
17 | - theme: ThemeData( | ||
18 | - primarySwatch: Colors.blue, | ||
19 | - ), | ||
20 | - home: Page(title: 'BLoC Sample'), | ||
21 | - ), | ||
22 | - ); | ||
23 | - } | ||
24 | -} | ||
25 | - | ||
26 | -class Page extends StatefulWidget { | ||
27 | - Page({Key key, this.title}) : super(key: key); | ||
28 | - | ||
29 | - final String title; | ||
30 | - | ||
31 | - @override | ||
32 | - _PageState createState() => _PageState(); | ||
33 | -} | ||
34 | - | ||
35 | -class _PageState extends State<Page> { | ||
36 | - @override | ||
37 | - void initState() { | ||
38 | - SchedulerBinding.instance.addPostFrameCallback((timeStamp) async { | ||
39 | - for (int i = 0; i < 10; i++) { | ||
40 | - await Future.delayed(Duration(milliseconds: 500)); | ||
41 | - ItemsBlocProvider.of(context) | ||
42 | - .addItem(Item(title: DateTime.now().toString())); | ||
43 | - } | ||
44 | - print("It's done. Print now!"); | ||
45 | - }); | ||
46 | - | ||
47 | - super.initState(); | ||
48 | - } | ||
49 | - | ||
50 | - @override | ||
51 | - Widget build(BuildContext context) { | ||
52 | - return Scaffold( | ||
53 | - appBar: AppBar( | ||
54 | - title: Text(widget.title), | ||
55 | - ), | ||
56 | - body: ListViewWidget(), | ||
57 | - ); | ||
58 | - } | ||
59 | -} | ||
60 | - | ||
61 | -class ListViewWidget extends StatelessWidget { | ||
62 | - @override | ||
63 | - Widget build(BuildContext context) { | ||
64 | - final ItemsBloc itemsBloc = ItemsBlocProvider.of(context); | ||
65 | - | ||
66 | - return StreamBuilder<List<Item>>( | ||
67 | - stream: itemsBloc.items, | ||
68 | - builder: (context, snapshot) { | ||
69 | - final items = snapshot.data; | ||
70 | - return ListView.builder( | ||
71 | - padding: EdgeInsets.fromLTRB(0.0, 8.0, 0.0, 8.0), | ||
72 | - itemCount: items is List<Item> ? items.length : 0, | ||
73 | - itemBuilder: (context, index) { | ||
74 | - return ListTile( | ||
75 | - title: Text(items[index].title), | ||
76 | - ); | ||
77 | - }, | ||
78 | - ); | ||
79 | - }, | ||
80 | - ); | ||
81 | - } | ||
82 | -} |
lib/_get/_store.dart
deleted
100644 → 0
1 | -import 'package:benckmark/item.dart'; | ||
2 | -import 'package:get/get.dart'; | ||
3 | - | ||
4 | -class Controller extends GetController { | ||
5 | - @override | ||
6 | - onInit() async { | ||
7 | - for (int i = 0; i < 10; i++) { | ||
8 | - await Future.delayed(Duration(milliseconds: 500)); | ||
9 | - addItem(Item(title: DateTime.now().toString())); | ||
10 | - } | ||
11 | - print("It's done. Print now!"); | ||
12 | - super.onInit(); | ||
13 | - } | ||
14 | - | ||
15 | - final items = List<Item>.of(sampleItems); | ||
16 | - | ||
17 | - void addItem(Item item) { | ||
18 | - items.add(item); | ||
19 | - update(); | ||
20 | - } | ||
21 | -} |
lib/_get/app.dart
deleted
100644 → 0
1 | -import 'package:flutter/material.dart'; | ||
2 | -import 'package:benckmark/_get/_store.dart'; | ||
3 | -import 'package:get/get.dart'; | ||
4 | - | ||
5 | -class App extends StatelessWidget { | ||
6 | - @override | ||
7 | - Widget build(BuildContext context) { | ||
8 | - return MaterialApp( | ||
9 | - title: 'Get Sample', | ||
10 | - theme: ThemeData( | ||
11 | - primarySwatch: Colors.blue, | ||
12 | - ), | ||
13 | - home: Page(title: 'Get Sample'), | ||
14 | - ); | ||
15 | - } | ||
16 | -} | ||
17 | - | ||
18 | -class Page extends StatelessWidget { | ||
19 | - Page({ | ||
20 | - Key key, | ||
21 | - this.title, | ||
22 | - }) : super(key: key); | ||
23 | - | ||
24 | - final String title; | ||
25 | - | ||
26 | - @override | ||
27 | - Widget build(BuildContext context) { | ||
28 | - return Scaffold( | ||
29 | - appBar: AppBar( | ||
30 | - title: Text(title), | ||
31 | - ), | ||
32 | - body: ListViewWidget(), | ||
33 | - ); | ||
34 | - } | ||
35 | -} | ||
36 | - | ||
37 | -class ListViewWidget extends StatelessWidget { | ||
38 | - @override | ||
39 | - Widget build(BuildContext context) { | ||
40 | - return GetBuilder<Controller>( | ||
41 | - init: Controller(), | ||
42 | - global: false, | ||
43 | - builder: (_) => ListView.builder( | ||
44 | - padding: EdgeInsets.fromLTRB(0.0, 8.0, 0.0, 8.0), | ||
45 | - itemCount: _.items.length, | ||
46 | - itemBuilder: (context, index) { | ||
47 | - return ListTile( | ||
48 | - title: Text(_.items[index].title), | ||
49 | - ); | ||
50 | - })); | ||
51 | - } | ||
52 | -} |
lib/_get_rx/_store.dart
deleted
100644 → 0
1 | -import 'package:benckmark/item.dart'; | ||
2 | -import 'package:get/get.dart'; | ||
3 | - | ||
4 | -class Controller extends RxController { | ||
5 | - final items = sampleItems.obs; | ||
6 | - | ||
7 | - @override | ||
8 | - onInit() async { | ||
9 | - for (int i = 0; i < 10; i++) { | ||
10 | - await Future.delayed(Duration(milliseconds: 500)); | ||
11 | - addItem(Item(title: DateTime.now().toString())); | ||
12 | - } | ||
13 | - | ||
14 | - print("It's done. Print now!"); | ||
15 | - super.onInit(); | ||
16 | - } | ||
17 | - | ||
18 | - void addItem(Item item) { | ||
19 | - items.add(item); | ||
20 | - } | ||
21 | -} |
lib/_get_rx/app.dart
deleted
100644 → 0
1 | -import 'package:benckmark/_get_rx/_store.dart'; | ||
2 | -import 'package:flutter/material.dart'; | ||
3 | -import 'package:get/get.dart'; | ||
4 | - | ||
5 | -class App extends StatelessWidget { | ||
6 | - @override | ||
7 | - Widget build(BuildContext context) { | ||
8 | - return MaterialApp( | ||
9 | - title: 'GetX Sample', | ||
10 | - theme: ThemeData( | ||
11 | - primarySwatch: Colors.blue, | ||
12 | - ), | ||
13 | - home: Page(title: 'GetX Sample'), | ||
14 | - ); | ||
15 | - } | ||
16 | -} | ||
17 | - | ||
18 | -Controller c = Controller(); | ||
19 | - | ||
20 | -class Page extends StatefulWidget { | ||
21 | - Page({ | ||
22 | - Key key, | ||
23 | - this.title, | ||
24 | - }) : super(key: key); | ||
25 | - | ||
26 | - final String title; | ||
27 | - | ||
28 | - @override | ||
29 | - _PageState createState() => _PageState(); | ||
30 | -} | ||
31 | - | ||
32 | -class _PageState extends State<Page> { | ||
33 | - @override | ||
34 | - void initState() { | ||
35 | - c.onInit(); | ||
36 | - super.initState(); | ||
37 | - } | ||
38 | - | ||
39 | - @override | ||
40 | - Widget build(BuildContext context) { | ||
41 | - return Scaffold( | ||
42 | - appBar: AppBar( | ||
43 | - title: Text(widget.title), | ||
44 | - ), | ||
45 | - body: ListViewWidget(), | ||
46 | - ); | ||
47 | - } | ||
48 | -} | ||
49 | - | ||
50 | -class ListViewWidget extends StatelessWidget { | ||
51 | - @override | ||
52 | - Widget build(BuildContext context) { | ||
53 | - return Obxx(() => ListView.builder( | ||
54 | - padding: EdgeInsets.fromLTRB(0.0, 8.0, 0.0, 8.0), | ||
55 | - itemCount: c.items.length, | ||
56 | - itemBuilder: (context, index) { | ||
57 | - return ListTile( | ||
58 | - title: Text(c.items[index].title), | ||
59 | - ); | ||
60 | - })); | ||
61 | - } | ||
62 | -} |
lib/_mobx/_store.dart
deleted
100644 → 0
1 | -import 'package:benckmark/item.dart'; | ||
2 | -import 'package:mobx/mobx.dart'; | ||
3 | - | ||
4 | -part '_store.g.dart'; | ||
5 | - | ||
6 | -class AppStore = _AppStore with _$AppStore; | ||
7 | - | ||
8 | -abstract class _AppStore with Store { | ||
9 | - @observable | ||
10 | - ObservableList<Item> items = ObservableList<Item>.of(sampleItems); | ||
11 | - | ||
12 | - @observable | ||
13 | - ObservableSet<String> checkedItemIds = ObservableSet<String>(); | ||
14 | - | ||
15 | - @action | ||
16 | - void addItem(Item item) { | ||
17 | - items.add(item); | ||
18 | - } | ||
19 | -} |
lib/_mobx/_store.g.dart
deleted
100644 → 0
1 | -// GENERATED CODE - DO NOT MODIFY BY HAND | ||
2 | - | ||
3 | -part of '_store.dart'; | ||
4 | - | ||
5 | -// ************************************************************************** | ||
6 | -// StoreGenerator | ||
7 | -// ************************************************************************** | ||
8 | - | ||
9 | -// ignore_for_file: non_constant_identifier_names, unnecessary_lambdas, prefer_expression_function_bodies, lines_longer_than_80_chars, avoid_as, avoid_annotating_with_dynamic | ||
10 | - | ||
11 | -mixin _$AppStore on _AppStore, Store { | ||
12 | - final _$itemsAtom = Atom(name: '_AppStore.items'); | ||
13 | - | ||
14 | - @override | ||
15 | - ObservableList<Item> get items { | ||
16 | - _$itemsAtom.context.enforceReadPolicy(_$itemsAtom); | ||
17 | - _$itemsAtom.reportObserved(); | ||
18 | - return super.items; | ||
19 | - } | ||
20 | - | ||
21 | - @override | ||
22 | - set items(ObservableList<Item> value) { | ||
23 | - _$itemsAtom.context.conditionallyRunInAction(() { | ||
24 | - super.items = value; | ||
25 | - _$itemsAtom.reportChanged(); | ||
26 | - }, _$itemsAtom, name: '${_$itemsAtom.name}_set'); | ||
27 | - } | ||
28 | - | ||
29 | - final _$checkedItemIdsAtom = Atom(name: '_AppStore.checkedItemIds'); | ||
30 | - | ||
31 | - @override | ||
32 | - ObservableSet<String> get checkedItemIds { | ||
33 | - _$checkedItemIdsAtom.context.enforceReadPolicy(_$checkedItemIdsAtom); | ||
34 | - _$checkedItemIdsAtom.reportObserved(); | ||
35 | - return super.checkedItemIds; | ||
36 | - } | ||
37 | - | ||
38 | - @override | ||
39 | - set checkedItemIds(ObservableSet<String> value) { | ||
40 | - _$checkedItemIdsAtom.context.conditionallyRunInAction(() { | ||
41 | - super.checkedItemIds = value; | ||
42 | - _$checkedItemIdsAtom.reportChanged(); | ||
43 | - }, _$checkedItemIdsAtom, name: '${_$checkedItemIdsAtom.name}_set'); | ||
44 | - } | ||
45 | - | ||
46 | - final _$_AppStoreActionController = ActionController(name: '_AppStore'); | ||
47 | - | ||
48 | - @override | ||
49 | - void addItem(Item item) { | ||
50 | - final _$actionInfo = _$_AppStoreActionController.startAction(); | ||
51 | - try { | ||
52 | - return super.addItem(item); | ||
53 | - } finally { | ||
54 | - _$_AppStoreActionController.endAction(_$actionInfo); | ||
55 | - } | ||
56 | - } | ||
57 | -} |
lib/_mobx/app.dart
deleted
100644 → 0
1 | -import 'package:flutter/material.dart'; | ||
2 | -import 'package:flutter_mobx/flutter_mobx.dart'; | ||
3 | -import 'package:benckmark/_mobx/_store.dart'; | ||
4 | -import 'package:benckmark/item.dart'; | ||
5 | - | ||
6 | -final store = AppStore(); | ||
7 | - | ||
8 | -class App extends StatelessWidget { | ||
9 | - @override | ||
10 | - Widget build(BuildContext context) { | ||
11 | - return MaterialApp( | ||
12 | - title: 'MobX Sample', | ||
13 | - theme: ThemeData( | ||
14 | - primarySwatch: Colors.blue, | ||
15 | - ), | ||
16 | - home: Page(title: 'MobX Sample'), | ||
17 | - ); | ||
18 | - } | ||
19 | -} | ||
20 | - | ||
21 | -class Page extends StatefulWidget { | ||
22 | - Page({ | ||
23 | - Key key, | ||
24 | - this.title, | ||
25 | - }) : super(key: key); | ||
26 | - | ||
27 | - final String title; | ||
28 | - | ||
29 | - @override | ||
30 | - _PageState createState() => _PageState(); | ||
31 | -} | ||
32 | - | ||
33 | -class _PageState extends State<Page> { | ||
34 | - @override | ||
35 | - void initState() { | ||
36 | - fill(); | ||
37 | - super.initState(); | ||
38 | - } | ||
39 | - | ||
40 | - fill() async { | ||
41 | - for (int i = 0; i < 10; i++) { | ||
42 | - await Future.delayed(Duration(milliseconds: 500)); | ||
43 | - store.addItem(Item(title: DateTime.now().toString())); | ||
44 | - } | ||
45 | - print("It's done. Print now!"); | ||
46 | - } | ||
47 | - | ||
48 | - @override | ||
49 | - Widget build(BuildContext context) { | ||
50 | - return Scaffold( | ||
51 | - appBar: AppBar( | ||
52 | - title: Text(widget.title), | ||
53 | - ), | ||
54 | - body: ListViewWidget(), | ||
55 | - ); | ||
56 | - } | ||
57 | -} | ||
58 | - | ||
59 | -class ListViewWidget extends StatelessWidget { | ||
60 | - @override | ||
61 | - Widget build(BuildContext context) { | ||
62 | - return Observer( | ||
63 | - builder: (_) { | ||
64 | - return ListView.builder( | ||
65 | - padding: EdgeInsets.fromLTRB(0.0, 8.0, 0.0, 8.0), | ||
66 | - itemCount: store.items.length, | ||
67 | - itemBuilder: (context, index) { | ||
68 | - return ListTile( | ||
69 | - title: Text(store.items[index].title), | ||
70 | - ); | ||
71 | - }, | ||
72 | - ); | ||
73 | - }, | ||
74 | - ); | ||
75 | - } | ||
76 | -} |
lib/_provider/_state.dart
deleted
100644 → 0
1 | -import 'package:flutter/foundation.dart'; | ||
2 | -import 'package:benckmark/item.dart'; | ||
3 | - | ||
4 | -class AppState with ChangeNotifier { | ||
5 | - List<Item> _items = sampleItems; | ||
6 | - | ||
7 | - List<Item> get items => _items; | ||
8 | - | ||
9 | - void addItem(Item item) { | ||
10 | - _items.add(item); | ||
11 | - | ||
12 | - notifyListeners(); | ||
13 | - } | ||
14 | -} |
lib/_provider/app.dart
deleted
100644 → 0
1 | -import 'package:flutter/material.dart'; | ||
2 | -import 'package:flutter/scheduler.dart'; | ||
3 | -import 'package:benckmark/item.dart'; | ||
4 | -import 'package:provider/provider.dart'; | ||
5 | - | ||
6 | -import '_state.dart'; | ||
7 | - | ||
8 | -class App extends StatelessWidget { | ||
9 | - @override | ||
10 | - Widget build(BuildContext context) { | ||
11 | - return ChangeNotifierProvider( | ||
12 | - create: (context) => AppState(), | ||
13 | - child: MaterialApp( | ||
14 | - title: 'Provider Sample', | ||
15 | - theme: ThemeData( | ||
16 | - primarySwatch: Colors.blue, | ||
17 | - ), | ||
18 | - home: Page(title: 'Provider Sample'), | ||
19 | - ), | ||
20 | - ); | ||
21 | - } | ||
22 | -} | ||
23 | - | ||
24 | -class Page extends StatefulWidget { | ||
25 | - Page({ | ||
26 | - Key key, | ||
27 | - this.title, | ||
28 | - }) : super(key: key); | ||
29 | - | ||
30 | - final String title; | ||
31 | - | ||
32 | - @override | ||
33 | - _PageState createState() => _PageState(); | ||
34 | -} | ||
35 | - | ||
36 | -class _PageState extends State<Page> { | ||
37 | - @override | ||
38 | - void initState() { | ||
39 | - SchedulerBinding.instance.addPostFrameCallback((timeStamp) async { | ||
40 | - for (int i = 0; i < 10; i++) { | ||
41 | - await Future.delayed(Duration(milliseconds: 500)); | ||
42 | - final state = Provider.of<AppState>(context, listen: false); | ||
43 | - state.addItem(Item(title: DateTime.now().toString())); | ||
44 | - } | ||
45 | - print("It's done. Print now!"); | ||
46 | - }); | ||
47 | - super.initState(); | ||
48 | - } | ||
49 | - | ||
50 | - @override | ||
51 | - Widget build(BuildContext context) { | ||
52 | - return Scaffold( | ||
53 | - appBar: AppBar( | ||
54 | - title: Text(widget.title), | ||
55 | - ), | ||
56 | - body: ListViewWidget(), | ||
57 | - ); | ||
58 | - } | ||
59 | -} | ||
60 | - | ||
61 | -class ListViewWidget extends StatelessWidget { | ||
62 | - @override | ||
63 | - Widget build(BuildContext context) { | ||
64 | - return Consumer<AppState>( | ||
65 | - builder: (context, state, child) { | ||
66 | - return ListView.builder( | ||
67 | - padding: EdgeInsets.fromLTRB(0.0, 8.0, 0.0, 8.0), | ||
68 | - itemCount: state.items.length, | ||
69 | - itemBuilder: (context, index) { | ||
70 | - return ListTile( | ||
71 | - title: Text(state.items[index].title), | ||
72 | - ); | ||
73 | - }, | ||
74 | - ); | ||
75 | - }, | ||
76 | - ); | ||
77 | - } | ||
78 | -} |
lib/_redux/_store.dart
deleted
100644 → 0
1 | -import 'package:benckmark/item.dart'; | ||
2 | -import 'package:meta/meta.dart'; | ||
3 | - | ||
4 | -@immutable | ||
5 | -class AppState { | ||
6 | - final List<Item> items; | ||
7 | - | ||
8 | - AppState({ | ||
9 | - this.items, | ||
10 | - }); | ||
11 | - | ||
12 | - AppState.initialState() : items = sampleItems; | ||
13 | -} | ||
14 | - | ||
15 | -class AddItemAction { | ||
16 | - Item payload; | ||
17 | - | ||
18 | - AddItemAction({ | ||
19 | - this.payload, | ||
20 | - }); | ||
21 | -} | ||
22 | - | ||
23 | -AppState appReducer(AppState state, dynamic action) { | ||
24 | - return AppState(items: itemsReducer(state.items, action)); | ||
25 | -} | ||
26 | - | ||
27 | -List<Item> itemsReducer(List<Item> state, dynamic action) { | ||
28 | - if (action is AddItemAction) { | ||
29 | - return [...state, action.payload]; | ||
30 | - } | ||
31 | - | ||
32 | - return state; | ||
33 | -} |
lib/_redux/app.dart
deleted
100644 → 0
1 | -import 'package:flutter/material.dart'; | ||
2 | -import 'package:flutter_redux/flutter_redux.dart'; | ||
3 | -import 'package:benckmark/item.dart'; | ||
4 | -import 'package:redux/redux.dart'; | ||
5 | -import '_store.dart'; | ||
6 | - | ||
7 | -final store = | ||
8 | - Store<AppState>(appReducer, initialState: AppState.initialState()); | ||
9 | - | ||
10 | -class App extends StatelessWidget { | ||
11 | - @override | ||
12 | - Widget build(BuildContext context) { | ||
13 | - return StoreProvider<AppState>( | ||
14 | - store: store, | ||
15 | - child: MaterialApp( | ||
16 | - title: 'Redux Sample', | ||
17 | - theme: ThemeData( | ||
18 | - primarySwatch: Colors.blue, | ||
19 | - ), | ||
20 | - home: Page(title: 'Redux Sample'), | ||
21 | - ), | ||
22 | - ); | ||
23 | - } | ||
24 | -} | ||
25 | - | ||
26 | -class Page extends StatefulWidget { | ||
27 | - Page({ | ||
28 | - Key key, | ||
29 | - this.title, | ||
30 | - }) : super(key: key); | ||
31 | - | ||
32 | - final String title; | ||
33 | - | ||
34 | - @override | ||
35 | - _PageState createState() => _PageState(); | ||
36 | -} | ||
37 | - | ||
38 | -class _PageState extends State<Page> { | ||
39 | - @override | ||
40 | - void initState() { | ||
41 | - super.initState(); | ||
42 | - fill(); | ||
43 | - } | ||
44 | - | ||
45 | - fill() async { | ||
46 | - for (int i = 0; i < 10; i++) { | ||
47 | - await Future.delayed(Duration(milliseconds: 500)); | ||
48 | - store.dispatch( | ||
49 | - AddItemAction(payload: Item(title: DateTime.now().toString()))); | ||
50 | - } | ||
51 | - print("It's done. Print now!"); | ||
52 | - } | ||
53 | - | ||
54 | - @override | ||
55 | - Widget build(BuildContext context) { | ||
56 | - return Scaffold( | ||
57 | - appBar: AppBar( | ||
58 | - title: Text(widget.title), | ||
59 | - ), | ||
60 | - body: ListViewWidget(), | ||
61 | - ); | ||
62 | - } | ||
63 | -} | ||
64 | - | ||
65 | -class ListViewWidget extends StatelessWidget { | ||
66 | - @override | ||
67 | - Widget build(BuildContext context) { | ||
68 | - return StoreConnector<AppState, List<Item>>( | ||
69 | - converter: (store) => store.state.items, | ||
70 | - builder: (context, items) { | ||
71 | - return ListView.builder( | ||
72 | - padding: EdgeInsets.fromLTRB(0.0, 8.0, 0.0, 8.0), | ||
73 | - itemCount: items.length, | ||
74 | - itemBuilder: (context, index) { | ||
75 | - return ListTile( | ||
76 | - title: Text(items[index].title), | ||
77 | - ); | ||
78 | - }, | ||
79 | - ); | ||
80 | - }, | ||
81 | - ); | ||
82 | - } | ||
83 | -} |
lib/item.dart
deleted
100644 → 0
lib/main.dart
deleted
100644 → 0
1 | -import 'package:flutter/material.dart'; | ||
2 | - | ||
3 | -import 'package:benckmark/_bloc_plain/app.dart'; | ||
4 | -//import 'package:benckmark/_bloc_lib/app.dart'; | ||
5 | -//import 'package:benckmark/_mobx/app.dart'; | ||
6 | -//import 'package:benckmark/_redux/app.dart'; | ||
7 | -//import 'package:benckmark/_get_rx/app.dart'; | ||
8 | - | ||
9 | -//import 'package:benckmark/_provider/app.dart'; | ||
10 | -//import 'package:benckmark/_get/app.dart'; | ||
11 | - | ||
12 | -void main() => runApp(App()); |
test/widget_test.dart
deleted
100644 → 0
1 | -// This is a basic Flutter widget test. | ||
2 | -// To perform an interaction with a widget in your test, use the WidgetTester utility that Flutter | ||
3 | -// provides. For example, you can send tap and scroll gestures. You can also use WidgetTester to | ||
4 | -// find child widgets in the widget tree, read text, and verify that the values of widget properties | ||
5 | -// are correct. | ||
6 | - | ||
7 | -import 'package:flutter/material.dart'; | ||
8 | -import 'package:benckmark/_redux/app.dart'; | ||
9 | -import 'package:flutter_test/flutter_test.dart'; | ||
10 | - | ||
11 | -void main() { | ||
12 | - testWidgets('Counter increments smoke test', (WidgetTester tester) async { | ||
13 | - // Build our app and trigger a frame. | ||
14 | - await tester.pumpWidget(App()); | ||
15 | - | ||
16 | - // Verify that our counter starts at 0. | ||
17 | - expect(find.text('0'), findsOneWidget); | ||
18 | - expect(find.text('1'), findsNothing); | ||
19 | - | ||
20 | - // Tap the '+' icon and trigger a frame. | ||
21 | - await tester.tap(find.byIcon(Icons.add)); | ||
22 | - await tester.pump(); | ||
23 | - | ||
24 | - // Verify that our counter has incremented. | ||
25 | - expect(find.text('0'), findsNothing); | ||
26 | - expect(find.text('1'), findsOneWidget); | ||
27 | - }); | ||
28 | -} |
-
Please register or login to post a comment