├── .github
    └── workflows
    │   └── dart.yml
├── .gitignore
├── .metadata
├── README.md
├── analysis_options.yaml
├── android
    ├── .gitignore
    ├── app
    │   ├── build.gradle
    │   └── src
    │   │   ├── debug
    │   │       └── AndroidManifest.xml
    │   │   ├── main
    │   │       ├── AndroidManifest.xml
    │   │       ├── kotlin
    │   │       │   └── com
    │   │       │   │   └── example
    │   │       │   │       └── rest_api_test
    │   │       │   │           └── MainActivity.kt
    │   │       └── res
    │   │       │   ├── drawable-v21
    │   │       │       └── launch_background.xml
    │   │       │   ├── drawable
    │   │       │       └── launch_background.xml
    │   │       │   ├── mipmap-hdpi
    │   │       │       └── ic_launcher.png
    │   │       │   ├── mipmap-mdpi
    │   │       │       └── ic_launcher.png
    │   │       │   ├── mipmap-xhdpi
    │   │       │       └── ic_launcher.png
    │   │       │   ├── mipmap-xxhdpi
    │   │       │       └── ic_launcher.png
    │   │       │   ├── mipmap-xxxhdpi
    │   │       │       └── ic_launcher.png
    │   │       │   ├── values-night
    │   │       │       └── styles.xml
    │   │       │   └── values
    │   │       │       └── styles.xml
    │   │   └── profile
    │   │       └── AndroidManifest.xml
    ├── build.gradle
    ├── gradle.properties
    ├── gradle
    │   └── wrapper
    │   │   └── gradle-wrapper.properties
    └── settings.gradle
├── assets
    └── .env.dev
├── ios
    ├── .gitignore
    ├── Flutter
    │   ├── AppFrameworkInfo.plist
    │   ├── Debug.xcconfig
    │   └── Release.xcconfig
    ├── Podfile
    ├── Podfile.lock
    ├── Runner.xcodeproj
    │   ├── project.pbxproj
    │   ├── project.xcworkspace
    │   │   ├── contents.xcworkspacedata
    │   │   └── xcshareddata
    │   │   │   ├── IDEWorkspaceChecks.plist
    │   │   │   └── WorkspaceSettings.xcsettings
    │   └── xcshareddata
    │   │   └── xcschemes
    │   │       └── Runner.xcscheme
    ├── Runner.xcworkspace
    │   ├── contents.xcworkspacedata
    │   └── xcshareddata
    │   │   ├── IDEWorkspaceChecks.plist
    │   │   └── WorkspaceSettings.xcsettings
    └── Runner
    │   ├── AppDelegate.swift
    │   ├── Assets.xcassets
    │       ├── AppIcon.appiconset
    │       │   ├── Contents.json
    │       │   ├── Icon-App-1024x1024@1x.png
    │       │   ├── Icon-App-20x20@1x.png
    │       │   ├── Icon-App-20x20@2x.png
    │       │   ├── Icon-App-20x20@3x.png
    │       │   ├── Icon-App-29x29@1x.png
    │       │   ├── Icon-App-29x29@2x.png
    │       │   ├── Icon-App-29x29@3x.png
    │       │   ├── Icon-App-40x40@1x.png
    │       │   ├── Icon-App-40x40@2x.png
    │       │   ├── Icon-App-40x40@3x.png
    │       │   ├── Icon-App-60x60@2x.png
    │       │   ├── Icon-App-60x60@3x.png
    │       │   ├── Icon-App-76x76@1x.png
    │       │   ├── Icon-App-76x76@2x.png
    │       │   └── Icon-App-83.5x83.5@2x.png
    │       └── LaunchImage.imageset
    │       │   ├── Contents.json
    │       │   ├── LaunchImage.png
    │       │   ├── LaunchImage@2x.png
    │       │   ├── LaunchImage@3x.png
    │       │   └── README.md
    │   ├── Base.lproj
    │       ├── LaunchScreen.storyboard
    │       └── Main.storyboard
    │   ├── Info.plist
    │   └── Runner-Bridging-Header.h
├── lib
    ├── bindings
    │   ├── bindings.dart
    │   ├── home_screen_binding.dart
    │   └── initial_binding.dart
    ├── controllers
    │   ├── controllers.dart
    │   ├── detail_screen_controller.dart
    │   └── home_screen_controller.dart
    ├── core
    │   ├── src
    │   │   └── const.dart
    │   └── utils
    │   │   └── toast.dart
    ├── main.dart
    ├── models
    │   ├── category.dart
    │   ├── models.dart
    │   └── recipe.dart
    ├── providers
    │   └── api_provider
    │   │   ├── api_provider.dart
    │   │   ├── api_providers.dart
    │   │   ├── apis.dart
    │   │   ├── base_provider.dart
    │   │   └── exceptions.dart
    ├── repositories
    │   ├── recipes_repository.dart
    │   └── repositories.dart
    ├── router
    │   ├── app_pages.dart
    │   └── app_routes.dart
    └── views
    │   ├── details
    │       ├── screens
    │       │   └── details_screen.dart
    │       └── widgets
    │       │   └── single_recipe.dart
    │   └── home
    │       ├── screens
    │           └── home_screen.dart
    │       └── widgets
    │           └── single_cateogry_widget.dart
├── pubspec.lock
├── pubspec.yaml
├── test
    └── widget_test.dart
└── web
    ├── favicon.png
    ├── icons
        ├── Icon-192.png
        ├── Icon-512.png
        ├── Icon-maskable-192.png
        └── Icon-maskable-512.png
    ├── index.html
    └── manifest.json
/.github/workflows/dart.yml:
--------------------------------------------------------------------------------
 1 | # This workflow uses actions that are not certified by GitHub.
 2 | # They are provided by a third-party and are governed by
 3 | # separate terms of service, privacy policy, and support
 4 | # documentation.
 5 | 
 6 | name: Dart
 7 | 
 8 | on:
 9 |   push:
10 |     branches: [ main ]
11 |   pull_request:
12 |     branches: [ main ]
13 | 
14 | jobs:
15 |   build:
16 |     runs-on: ubuntu-latest
17 | 
18 |     steps:
19 |       - uses: actions/checkout@v2
20 | 
21 |       # Note: This workflow uses the latest stable version of the Dart SDK.
22 |       # You can specify other versions if desired, see documentation here:
23 |       # https://github.com/dart-lang/setup-dart/blob/main/README.md
24 |       # - uses: dart-lang/setup-dart@v1
25 |       - uses: dart-lang/setup-dart@9a04e6d73cca37bd455e0608d7e5092f881fd603
26 | 
27 |       - name: Install dependencies
28 |         run: dart pub get
29 | 
30 |       # Uncomment this step to verify the use of 'dart format' on each commit.
31 |       # - name: Verify formatting
32 |       #   run: dart format --output=none --set-exit-if-changed .
33 | 
34 |       # Consider passing '--fatal-infos' for slightly stricter analysis.
35 |       - name: Analyze project source
36 |         run: dart analyze
37 | 
38 |       # Your project will need to have tests in test/ and a dependency on
39 |       # package:test for this step to succeed. Note that Flutter projects will
40 |       # want to change this to 'flutter test'.
41 |       - name: Run tests
42 |         run: dart test
43 | 
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
 1 | # Miscellaneous
 2 | *.class
 3 | *.log
 4 | *.pyc
 5 | *.swp
 6 | .DS_Store
 7 | .atom/
 8 | .buildlog/
 9 | .history
10 | .svn/
11 | 
12 | # IntelliJ related
13 | *.iml
14 | *.ipr
15 | *.iws
16 | .idea/
17 | 
18 | # The .vscode folder contains launch configuration and tasks you configure in
19 | # VS Code which you may wish to be included in version control, so this line
20 | # is commented out by default.
21 | #.vscode/
22 | 
23 | # Flutter/Dart/Pub related
24 | **/doc/api/
25 | **/ios/Flutter/.last_build_id
26 | .dart_tool/
27 | .flutter-plugins
28 | .flutter-plugins-dependencies
29 | .packages
30 | .pub-cache/
31 | .pub/
32 | /build/
33 | 
34 | # Web related
35 | lib/generated_plugin_registrant.dart
36 | 
37 | # Symbolication related
38 | app.*.symbols
39 | 
40 | # Obfuscation related
41 | app.*.map.json
42 | 
43 | # Android Studio will place build artifacts here
44 | /android/app/debug
45 | /android/app/profile
46 | /android/app/release
47 | 
--------------------------------------------------------------------------------
/.metadata:
--------------------------------------------------------------------------------
 1 | # This file tracks properties of this Flutter project.
 2 | # Used by Flutter tool to assess capabilities and perform upgrades etc.
 3 | #
 4 | # This file should be version controlled and should not be manually edited.
 5 | 
 6 | version:
 7 |   revision: 77d935af4db863f6abd0b9c31c7e6df2a13de57b
 8 |   channel: stable
 9 | 
10 | project_type: app
11 | 
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
 1 | # rest_api_test
 2 | 
 3 | A new Flutter project.
 4 | 
 5 | ## Getting Started
 6 | 
 7 | This project is a starting point for a Flutter application.
 8 | 
 9 | A few resources to get you started if this is your first Flutter project:
10 | 
11 | - [Lab: Write your first Flutter app](https://flutter.dev/docs/get-started/codelab)
12 | - [Cookbook: Useful Flutter samples](https://flutter.dev/docs/cookbook)
13 | 
14 | For help getting started with Flutter, view our
15 | [online documentation](https://flutter.dev/docs), which offers tutorials,
16 | samples, guidance on mobile development, and a full API reference.
17 | 
--------------------------------------------------------------------------------
/analysis_options.yaml:
--------------------------------------------------------------------------------
 1 | # This file configures the analyzer, which statically analyzes Dart code to
 2 | # check for errors, warnings, and lints.
 3 | #
 4 | # The issues identified by the analyzer are surfaced in the UI of Dart-enabled
 5 | # IDEs (https://dart.dev/tools#ides-and-editors). The analyzer can also be
 6 | # invoked from the command line by running `flutter analyze`.
 7 | 
 8 | # The following line activates a set of recommended lints for Flutter apps,
 9 | # packages, and plugins designed to encourage good coding practices.
10 | include: package:flutter_lints/flutter.yaml
11 | 
12 | linter:
13 |   # The lint rules applied to this project can be customized in the
14 |   # section below to disable rules from the `package:flutter_lints/flutter.yaml`
15 |   # included above or to enable additional rules. A list of all available lints
16 |   # and their documentation is published at
17 |   # https://dart-lang.github.io/linter/lints/index.html.
18 |   #
19 |   # Instead of disabling a lint rule for the entire project in the
20 |   # section below, it can also be suppressed for a single line of code
21 |   # or a specific dart file by using the `// ignore: name_of_lint` and
22 |   # `// ignore_for_file: name_of_lint` syntax on the line or in the file
23 |   # producing the lint.
24 |   rules:
25 |     # avoid_print: false  # Uncomment to disable the `avoid_print` rule
26 |     # prefer_single_quotes: true  # Uncomment to enable the `prefer_single_quotes` rule
27 | 
28 | # Additional information about this file can be found at
29 | # https://dart.dev/guides/language/analysis-options
30 | 
--------------------------------------------------------------------------------
/android/.gitignore:
--------------------------------------------------------------------------------
 1 | gradle-wrapper.jar
 2 | /.gradle
 3 | /captures/
 4 | /gradlew
 5 | /gradlew.bat
 6 | /local.properties
 7 | GeneratedPluginRegistrant.java
 8 | 
 9 | # Remember to never publicly share your keystore.
10 | # See https://flutter.dev/docs/deployment/android#reference-the-keystore-from-the-app
11 | key.properties
12 | **/*.keystore
13 | **/*.jks
14 | 
--------------------------------------------------------------------------------
/android/app/build.gradle:
--------------------------------------------------------------------------------
 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 | def flutterVersionCode = localProperties.getProperty('flutter.versionCode')
15 | if (flutterVersionCode == null) {
16 |     flutterVersionCode = '1'
17 | }
18 | 
19 | def flutterVersionName = localProperties.getProperty('flutter.versionName')
20 | if (flutterVersionName == null) {
21 |     flutterVersionName = '1.0'
22 | }
23 | 
24 | apply plugin: 'com.android.application'
25 | apply plugin: 'kotlin-android'
26 | apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"
27 | 
28 | android {
29 |     compileSdkVersion flutter.compileSdkVersion
30 | 
31 |     compileOptions {
32 |         sourceCompatibility JavaVersion.VERSION_1_8
33 |         targetCompatibility JavaVersion.VERSION_1_8
34 |     }
35 | 
36 |     kotlinOptions {
37 |         jvmTarget = '1.8'
38 |     }
39 | 
40 |     sourceSets {
41 |         main.java.srcDirs += 'src/main/kotlin'
42 |     }
43 | 
44 |     defaultConfig {
45 |         // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
46 |         applicationId "com.example.rest_api_test"
47 |         minSdkVersion flutter.minSdkVersion
48 |         targetSdkVersion flutter.targetSdkVersion
49 |         versionCode flutterVersionCode.toInteger()
50 |         versionName flutterVersionName
51 |     }
52 | 
53 |     buildTypes {
54 |         release {
55 |             // TODO: Add your own signing config for the release build.
56 |             // Signing with the debug keys for now, so `flutter run --release` works.
57 |             signingConfig signingConfigs.debug
58 |         }
59 |     }
60 | }
61 | 
62 | flutter {
63 |     source '../..'
64 | }
65 | 
66 | dependencies {
67 |     implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
68 | }
69 | 
--------------------------------------------------------------------------------
/android/app/src/debug/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 | 
3 |     
6 |     
7 | 
8 | 
--------------------------------------------------------------------------------
/android/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
 1 | 
 3 |    
 7 |         
15 |             
19 |             
23 |             
24 |                 
25 |                 
26 |             
27 |         
28 |         
30 |         
33 |     
34 | 
35 | 
--------------------------------------------------------------------------------
/android/app/src/main/kotlin/com/example/rest_api_test/MainActivity.kt:
--------------------------------------------------------------------------------
1 | package com.example.rest_api_test
2 | 
3 | import io.flutter.embedding.android.FlutterActivity
4 | 
5 | class MainActivity: FlutterActivity() {
6 | }
7 | 
--------------------------------------------------------------------------------
/android/app/src/main/res/drawable-v21/launch_background.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 | 
 4 |     5 | 
 6 |     
 7 |     
12 | 
13 | 
--------------------------------------------------------------------------------
/android/app/src/main/res/drawable/launch_background.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 | 
 4 |
5 | 
 6 |     
 7 |     
12 | 
13 | 
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/values-night/styles.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 |     
 4 |     
 9 |     
15 |     
18 | 
19 | 
--------------------------------------------------------------------------------
/android/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 |     
 4 |     
 9 |     
15 |     
18 | 
19 | 
--------------------------------------------------------------------------------
/android/app/src/profile/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 | 
3 |     
6 |     
7 | 
8 | 
--------------------------------------------------------------------------------
/android/build.gradle:
--------------------------------------------------------------------------------
 1 | buildscript {
 2 |     ext.kotlin_version = '1.3.50'
 3 |     repositories {
 4 |         google()
 5 |         mavenCentral()
 6 |     }
 7 | 
 8 |     dependencies {
 9 |         classpath 'com.android.tools.build:gradle:4.1.0'
10 |         classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
11 |     }
12 | }
13 | 
14 | allprojects {
15 |     repositories {
16 |         google()
17 |         mavenCentral()
18 |     }
19 | }
20 | 
21 | rootProject.buildDir = '../build'
22 | subprojects {
23 |     project.buildDir = "${rootProject.buildDir}/${project.name}"
24 | }
25 | subprojects {
26 |     project.evaluationDependsOn(':app')
27 | }
28 | 
29 | task clean(type: Delete) {
30 |     delete rootProject.buildDir
31 | }
32 | 
--------------------------------------------------------------------------------
/android/gradle.properties:
--------------------------------------------------------------------------------
1 | org.gradle.jvmargs=-Xmx1536M
2 | android.useAndroidX=true
3 | android.enableJetifier=true
4 | 
--------------------------------------------------------------------------------
/android/gradle/wrapper/gradle-wrapper.properties:
--------------------------------------------------------------------------------
1 | #Fri Jun 23 08:50:38 CEST 2017
2 | distributionBase=GRADLE_USER_HOME
3 | distributionPath=wrapper/dists
4 | zipStoreBase=GRADLE_USER_HOME
5 | zipStorePath=wrapper/dists
6 | distributionUrl=https\://services.gradle.org/distributions/gradle-6.7-all.zip
7 | 
--------------------------------------------------------------------------------
/android/settings.gradle:
--------------------------------------------------------------------------------
 1 | include ':app'
 2 | 
 3 | def localPropertiesFile = new File(rootProject.projectDir, "local.properties")
 4 | def properties = new Properties()
 5 | 
 6 | assert localPropertiesFile.exists()
 7 | localPropertiesFile.withReader("UTF-8") { reader -> properties.load(reader) }
 8 | 
 9 | def flutterSdkPath = properties.getProperty("flutter.sdk")
10 | assert flutterSdkPath != null, "flutter.sdk not set in local.properties"
11 | apply from: "$flutterSdkPath/packages/flutter_tools/gradle/app_plugin_loader.gradle"
12 | 
--------------------------------------------------------------------------------
/assets/.env.dev:
--------------------------------------------------------------------------------
1 | API_KEY = 49694fc808msh9f07b135ef73ca9p1b9e39jsn1e3c7fd9d297
2 | API_SERVER_HOST = https://cooking-recipe2.p.rapidapi.com
--------------------------------------------------------------------------------
/ios/.gitignore:
--------------------------------------------------------------------------------
 1 | **/dgph
 2 | *.mode1v3
 3 | *.mode2v3
 4 | *.moved-aside
 5 | *.pbxuser
 6 | *.perspectivev3
 7 | **/*sync/
 8 | .sconsign.dblite
 9 | .tags*
10 | **/.vagrant/
11 | **/DerivedData/
12 | Icon?
13 | **/Pods/
14 | **/.symlinks/
15 | profile
16 | xcuserdata
17 | **/.generated/
18 | Flutter/App.framework
19 | Flutter/Flutter.framework
20 | Flutter/Flutter.podspec
21 | Flutter/Generated.xcconfig
22 | Flutter/ephemeral/
23 | Flutter/app.flx
24 | Flutter/app.zip
25 | Flutter/flutter_assets/
26 | Flutter/flutter_export_environment.sh
27 | ServiceDefinitions.json
28 | Runner/GeneratedPluginRegistrant.*
29 | 
30 | # Exceptions to above rules.
31 | !default.mode1v3
32 | !default.mode2v3
33 | !default.pbxuser
34 | !default.perspectivev3
35 | 
--------------------------------------------------------------------------------
/ios/Flutter/AppFrameworkInfo.plist:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 | 
 4 | 
 5 |   CFBundleDevelopmentRegion
 6 |   en
 7 |   CFBundleExecutable
 8 |   App
 9 |   CFBundleIdentifier
10 |   io.flutter.flutter.app
11 |   CFBundleInfoDictionaryVersion
12 |   6.0
13 |   CFBundleName
14 |   App
15 |   CFBundlePackageType
16 |   FMWK
17 |   CFBundleShortVersionString
18 |   1.0
19 |   CFBundleSignature
20 |   ????
21 |   CFBundleVersion
22 |   1.0
23 |   MinimumOSVersion
24 |   9.0
25 | 
26 | 
27 | 
--------------------------------------------------------------------------------
/ios/Flutter/Debug.xcconfig:
--------------------------------------------------------------------------------
1 | #include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"
2 | #include "Generated.xcconfig"
3 | 
--------------------------------------------------------------------------------
/ios/Flutter/Release.xcconfig:
--------------------------------------------------------------------------------
1 | #include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"
2 | #include "Generated.xcconfig"
3 | 
--------------------------------------------------------------------------------
/ios/Podfile:
--------------------------------------------------------------------------------
 1 | # Uncomment this line to define a global platform for your project
 2 | # platform :ios, '9.0'
 3 | 
 4 | # CocoaPods analytics sends network stats synchronously affecting flutter build latency.
 5 | ENV['COCOAPODS_DISABLE_STATS'] = 'true'
 6 | 
 7 | project 'Runner', {
 8 |   'Debug' => :debug,
 9 |   'Profile' => :release,
10 |   'Release' => :release,
11 | }
12 | 
13 | def flutter_root
14 |   generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'Generated.xcconfig'), __FILE__)
15 |   unless File.exist?(generated_xcode_build_settings_path)
16 |     raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure flutter pub get is executed first"
17 |   end
18 | 
19 |   File.foreach(generated_xcode_build_settings_path) do |line|
20 |     matches = line.match(/FLUTTER_ROOT\=(.*)/)
21 |     return matches[1].strip if matches
22 |   end
23 |   raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Generated.xcconfig, then run flutter pub get"
24 | end
25 | 
26 | require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root)
27 | 
28 | flutter_ios_podfile_setup
29 | 
30 | target 'Runner' do
31 |   use_frameworks!
32 |   use_modular_headers!
33 | 
34 |   flutter_install_all_ios_pods File.dirname(File.realpath(__FILE__))
35 | end
36 | 
37 | post_install do |installer|
38 |   installer.pods_project.targets.each do |target|
39 |     flutter_additional_ios_build_settings(target)
40 |   end
41 | end
42 | 
--------------------------------------------------------------------------------
/ios/Podfile.lock:
--------------------------------------------------------------------------------
 1 | PODS:
 2 |   - Flutter (1.0.0)
 3 |   - fluttertoast (0.0.2):
 4 |     - Flutter
 5 |     - Toast
 6 |   - Toast (4.0.0)
 7 | 
 8 | DEPENDENCIES:
 9 |   - Flutter (from `Flutter`)
10 |   - fluttertoast (from `.symlinks/plugins/fluttertoast/ios`)
11 | 
12 | SPEC REPOS:
13 |   trunk:
14 |     - Toast
15 | 
16 | EXTERNAL SOURCES:
17 |   Flutter:
18 |     :path: Flutter
19 |   fluttertoast:
20 |     :path: ".symlinks/plugins/fluttertoast/ios"
21 | 
22 | SPEC CHECKSUMS:
23 |   Flutter: 50d75fe2f02b26cc09d224853bb45737f8b3214a
24 |   fluttertoast: 6122fa75143e992b1d3470f61000f591a798cc58
25 |   Toast: 91b396c56ee72a5790816f40d3a94dd357abc196
26 | 
27 | PODFILE CHECKSUM: aafe91acc616949ddb318b77800a7f51bffa2a4c
28 | 
29 | COCOAPODS: 1.11.2
30 | 
--------------------------------------------------------------------------------
/ios/Runner.xcodeproj/project.pbxproj:
--------------------------------------------------------------------------------
  1 | // !$*UTF8*$!
  2 | {
  3 | 	archiveVersion = 1;
  4 | 	classes = {
  5 | 	};
  6 | 	objectVersion = 50;
  7 | 	objects = {
  8 | 
  9 | /* Begin PBXBuildFile section */
 10 | 		1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };
 11 | 		3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };
 12 | 		6C73F989FADDAE9240D5A25C /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = E9A421B079A365A0327B20BD /* Pods_Runner.framework */; };
 13 | 		74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; };
 14 | 		97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; };
 15 | 		97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; };
 16 | 		97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; };
 17 | /* End PBXBuildFile section */
 18 | 
 19 | /* Begin PBXCopyFilesBuildPhase section */
 20 | 		9705A1C41CF9048500538489 /* Embed Frameworks */ = {
 21 | 			isa = PBXCopyFilesBuildPhase;
 22 | 			buildActionMask = 2147483647;
 23 | 			dstPath = "";
 24 | 			dstSubfolderSpec = 10;
 25 | 			files = (
 26 | 			);
 27 | 			name = "Embed Frameworks";
 28 | 			runOnlyForDeploymentPostprocessing = 0;
 29 | 		};
 30 | /* End PBXCopyFilesBuildPhase section */
 31 | 
 32 | /* Begin PBXFileReference section */
 33 | 		1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = ""; };
 34 | 		1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = ""; };
 35 | 		3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = ""; };
 36 | 		74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = ""; };
 37 | 		74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; };
 38 | 		748C24E6897B2C1A10CB28B5 /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = ""; };
 39 | 		7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = ""; };
 40 | 		9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = ""; };
 41 | 		9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = ""; };
 42 | 		97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };
 43 | 		97C146FB1CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; };
 44 | 		97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; };
 45 | 		97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; };
 46 | 		97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
 47 | 		D096891D8198693EF8EEBF89 /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = ""; };
 48 | 		E9A421B079A365A0327B20BD /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; };
 49 | 		F73ADCA79EC47124BA98A3B6 /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = ""; };
 50 | /* End PBXFileReference section */
 51 | 
 52 | /* Begin PBXFrameworksBuildPhase section */
 53 | 		97C146EB1CF9000F007C117D /* Frameworks */ = {
 54 | 			isa = PBXFrameworksBuildPhase;
 55 | 			buildActionMask = 2147483647;
 56 | 			files = (
 57 | 				6C73F989FADDAE9240D5A25C /* Pods_Runner.framework in Frameworks */,
 58 | 			);
 59 | 			runOnlyForDeploymentPostprocessing = 0;
 60 | 		};
 61 | /* End PBXFrameworksBuildPhase section */
 62 | 
 63 | /* Begin PBXGroup section */
 64 | 		2CF1E5A6D4720A4FF3E35D8F /* Frameworks */ = {
 65 | 			isa = PBXGroup;
 66 | 			children = (
 67 | 				E9A421B079A365A0327B20BD /* Pods_Runner.framework */,
 68 | 			);
 69 | 			name = Frameworks;
 70 | 			sourceTree = "";
 71 | 		};
 72 | 		9740EEB11CF90186004384FC /* Flutter */ = {
 73 | 			isa = PBXGroup;
 74 | 			children = (
 75 | 				3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */,
 76 | 				9740EEB21CF90195004384FC /* Debug.xcconfig */,
 77 | 				7AFA3C8E1D35360C0083082E /* Release.xcconfig */,
 78 | 				9740EEB31CF90195004384FC /* Generated.xcconfig */,
 79 | 			);
 80 | 			name = Flutter;
 81 | 			sourceTree = "";
 82 | 		};
 83 | 		97C146E51CF9000F007C117D = {
 84 | 			isa = PBXGroup;
 85 | 			children = (
 86 | 				9740EEB11CF90186004384FC /* Flutter */,
 87 | 				97C146F01CF9000F007C117D /* Runner */,
 88 | 				97C146EF1CF9000F007C117D /* Products */,
 89 | 				B67AA6013F2B58D62B0F3C6E /* Pods */,
 90 | 				2CF1E5A6D4720A4FF3E35D8F /* Frameworks */,
 91 | 			);
 92 | 			sourceTree = "";
 93 | 		};
 94 | 		97C146EF1CF9000F007C117D /* Products */ = {
 95 | 			isa = PBXGroup;
 96 | 			children = (
 97 | 				97C146EE1CF9000F007C117D /* Runner.app */,
 98 | 			);
 99 | 			name = Products;
100 | 			sourceTree = "";
101 | 		};
102 | 		97C146F01CF9000F007C117D /* Runner */ = {
103 | 			isa = PBXGroup;
104 | 			children = (
105 | 				97C146FA1CF9000F007C117D /* Main.storyboard */,
106 | 				97C146FD1CF9000F007C117D /* Assets.xcassets */,
107 | 				97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */,
108 | 				97C147021CF9000F007C117D /* Info.plist */,
109 | 				1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */,
110 | 				1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */,
111 | 				74858FAE1ED2DC5600515810 /* AppDelegate.swift */,
112 | 				74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */,
113 | 			);
114 | 			path = Runner;
115 | 			sourceTree = "";
116 | 		};
117 | 		B67AA6013F2B58D62B0F3C6E /* Pods */ = {
118 | 			isa = PBXGroup;
119 | 			children = (
120 | 				748C24E6897B2C1A10CB28B5 /* Pods-Runner.debug.xcconfig */,
121 | 				F73ADCA79EC47124BA98A3B6 /* Pods-Runner.release.xcconfig */,
122 | 				D096891D8198693EF8EEBF89 /* Pods-Runner.profile.xcconfig */,
123 | 			);
124 | 			name = Pods;
125 | 			path = Pods;
126 | 			sourceTree = "";
127 | 		};
128 | /* End PBXGroup section */
129 | 
130 | /* Begin PBXNativeTarget section */
131 | 		97C146ED1CF9000F007C117D /* Runner */ = {
132 | 			isa = PBXNativeTarget;
133 | 			buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
134 | 			buildPhases = (
135 | 				764CAA8A461C482BF55961E8 /* [CP] Check Pods Manifest.lock */,
136 | 				9740EEB61CF901F6004384FC /* Run Script */,
137 | 				97C146EA1CF9000F007C117D /* Sources */,
138 | 				97C146EB1CF9000F007C117D /* Frameworks */,
139 | 				97C146EC1CF9000F007C117D /* Resources */,
140 | 				9705A1C41CF9048500538489 /* Embed Frameworks */,
141 | 				3B06AD1E1E4923F5004D2608 /* Thin Binary */,
142 | 				91082F73749875D0E0A4885C /* [CP] Embed Pods Frameworks */,
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 = 1300;
160 | 				ORGANIZATIONNAME = "";
161 | 				TargetAttributes = {
162 | 					97C146ED1CF9000F007C117D = {
163 | 						CreatedOnToolsVersion = 7.3.1;
164 | 						LastSwiftMigration = 1100;
165 | 					};
166 | 				};
167 | 			};
168 | 			buildConfigurationList = 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */;
169 | 			compatibilityVersion = "Xcode 9.3";
170 | 			developmentRegion = en;
171 | 			hasScannedForEncodings = 0;
172 | 			knownRegions = (
173 | 				en,
174 | 				Base,
175 | 			);
176 | 			mainGroup = 97C146E51CF9000F007C117D;
177 | 			productRefGroup = 97C146EF1CF9000F007C117D /* Products */;
178 | 			projectDirPath = "";
179 | 			projectRoot = "";
180 | 			targets = (
181 | 				97C146ED1CF9000F007C117D /* Runner */,
182 | 			);
183 | 		};
184 | /* End PBXProject section */
185 | 
186 | /* Begin PBXResourcesBuildPhase section */
187 | 		97C146EC1CF9000F007C117D /* Resources */ = {
188 | 			isa = PBXResourcesBuildPhase;
189 | 			buildActionMask = 2147483647;
190 | 			files = (
191 | 				97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */,
192 | 				3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */,
193 | 				97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */,
194 | 				97C146FC1CF9000F007C117D /* Main.storyboard in Resources */,
195 | 			);
196 | 			runOnlyForDeploymentPostprocessing = 0;
197 | 		};
198 | /* End PBXResourcesBuildPhase section */
199 | 
200 | /* Begin PBXShellScriptBuildPhase section */
201 | 		3B06AD1E1E4923F5004D2608 /* Thin Binary */ = {
202 | 			isa = PBXShellScriptBuildPhase;
203 | 			buildActionMask = 2147483647;
204 | 			files = (
205 | 			);
206 | 			inputPaths = (
207 | 			);
208 | 			name = "Thin Binary";
209 | 			outputPaths = (
210 | 			);
211 | 			runOnlyForDeploymentPostprocessing = 0;
212 | 			shellPath = /bin/sh;
213 | 			shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin";
214 | 		};
215 | 		764CAA8A461C482BF55961E8 /* [CP] Check Pods Manifest.lock */ = {
216 | 			isa = PBXShellScriptBuildPhase;
217 | 			buildActionMask = 2147483647;
218 | 			files = (
219 | 			);
220 | 			inputFileListPaths = (
221 | 			);
222 | 			inputPaths = (
223 | 				"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
224 | 				"${PODS_ROOT}/Manifest.lock",
225 | 			);
226 | 			name = "[CP] Check Pods Manifest.lock";
227 | 			outputFileListPaths = (
228 | 			);
229 | 			outputPaths = (
230 | 				"$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt",
231 | 			);
232 | 			runOnlyForDeploymentPostprocessing = 0;
233 | 			shellPath = /bin/sh;
234 | 			shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n    # print error to STDERR\n    echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n    exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
235 | 			showEnvVarsInLog = 0;
236 | 		};
237 | 		91082F73749875D0E0A4885C /* [CP] Embed Pods Frameworks */ = {
238 | 			isa = PBXShellScriptBuildPhase;
239 | 			buildActionMask = 2147483647;
240 | 			files = (
241 | 			);
242 | 			inputFileListPaths = (
243 | 				"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-input-files.xcfilelist",
244 | 			);
245 | 			name = "[CP] Embed Pods Frameworks";
246 | 			outputFileListPaths = (
247 | 				"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-output-files.xcfilelist",
248 | 			);
249 | 			runOnlyForDeploymentPostprocessing = 0;
250 | 			shellPath = /bin/sh;
251 | 			shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh\"\n";
252 | 			showEnvVarsInLog = 0;
253 | 		};
254 | 		9740EEB61CF901F6004384FC /* Run Script */ = {
255 | 			isa = PBXShellScriptBuildPhase;
256 | 			buildActionMask = 2147483647;
257 | 			files = (
258 | 			);
259 | 			inputPaths = (
260 | 			);
261 | 			name = "Run Script";
262 | 			outputPaths = (
263 | 			);
264 | 			runOnlyForDeploymentPostprocessing = 0;
265 | 			shellPath = /bin/sh;
266 | 			shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build";
267 | 		};
268 | /* End PBXShellScriptBuildPhase section */
269 | 
270 | /* Begin PBXSourcesBuildPhase section */
271 | 		97C146EA1CF9000F007C117D /* Sources */ = {
272 | 			isa = PBXSourcesBuildPhase;
273 | 			buildActionMask = 2147483647;
274 | 			files = (
275 | 				74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */,
276 | 				1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */,
277 | 			);
278 | 			runOnlyForDeploymentPostprocessing = 0;
279 | 		};
280 | /* End PBXSourcesBuildPhase section */
281 | 
282 | /* Begin PBXVariantGroup section */
283 | 		97C146FA1CF9000F007C117D /* Main.storyboard */ = {
284 | 			isa = PBXVariantGroup;
285 | 			children = (
286 | 				97C146FB1CF9000F007C117D /* Base */,
287 | 			);
288 | 			name = Main.storyboard;
289 | 			sourceTree = "";
290 | 		};
291 | 		97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */ = {
292 | 			isa = PBXVariantGroup;
293 | 			children = (
294 | 				97C147001CF9000F007C117D /* Base */,
295 | 			);
296 | 			name = LaunchScreen.storyboard;
297 | 			sourceTree = "";
298 | 		};
299 | /* End PBXVariantGroup section */
300 | 
301 | /* Begin XCBuildConfiguration section */
302 | 		249021D3217E4FDB00AE95B9 /* Profile */ = {
303 | 			isa = XCBuildConfiguration;
304 | 			buildSettings = {
305 | 				ALWAYS_SEARCH_USER_PATHS = NO;
306 | 				CLANG_ANALYZER_NONNULL = YES;
307 | 				CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
308 | 				CLANG_CXX_LIBRARY = "libc++";
309 | 				CLANG_ENABLE_MODULES = YES;
310 | 				CLANG_ENABLE_OBJC_ARC = YES;
311 | 				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
312 | 				CLANG_WARN_BOOL_CONVERSION = YES;
313 | 				CLANG_WARN_COMMA = YES;
314 | 				CLANG_WARN_CONSTANT_CONVERSION = YES;
315 | 				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
316 | 				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
317 | 				CLANG_WARN_EMPTY_BODY = YES;
318 | 				CLANG_WARN_ENUM_CONVERSION = YES;
319 | 				CLANG_WARN_INFINITE_RECURSION = YES;
320 | 				CLANG_WARN_INT_CONVERSION = YES;
321 | 				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
322 | 				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
323 | 				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
324 | 				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
325 | 				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
326 | 				CLANG_WARN_STRICT_PROTOTYPES = YES;
327 | 				CLANG_WARN_SUSPICIOUS_MOVE = YES;
328 | 				CLANG_WARN_UNREACHABLE_CODE = YES;
329 | 				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
330 | 				"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
331 | 				COPY_PHASE_STRIP = NO;
332 | 				DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
333 | 				ENABLE_NS_ASSERTIONS = NO;
334 | 				ENABLE_STRICT_OBJC_MSGSEND = YES;
335 | 				GCC_C_LANGUAGE_STANDARD = gnu99;
336 | 				GCC_NO_COMMON_BLOCKS = YES;
337 | 				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
338 | 				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
339 | 				GCC_WARN_UNDECLARED_SELECTOR = YES;
340 | 				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
341 | 				GCC_WARN_UNUSED_FUNCTION = YES;
342 | 				GCC_WARN_UNUSED_VARIABLE = YES;
343 | 				IPHONEOS_DEPLOYMENT_TARGET = 9.0;
344 | 				MTL_ENABLE_DEBUG_INFO = NO;
345 | 				SDKROOT = iphoneos;
346 | 				SUPPORTED_PLATFORMS = iphoneos;
347 | 				TARGETED_DEVICE_FAMILY = "1,2";
348 | 				VALIDATE_PRODUCT = YES;
349 | 			};
350 | 			name = Profile;
351 | 		};
352 | 		249021D4217E4FDB00AE95B9 /* Profile */ = {
353 | 			isa = XCBuildConfiguration;
354 | 			baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
355 | 			buildSettings = {
356 | 				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
357 | 				CLANG_ENABLE_MODULES = YES;
358 | 				CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
359 | 				DEVELOPMENT_TEAM = 5P3BL558UF;
360 | 				ENABLE_BITCODE = NO;
361 | 				INFOPLIST_FILE = Runner/Info.plist;
362 | 				LD_RUNPATH_SEARCH_PATHS = (
363 | 					"$(inherited)",
364 | 					"@executable_path/Frameworks",
365 | 				);
366 | 				PRODUCT_BUNDLE_IDENTIFIER = com.example.restApiTest;
367 | 				PRODUCT_NAME = "$(TARGET_NAME)";
368 | 				SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
369 | 				SWIFT_VERSION = 5.0;
370 | 				VERSIONING_SYSTEM = "apple-generic";
371 | 			};
372 | 			name = Profile;
373 | 		};
374 | 		97C147031CF9000F007C117D /* Debug */ = {
375 | 			isa = XCBuildConfiguration;
376 | 			buildSettings = {
377 | 				ALWAYS_SEARCH_USER_PATHS = NO;
378 | 				CLANG_ANALYZER_NONNULL = YES;
379 | 				CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
380 | 				CLANG_CXX_LIBRARY = "libc++";
381 | 				CLANG_ENABLE_MODULES = YES;
382 | 				CLANG_ENABLE_OBJC_ARC = YES;
383 | 				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
384 | 				CLANG_WARN_BOOL_CONVERSION = YES;
385 | 				CLANG_WARN_COMMA = YES;
386 | 				CLANG_WARN_CONSTANT_CONVERSION = YES;
387 | 				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
388 | 				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
389 | 				CLANG_WARN_EMPTY_BODY = YES;
390 | 				CLANG_WARN_ENUM_CONVERSION = YES;
391 | 				CLANG_WARN_INFINITE_RECURSION = YES;
392 | 				CLANG_WARN_INT_CONVERSION = YES;
393 | 				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
394 | 				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
395 | 				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
396 | 				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
397 | 				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
398 | 				CLANG_WARN_STRICT_PROTOTYPES = YES;
399 | 				CLANG_WARN_SUSPICIOUS_MOVE = YES;
400 | 				CLANG_WARN_UNREACHABLE_CODE = YES;
401 | 				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
402 | 				"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
403 | 				COPY_PHASE_STRIP = NO;
404 | 				DEBUG_INFORMATION_FORMAT = dwarf;
405 | 				ENABLE_STRICT_OBJC_MSGSEND = YES;
406 | 				ENABLE_TESTABILITY = YES;
407 | 				GCC_C_LANGUAGE_STANDARD = gnu99;
408 | 				GCC_DYNAMIC_NO_PIC = NO;
409 | 				GCC_NO_COMMON_BLOCKS = YES;
410 | 				GCC_OPTIMIZATION_LEVEL = 0;
411 | 				GCC_PREPROCESSOR_DEFINITIONS = (
412 | 					"DEBUG=1",
413 | 					"$(inherited)",
414 | 				);
415 | 				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
416 | 				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
417 | 				GCC_WARN_UNDECLARED_SELECTOR = YES;
418 | 				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
419 | 				GCC_WARN_UNUSED_FUNCTION = YES;
420 | 				GCC_WARN_UNUSED_VARIABLE = YES;
421 | 				IPHONEOS_DEPLOYMENT_TARGET = 9.0;
422 | 				MTL_ENABLE_DEBUG_INFO = YES;
423 | 				ONLY_ACTIVE_ARCH = YES;
424 | 				SDKROOT = iphoneos;
425 | 				TARGETED_DEVICE_FAMILY = "1,2";
426 | 			};
427 | 			name = Debug;
428 | 		};
429 | 		97C147041CF9000F007C117D /* Release */ = {
430 | 			isa = XCBuildConfiguration;
431 | 			buildSettings = {
432 | 				ALWAYS_SEARCH_USER_PATHS = NO;
433 | 				CLANG_ANALYZER_NONNULL = YES;
434 | 				CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
435 | 				CLANG_CXX_LIBRARY = "libc++";
436 | 				CLANG_ENABLE_MODULES = YES;
437 | 				CLANG_ENABLE_OBJC_ARC = YES;
438 | 				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
439 | 				CLANG_WARN_BOOL_CONVERSION = YES;
440 | 				CLANG_WARN_COMMA = YES;
441 | 				CLANG_WARN_CONSTANT_CONVERSION = YES;
442 | 				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
443 | 				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
444 | 				CLANG_WARN_EMPTY_BODY = YES;
445 | 				CLANG_WARN_ENUM_CONVERSION = YES;
446 | 				CLANG_WARN_INFINITE_RECURSION = YES;
447 | 				CLANG_WARN_INT_CONVERSION = YES;
448 | 				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
449 | 				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
450 | 				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
451 | 				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
452 | 				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
453 | 				CLANG_WARN_STRICT_PROTOTYPES = YES;
454 | 				CLANG_WARN_SUSPICIOUS_MOVE = YES;
455 | 				CLANG_WARN_UNREACHABLE_CODE = YES;
456 | 				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
457 | 				"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
458 | 				COPY_PHASE_STRIP = NO;
459 | 				DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
460 | 				ENABLE_NS_ASSERTIONS = NO;
461 | 				ENABLE_STRICT_OBJC_MSGSEND = YES;
462 | 				GCC_C_LANGUAGE_STANDARD = gnu99;
463 | 				GCC_NO_COMMON_BLOCKS = YES;
464 | 				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
465 | 				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
466 | 				GCC_WARN_UNDECLARED_SELECTOR = YES;
467 | 				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
468 | 				GCC_WARN_UNUSED_FUNCTION = YES;
469 | 				GCC_WARN_UNUSED_VARIABLE = YES;
470 | 				IPHONEOS_DEPLOYMENT_TARGET = 9.0;
471 | 				MTL_ENABLE_DEBUG_INFO = NO;
472 | 				SDKROOT = iphoneos;
473 | 				SUPPORTED_PLATFORMS = iphoneos;
474 | 				SWIFT_COMPILATION_MODE = wholemodule;
475 | 				SWIFT_OPTIMIZATION_LEVEL = "-O";
476 | 				TARGETED_DEVICE_FAMILY = "1,2";
477 | 				VALIDATE_PRODUCT = YES;
478 | 			};
479 | 			name = Release;
480 | 		};
481 | 		97C147061CF9000F007C117D /* Debug */ = {
482 | 			isa = XCBuildConfiguration;
483 | 			baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */;
484 | 			buildSettings = {
485 | 				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
486 | 				CLANG_ENABLE_MODULES = YES;
487 | 				CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
488 | 				DEVELOPMENT_TEAM = 5P3BL558UF;
489 | 				ENABLE_BITCODE = NO;
490 | 				INFOPLIST_FILE = Runner/Info.plist;
491 | 				LD_RUNPATH_SEARCH_PATHS = (
492 | 					"$(inherited)",
493 | 					"@executable_path/Frameworks",
494 | 				);
495 | 				PRODUCT_BUNDLE_IDENTIFIER = com.example.restApiTest;
496 | 				PRODUCT_NAME = "$(TARGET_NAME)";
497 | 				SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
498 | 				SWIFT_OPTIMIZATION_LEVEL = "-Onone";
499 | 				SWIFT_VERSION = 5.0;
500 | 				VERSIONING_SYSTEM = "apple-generic";
501 | 			};
502 | 			name = Debug;
503 | 		};
504 | 		97C147071CF9000F007C117D /* Release */ = {
505 | 			isa = XCBuildConfiguration;
506 | 			baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
507 | 			buildSettings = {
508 | 				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
509 | 				CLANG_ENABLE_MODULES = YES;
510 | 				CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
511 | 				DEVELOPMENT_TEAM = 5P3BL558UF;
512 | 				ENABLE_BITCODE = NO;
513 | 				INFOPLIST_FILE = Runner/Info.plist;
514 | 				LD_RUNPATH_SEARCH_PATHS = (
515 | 					"$(inherited)",
516 | 					"@executable_path/Frameworks",
517 | 				);
518 | 				PRODUCT_BUNDLE_IDENTIFIER = com.example.restApiTest;
519 | 				PRODUCT_NAME = "$(TARGET_NAME)";
520 | 				SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
521 | 				SWIFT_VERSION = 5.0;
522 | 				VERSIONING_SYSTEM = "apple-generic";
523 | 			};
524 | 			name = Release;
525 | 		};
526 | /* End XCBuildConfiguration section */
527 | 
528 | /* Begin XCConfigurationList section */
529 | 		97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */ = {
530 | 			isa = XCConfigurationList;
531 | 			buildConfigurations = (
532 | 				97C147031CF9000F007C117D /* Debug */,
533 | 				97C147041CF9000F007C117D /* Release */,
534 | 				249021D3217E4FDB00AE95B9 /* Profile */,
535 | 			);
536 | 			defaultConfigurationIsVisible = 0;
537 | 			defaultConfigurationName = Release;
538 | 		};
539 | 		97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */ = {
540 | 			isa = XCConfigurationList;
541 | 			buildConfigurations = (
542 | 				97C147061CF9000F007C117D /* Debug */,
543 | 				97C147071CF9000F007C117D /* Release */,
544 | 				249021D4217E4FDB00AE95B9 /* Profile */,
545 | 			);
546 | 			defaultConfigurationIsVisible = 0;
547 | 			defaultConfigurationName = Release;
548 | 		};
549 | /* End XCConfigurationList section */
550 | 	};
551 | 	rootObject = 97C146E61CF9000F007C117D /* Project object */;
552 | }
553 | 
--------------------------------------------------------------------------------
/ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata:
--------------------------------------------------------------------------------
1 | 
2 | 
4 |    
6 |    
7 | 
8 | 
--------------------------------------------------------------------------------
/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist:
--------------------------------------------------------------------------------
1 | 
2 | 
3 | 
4 | 
5 | 	IDEDidComputeMac32BitWarning
6 | 	
7 | 
8 | 
9 | 
--------------------------------------------------------------------------------
/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings:
--------------------------------------------------------------------------------
1 | 
2 | 
3 | 
4 | 
5 | 	PreviewsEnabled
6 | 	
7 | 
8 | 
9 | 
--------------------------------------------------------------------------------
/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 5 |    
 8 |       
 9 |          
15 |             
21 |             
22 |          
23 |       
24 |    
25 |    
30 |       
31 |          
37 |          
38 |       
39 |       
40 |       
41 |    
42 |    
52 |       
54 |          
60 |          
61 |       
62 |    
63 |    
69 |       
71 |          
77 |          
78 |       
79 |    
80 |    
82 |    
83 |    
86 |    
87 | 
88 | 
--------------------------------------------------------------------------------
/ios/Runner.xcworkspace/contents.xcworkspacedata:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 4 |    
 6 |    
 7 |    
 9 |    
10 | 
11 | 
--------------------------------------------------------------------------------
/ios/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist:
--------------------------------------------------------------------------------
1 | 
2 | 
3 | 
4 | 
5 | 	IDEDidComputeMac32BitWarning
6 | 	
7 | 
8 | 
9 | 
--------------------------------------------------------------------------------
/ios/Runner.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings:
--------------------------------------------------------------------------------
1 | 
2 | 
3 | 
4 | 
5 | 	PreviewsEnabled
6 | 	
7 | 
8 | 
9 | 
--------------------------------------------------------------------------------
/ios/Runner/AppDelegate.swift:
--------------------------------------------------------------------------------
 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 | }
14 | 
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json:
--------------------------------------------------------------------------------
  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 | }
123 | 
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json:
--------------------------------------------------------------------------------
 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 | }
24 | 
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png
--------------------------------------------------------------------------------
/ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md:
--------------------------------------------------------------------------------
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.
--------------------------------------------------------------------------------
/ios/Runner/Base.lproj/LaunchScreen.storyboard:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 |     
 4 |         
 5 |         
 6 |     
 7 |     
 8 |         
 9 |         
10 |             
11 |                 
12 |                     
13 |                         
14 |                         
15 |                     
16 |                     
17 |                         
18 |                         
19 |                             
20 |                             
21 |                         
22 |                         
23 |                         
24 |                             
25 |                             
26 |                         
27 |                     
28 |                 
29 |                 
30 |             
31 |             
32 |         
33 |     
34 |     
35 |         
36 |     
37 | 
38 | 
--------------------------------------------------------------------------------
/ios/Runner/Base.lproj/Main.storyboard:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 |     
 4 |         
 5 |         
 6 |     
 7 |     
 8 |         
 9 |         
10 |             
11 |                 
12 |                     
13 |                         
14 |                         
15 |                     
16 |                     
17 |                         
18 |                         
19 |                         
20 |                     
21 |                 
22 |                 
23 |             
24 |         
25 |     
26 | 
27 | 
--------------------------------------------------------------------------------
/ios/Runner/Info.plist:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 | 
 4 | 
 5 | 	CFBundleDevelopmentRegion
 6 | 	$(DEVELOPMENT_LANGUAGE)
 7 | 	CFBundleDisplayName
 8 | 	Rest Api Test
 9 | 	CFBundleExecutable
10 | 	$(EXECUTABLE_NAME)
11 | 	CFBundleIdentifier
12 | 	$(PRODUCT_BUNDLE_IDENTIFIER)
13 | 	CFBundleInfoDictionaryVersion
14 | 	6.0
15 | 	CFBundleName
16 | 	rest_api_test
17 | 	CFBundlePackageType
18 | 	APPL
19 | 	CFBundleShortVersionString
20 | 	$(FLUTTER_BUILD_NAME)
21 | 	CFBundleSignature
22 | 	????
23 | 	CFBundleVersion
24 | 	$(FLUTTER_BUILD_NUMBER)
25 | 	LSRequiresIPhoneOS
26 | 	
27 | 	UILaunchStoryboardName
28 | 	LaunchScreen
29 | 	UIMainStoryboardFile
30 | 	Main
31 | 	UISupportedInterfaceOrientations
32 | 	
33 | 		UIInterfaceOrientationPortrait
34 | 		UIInterfaceOrientationLandscapeLeft
35 | 		UIInterfaceOrientationLandscapeRight
36 | 	
37 | 	UISupportedInterfaceOrientations~ipad
38 | 	
39 | 		UIInterfaceOrientationPortrait
40 | 		UIInterfaceOrientationPortraitUpsideDown
41 | 		UIInterfaceOrientationLandscapeLeft
42 | 		UIInterfaceOrientationLandscapeRight
43 | 	
44 | 	UIViewControllerBasedStatusBarAppearance
45 | 	
46 | 
47 | 
48 | 
--------------------------------------------------------------------------------
/ios/Runner/Runner-Bridging-Header.h:
--------------------------------------------------------------------------------
1 | #import "GeneratedPluginRegistrant.h"
2 | 
--------------------------------------------------------------------------------
/lib/bindings/bindings.dart:
--------------------------------------------------------------------------------
1 | export 'initial_binding.dart';
2 | export 'home_screen_binding.dart';
--------------------------------------------------------------------------------
/lib/bindings/home_screen_binding.dart:
--------------------------------------------------------------------------------
 1 | import 'package:get/get.dart';
 2 | import 'package:rest_api_test/controllers/home_screen_controller.dart';
 3 | import 'package:rest_api_test/providers/api_provider/api_providers.dart';
 4 | import 'package:rest_api_test/providers/api_provider/apis.dart';
 5 | import 'package:rest_api_test/repositories/repositories.dart';
 6 | class HomeScreenBinding extends Bindings{
 7 | 
 8 |   @override
 9 |   void dependencies() async  {
10 | 
11 |     Get.lazyPut(() => RecipesRepository(recipesApi:Get.find()), fenix: true );
12 |     Get.put(HomeScreenController());
13 | 
14 |   }
15 | 
16 | }
--------------------------------------------------------------------------------
/lib/bindings/initial_binding.dart:
--------------------------------------------------------------------------------
 1 | 
 2 | import 'package:get/get.dart';
 3 | import 'package:rest_api_test/providers/api_provider/api_provider.dart';
 4 | 
 5 | class InitialBinding extends Bindings{
 6 |   @override
 7 |   void dependencies() {
 8 |     Get.put(RecipesApi(), permanent:  true);
 9 |   }
10 | 
11 | }
--------------------------------------------------------------------------------
/lib/controllers/controllers.dart:
--------------------------------------------------------------------------------
1 | export 'home_screen_controller.dart';
2 | export 'detail_screen_controller.dart';
--------------------------------------------------------------------------------
/lib/controllers/detail_screen_controller.dart:
--------------------------------------------------------------------------------
 1 | import 'package:get/get.dart';
 2 | import 'package:rest_api_test/models/recipe.dart';
 3 | import 'package:rest_api_test/repositories/recipes_repository.dart';
 4 | import 'package:rest_api_test/core/src/const.dart';
 5 | import 'package:rest_api_test/views/details/screens/details_screen.dart';
 6 | 
 7 | class DetailScreenController extends GetxController{
 8 | 
 9 |   late RecipesRepository recipesRepository;
10 |   final Rx _args = Rx(null);
11 |   final  RxList _recipes = [].obs;
12 | 
13 |   List get  recipes  => _recipes;
14 | 
15 |   @override
16 |   void onInit() {
17 | 
18 |     recipesRepository = Get.find();
19 |     _args.value = Get.arguments[ConstVariables.DETAIL_SCREEN_KEY] as DetailScreenArgs;
20 |     fetchRecipesByCategory(_args.value?.category.category??"");
21 | 
22 |     super.onInit();
23 |   }
24 |   
25 |   Future fetchRecipesByCategory(String  categoryName) async{
26 |     List recipes = await recipesRepository.fetchRecipesByCategory(categoryName);
27 |     _recipes.value =  recipes;
28 | 
29 |   }
30 | 
31 | 
32 | 
33 | 
34 | }
35 | 
36 | 
--------------------------------------------------------------------------------
/lib/controllers/home_screen_controller.dart:
--------------------------------------------------------------------------------
 1 | import 'package:get/get.dart';
 2 | import 'package:rest_api_test/models/category.dart';
 3 | import 'package:rest_api_test/repositories/recipes_repository.dart';
 4 | 
 5 | class HomeScreenController extends GetxController{
 6 | 
 7 | late final RecipesRepository repository;
 8 | final  RxList _categories = [].obs;
 9 | 
10 | 
11 | List get  categories => _categories;
12 | 
13 |   @override
14 |   void onInit() {
15 |     repository = Get.find();
16 |    getCategories();
17 |     super.onInit();
18 |   }
19 | 
20 |   Future getCategories() async {
21 |     var res =  await repository.fetchAllCategories();
22 |     _categories.value = res;
23 |   }
24 | }
--------------------------------------------------------------------------------
/lib/core/src/const.dart:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 | 
 4 | class ConstVariables{
 5 | 
 6 |     ConstVariables._();
 7 | 
 8 |     static const DETAIL_SCREEN_KEY =  "detail";
 9 | 
10 | 
11 | }
12 | 
--------------------------------------------------------------------------------
/lib/core/utils/toast.dart:
--------------------------------------------------------------------------------
 1 | import 'package:flutter/material.dart';
 2 | import 'package:fluttertoast/fluttertoast.dart';
 3 | 
 4 | class Toaster{
 5 | 
 6 |   static void showToast({required  String message}){
 7 |     Fluttertoast.showToast(
 8 |         msg: message,
 9 |         toastLength: Toast.LENGTH_SHORT,
10 |         gravity: ToastGravity.SNACKBAR,
11 |         timeInSecForIosWeb: 1,
12 |         backgroundColor: Colors.red,
13 |         textColor: Colors.white,
14 |         fontSize: 16.0
15 |     );
16 |   }
17 | }
--------------------------------------------------------------------------------
/lib/main.dart:
--------------------------------------------------------------------------------
 1 | import 'package:flutter/material.dart';
 2 | import 'package:flutter_dotenv/flutter_dotenv.dart';
 3 | import 'package:flutter_easyloading/flutter_easyloading.dart';
 4 | import 'package:get/get.dart';
 5 | import 'package:rest_api_test/bindings/initial_binding.dart';
 6 | import 'package:rest_api_test/router/app_pages.dart';
 7 | import 'package:rest_api_test/router/app_routes.dart';
 8 | 
 9 | void main() async  {
10 | 
11 |   await dotenv.load(fileName: "assets/.env.dev");
12 |   runApp(const MyApp());
13 | }
14 | 
15 | class MyApp extends StatelessWidget {
16 |   const MyApp({Key? key}) : super(key: key);
17 | 
18 |   // This widget is the root of your application.
19 |   @override
20 |   Widget build(BuildContext context) {
21 |     return GetMaterialApp(
22 |       title: 'Recipe App',
23 |       getPages: AppRouter.routes,
24 |       initialRoute:Routes.HOME_SCREEN,
25 |       initialBinding: InitialBinding(),
26 |       builder: EasyLoading.init(),
27 |       theme: ThemeData(
28 | 
29 |         primarySwatch: Colors.blue,
30 |       ),
31 |       // home:  HomeScreen(),
32 |     );
33 |   }
34 | }
35 | 
36 | 
--------------------------------------------------------------------------------
/lib/models/category.dart:
--------------------------------------------------------------------------------
 1 | class Category {
 2 | 
 3 |   final String category;
 4 | 
 5 | //
 6 | 
 7 |   const Category({
 8 |     required this.category,
 9 |   });
10 | 
11 |   @override
12 |   bool operator ==(Object other) =>
13 |       identical(this, other) ||
14 |       (other is Category &&
15 |           runtimeType == other.runtimeType &&
16 |           category == other.category);
17 | 
18 |   @override
19 |   int get hashCode => category.hashCode;
20 | 
21 |   @override
22 |   String toString() {
23 |     return 'Category{' + ' category: $category,' + '}';
24 |   }
25 | 
26 |   Category copyWith({
27 |     String? category,
28 |   }) {
29 |     return Category(
30 |       category: category ?? this.category,
31 |     );
32 |   }
33 | 
34 |   Map toJson() {
35 |     return {
36 |       'category': category,
37 |     };
38 |   }
39 | 
40 |   factory Category.fromJson(Map json) {
41 |     return Category(
42 |       category: json['category'] as String,
43 |     );
44 |   }
45 | 
46 | //
47 | }
--------------------------------------------------------------------------------
/lib/models/models.dart:
--------------------------------------------------------------------------------
1 | export 'category.dart';
2 | export 'recipe.dart';
--------------------------------------------------------------------------------
/lib/models/recipe.dart:
--------------------------------------------------------------------------------
 1 | class Recipe {
 2 | 
 3 |   final String title;
 4 |   final String category;
 5 |   final String url;
 6 |   final String img;
 7 |   final String source;
 8 | 
 9 | //
10 | 
11 |   const Recipe({
12 |     required this.title,
13 |     required this.category,
14 |     required this.url,
15 |     required this.img,
16 |     required this.source,
17 |   });
18 | 
19 |   @override
20 |   bool operator ==(Object other) =>
21 |       identical(this, other) ||
22 |       (other is Recipe &&
23 |           runtimeType == other.runtimeType &&
24 |           title == other.title &&
25 |           category == other.category &&
26 |           url == other.url &&
27 |           img == other.img &&
28 |           source == other.source);
29 | 
30 |   @override
31 |   int get hashCode =>
32 |       title.hashCode ^
33 |       category.hashCode ^
34 |       url.hashCode ^
35 |       img.hashCode ^
36 |       source.hashCode;
37 | 
38 |   @override
39 |   String toString() {
40 |     return 'Recipe{' +
41 |         ' title: $title,' +
42 |         ' category: $category,' +
43 |         ' url: $url,' +
44 |         ' img: $img,' +
45 |         ' source: $source,' +
46 |         '}';
47 |   }
48 | 
49 |   Recipe copyWith({
50 |     String? title,
51 |     String? category,
52 |     String? url,
53 |     String? img,
54 |     String? source,
55 |   }) {
56 |     return Recipe(
57 |       title: title ?? this.title,
58 |       category: category ?? this.category,
59 |       url: url ?? this.url,
60 |       img: img ?? this.img,
61 |       source: source ?? this.source,
62 |     );
63 |   }
64 | 
65 |   Map toJson() {
66 |     return {
67 |       'title': title,
68 |       'category': category,
69 |       'url': url,
70 |       'img': img,
71 |       'source': source,
72 |     };
73 |   }
74 | 
75 |   factory Recipe.fromJson(Map json) {
76 |     return Recipe(
77 |       title: json['title'] as String,
78 |       category: json['category'] as String,
79 |       url: json['url'] as String,
80 |       img: json['img'] as String,
81 |       source: json['source'] as String,
82 |     );
83 |   }
84 | 
85 | //
86 | }
--------------------------------------------------------------------------------
/lib/providers/api_provider/api_provider.dart:
--------------------------------------------------------------------------------
 1 | import 'package:get/get.dart';
 2 | import 'package:rest_api_test/providers/api_provider/api_providers.dart';
 3 | import 'base_provider.dart';
 4 | 
 5 | class RecipesApi extends BaseApiProvider implements IRecipesApi{
 6 | 
 7 |   @override
 8 |   Future fetchAllCategories() async {
 9 |     var  response = await get("/category");
10 |      return response;
11 |   }
12 | 
13 |   @override
14 |   Future fetchRecipesByCategory(String categoryName) async {
15 |     var  response = await get("/getbycat/$categoryName");
16 |     return response;
17 |   }
18 | }
--------------------------------------------------------------------------------
/lib/providers/api_provider/api_providers.dart:
--------------------------------------------------------------------------------
1 | 
2 | import 'package:get/get_connect/http/src/response/response.dart';
3 | 
4 | abstract class IRecipesApi{
5 | 
6 |   Future fetchAllCategories();
7 |   Future fetchRecipesByCategory(String categoryName);
8 | 
9 | }
--------------------------------------------------------------------------------
/lib/providers/api_provider/apis.dart:
--------------------------------------------------------------------------------
1 | export 'base_provider.dart';
2 | export 'exceptions.dart';
3 | export 'api_provider.dart';
--------------------------------------------------------------------------------
/lib/providers/api_provider/base_provider.dart:
--------------------------------------------------------------------------------
 1 | import 'package:flutter_easyloading/flutter_easyloading.dart';
 2 | import 'package:get/get_connect/http/src/request/request.dart';
 3 | import 'package:flutter_dotenv/flutter_dotenv.dart';
 4 | import 'package:get/get.dart';
 5 | import 'package:rest_api_test/core/utils/toast.dart';
 6 | import 'exceptions.dart';
 7 | import 'dart:async';
 8 | 
 9 | class BaseApiProvider extends GetConnect {
10 |   late String apiKey;
11 |   late Map headers;
12 |   late String httpBaseUrl;
13 |   @override
14 |   void onInit() {
15 |     initCredentials();
16 |     httpClient.baseUrl = httpBaseUrl;
17 |     httpClient.defaultContentType = "application/json; charset=utf-8";
18 |     httpClient.timeout = const Duration(seconds: 10);
19 |     httpClient.addResponseModifier(responseInterceptor);
20 |     httpClient.addRequestModifier(requestInterceptor);
21 | 
22 |     super.onInit();
23 |   }
24 | 
25 |   void initCredentials() {
26 |     httpBaseUrl = dotenv.env["API_SERVER_HOST"].toString();
27 |     apiKey = dotenv.env["API_KEY"].toString();
28 |     headers = {"x-rapidapi-key": apiKey};
29 |   }
30 | 
31 |   FutureOr responseInterceptor(Request request, Response response) {
32 |     EasyLoading.dismiss();
33 |     switch (response.statusCode) {
34 |       case 200:
35 |         return response;
36 |       case 201:
37 |         return response;
38 |       case 400:
39 |         Toaster.showToast(message: response.body.toString());
40 |         throw BadRequestException(response.body.toString());
41 |       case 401:
42 |         Toaster.showToast(message: response.body.toString());
43 |         throw BadRequestException(response.body.toString());
44 |       case 403:
45 |         Toaster.showToast(message: response.body.toString());
46 |         throw UnauthorizedException(response.body.toString());
47 |       case 500:
48 |         Toaster.showToast(message: response.body.toString());
49 |        throw InternalServerException(response.body.toString());
50 |       default:
51 |         Toaster.showToast(message:"Unexpected error occurred, try again...");
52 |         throw FetchDataException('Unexpected error occurred : ${response.statusCode}');
53 |     }
54 |   }
55 | 
56 |   FutureOr requestInterceptor(Request request) async {
57 |     request.headers.addAll(headers);
58 |     EasyLoading.show(status: "로드중...");
59 |     return request;
60 |   }
61 | }
62 | 
--------------------------------------------------------------------------------
/lib/providers/api_provider/exceptions.dart:
--------------------------------------------------------------------------------
 1 | 
 2 | 
 3 | 
 4 | class AppException implements Exception {
 5 |   final _message;
 6 |   final _prefix;
 7 | 
 8 |   AppException([this._message, this._prefix]);
 9 | 
10 |   @override
11 |   String toString() {
12 |     return "$_prefix$_message";
13 |   }
14 | }
15 | 
16 | class FetchDataException extends AppException {
17 |   FetchDataException([message])
18 |       : super(message, "Error During Communication: ");
19 | }
20 | 
21 | class BadRequestException extends AppException {
22 |   BadRequestException([message]) : super(message, "Invalid Request: ");
23 | }
24 | 
25 | class UnauthorizedException extends AppException {
26 |   UnauthorizedException([message]) : super(message, "Unauthorised: ");
27 | }
28 | 
29 | class InvalidInputException extends AppException {
30 |   InvalidInputException([message]) : super(message, "Invalid Input: ");
31 | }
32 | class InternalServerException extends AppException {
33 |    InternalServerException([message])
34 | :super(message, "Internal Server Error:");
35 | }
--------------------------------------------------------------------------------
/lib/repositories/recipes_repository.dart:
--------------------------------------------------------------------------------
 1 | 
 2 | import 'dart:convert';
 3 | 
 4 | import 'package:rest_api_test/models/category.dart';
 5 | import 'package:rest_api_test/models/recipe.dart';
 6 | import 'package:rest_api_test/providers/api_provider/api_providers.dart';
 7 | 
 8 | abstract class IRecipesRepository{
 9 | 
10 |   Future
> fetchRecipesByCategory(String categoryName);
11 |   Future> fetchAllCategories();
12 | 
13 | }
14 | 
15 | 
16 | class RecipesRepository implements IRecipesRepository{
17 | 
18 | 
19 |   final IRecipesApi recipesApi;
20 |   RecipesRepository({required this.recipesApi});
21 | 
22 |   @override
23 |   Future> fetchRecipesByCategory(String  categoryName)  async{
24 |      var  response = await recipesApi.fetchRecipesByCategory(categoryName);
25 |      return  List.from(json.decode(response.bodyString!) as List).map((e) => Recipe.fromJson(e)).toList();
26 |   }
27 | 
28 |   @override
29 |    Future> fetchAllCategories()  async{
30 |     var  response =   await recipesApi.fetchAllCategories();
31 |     if (response.bodyString != null) {
32 |       return  List.from(json.decode(response.bodyString!) as List).map((e) => Category.fromJson(e)).toList();
33 |     }
34 |     return [];
35 |   }
36 | 
37 | }
--------------------------------------------------------------------------------
/lib/repositories/repositories.dart:
--------------------------------------------------------------------------------
1 | export 'recipes_repository.dart';
2 | 
--------------------------------------------------------------------------------
/lib/router/app_pages.dart:
--------------------------------------------------------------------------------
1 | 
2 | class Routes {
3 | 
4 |   static const String HOME_SCREEN = "/home";
5 |   static const String DETAIL_SCREEN = "/details";
6 | }
7 | 
--------------------------------------------------------------------------------
/lib/router/app_routes.dart:
--------------------------------------------------------------------------------
 1 | import 'package:get/get.dart';
 2 | import 'package:rest_api_test/router/app_pages.dart';
 3 | import 'package:rest_api_test/bindings/home_screen_binding.dart';
 4 | import 'package:rest_api_test/views/home/screens/home_screen.dart';
 5 | import 'package:rest_api_test/views/details/screens/details_screen.dart';
 6 | 
 7 | class AppRouter{
 8 | 
 9 |   AppRouter._();
10 | 
11 | 
12 |   static final routes = [
13 |     GetPage(
14 |       name: Routes.HOME_SCREEN,
15 |       page: () =>  HomeScreen(),
16 |       binding: HomeScreenBinding(),
17 |     ),
18 |     GetPage(
19 |       name: Routes.DETAIL_SCREEN,
20 |       page: () =>  DetailScreen(),
21 |     ),
22 | 
23 |   ];
24 | }
--------------------------------------------------------------------------------
/lib/views/details/screens/details_screen.dart:
--------------------------------------------------------------------------------
 1 | 
 2 | import 'package:flutter/material.dart';
 3 | import 'package:get/get.dart';
 4 | import 'package:rest_api_test/controllers/detail_screen_controller.dart';
 5 | import 'package:rest_api_test/models/category.dart';
 6 | import 'package:rest_api_test/core/src/const.dart';
 7 | import 'package:rest_api_test/views/details/widgets/single_recipe.dart';
 8 | class DetailScreen extends StatelessWidget {
 9 | 
10 |   final controller = Get.find(
11 |       tag: (Get.arguments[ConstVariables.DETAIL_SCREEN_KEY]
12 |       as DetailScreenArgs).index
13 |           .toString());
14 | 
15 |    DetailScreen({Key? key}) : super(key: key);
16 | 
17 | 
18 | 
19 |   @override
20 |   Widget build(BuildContext context) {
21 |     return  Scaffold(
22 |       body:Obx(() {
23 |         return  ListView.builder(
24 |             itemCount: controller.recipes.length,
25 |             itemBuilder: (context, index){
26 |               return SingleRecipeWidget(recipe: controller.recipes[index]);
27 |             });
28 |       }),
29 |     );
30 |   }
31 | }
32 | 
33 | class DetailScreenArgs {
34 |   final Category category;
35 |   final int index;
36 |   DetailScreenArgs({required this.index, required this.category});
37 | 
38 | }
--------------------------------------------------------------------------------
/lib/views/details/widgets/single_recipe.dart:
--------------------------------------------------------------------------------
 1 | import 'package:flutter/material.dart';
 2 | import 'package:get/get.dart';
 3 | import 'package:rest_api_test/models/recipe.dart';
 4 | 
 5 | 
 6 | class SingleRecipeWidget extends StatelessWidget {
 7 |   const SingleRecipeWidget({Key? key, required this.recipe}) : super(key: key);
 8 |   static const double CARD_HEIGHT = 300;
 9 | 
10 |    final Recipe recipe;
11 |   @override
12 |   Widget build(BuildContext context) {
13 |     final width  = Get.width;
14 |     return Align(
15 |       alignment: Alignment.center,
16 |       child: SizedBox(
17 |         height: CARD_HEIGHT,
18 |         width: 0.9*width ,
19 |         child: Card(
20 |           child: _buildCardChild(),
21 |           elevation: 5.0,
22 |           shape: RoundedRectangleBorder(
23 |             borderRadius: BorderRadius.circular(10.0),
24 |           ),
25 |         ),
26 |       ),
27 |     );
28 |   }
29 | 
30 |   Widget _buildCardChild(){
31 |     return  Column(
32 |       crossAxisAlignment: CrossAxisAlignment.start ,
33 |       children: [
34 |         SizedBox(
35 |           width: 0.9*Get.width,
36 |          height: 0.7 *  CARD_HEIGHT,
37 |           child: ClipRRect(
38 |             borderRadius: BorderRadius.circular(10.0),
39 |              child: Image.network(recipe.img, fit: BoxFit.cover,),
40 |           ),
41 |         ),
42 |         const SizedBox(height: 10),
43 |         Container(
44 |             margin: const EdgeInsets.only(left: 10),
45 |             child: Text("name: ${recipe.title}", maxLines: 1, style: const TextStyle(fontSize: 18),)),
46 |         Container(
47 |             margin: const EdgeInsets.only(left: 10),
48 |             child: Text("source: ${recipe.source}", maxLines: 1, style: const TextStyle(fontSize: 18),)),
49 |         Container(
50 |             margin: const EdgeInsets.only(left: 10),
51 |             child: Text("category: ${recipe.category}", maxLines: 1, style: const TextStyle(fontSize: 18),))
52 | 
53 |       ],
54 |     );
55 |   }
56 | }
57 | 
--------------------------------------------------------------------------------
/lib/views/home/screens/home_screen.dart:
--------------------------------------------------------------------------------
 1 | import 'package:flutter/material.dart';
 2 | import 'package:get/get.dart';
 3 | import 'package:rest_api_test/controllers/home_screen_controller.dart';
 4 | import 'package:rest_api_test/views/home/widgets/single_cateogry_widget.dart';
 5 | 
 6 | 
 7 | 
 8 | class HomeScreen extends StatelessWidget {
 9 |    HomeScreen({Key? key}) : super(key: key);
10 | 
11 |   var  controller = Get.find();
12 |   @override
13 |   Widget build(BuildContext context) {
14 |     return Scaffold(
15 | 
16 |       body:Obx(() {
17 |          return  ListView.builder(
18 |              itemCount: controller.categories.length,
19 |              itemBuilder: (context, index){
20 |             return SingleCategoryWidget(category: controller.categories[index], index: index,);
21 |          });
22 |       }),
23 |     );
24 |   }
25 | }
26 | 
--------------------------------------------------------------------------------
/lib/views/home/widgets/single_cateogry_widget.dart:
--------------------------------------------------------------------------------
 1 | import 'package:flutter/material.dart';
 2 | import 'package:rest_api_test/controllers/detail_screen_controller.dart';
 3 | import 'package:rest_api_test/models/category.dart';
 4 | import 'package:get/get.dart';
 5 | import 'package:rest_api_test/router/app_pages.dart';
 6 | import 'package:rest_api_test/core/src/const.dart';
 7 | import 'package:rest_api_test/views/details/screens/details_screen.dart';
 8 | 
 9 | 
10 | 
11 | class SingleCategoryWidget extends StatelessWidget {
12 |    const  SingleCategoryWidget({Key? key, required this.category, required this.index}) : super(key: key);
13 |    static const double CARD_HEIGHT = 70;
14 |   final Category category;
15 |   final  int index;
16 |   @override
17 |   Widget build(BuildContext context) {
18 |     final width = Get.width;
19 |     return SizedBox(
20 |     height: CARD_HEIGHT, width: 0.8  * width ,
21 |         child:GestureDetector(
22 |         onTap: ()  {
23 |           onTap(index);
24 |         }  ,
25 |         child: Card(
26 |           elevation: 5.0,
27 |           shape: RoundedRectangleBorder(
28 |             borderRadius: BorderRadius.circular(10.0),
29 |           ),
30 |           child: Center(child: Text(category.category, style: const TextStyle(fontSize: 17),)),
31 |         ),
32 |       )
33 |     );
34 |   }
35 |   void onTap(int index) {
36 |     final screenArgs = {ConstVariables.DETAIL_SCREEN_KEY: DetailScreenArgs(category: category, index: index)};
37 |     Get.lazyPut(() => DetailScreenController(), tag: index.toString());
38 |     Get.toNamed(Routes.DETAIL_SCREEN,  arguments: screenArgs);
39 |   }
40 | }
41 | 
--------------------------------------------------------------------------------
/pubspec.lock:
--------------------------------------------------------------------------------
  1 | # Generated by pub
  2 | # See https://dart.dev/tools/pub/glossary#lockfile
  3 | packages:
  4 |   async:
  5 |     dependency: transitive
  6 |     description:
  7 |       name: async
  8 |       url: "https://pub.dartlang.org"
  9 |     source: hosted
 10 |     version: "2.8.2"
 11 |   boolean_selector:
 12 |     dependency: transitive
 13 |     description:
 14 |       name: boolean_selector
 15 |       url: "https://pub.dartlang.org"
 16 |     source: hosted
 17 |     version: "2.1.0"
 18 |   characters:
 19 |     dependency: transitive
 20 |     description:
 21 |       name: characters
 22 |       url: "https://pub.dartlang.org"
 23 |     source: hosted
 24 |     version: "1.2.0"
 25 |   charcode:
 26 |     dependency: transitive
 27 |     description:
 28 |       name: charcode
 29 |       url: "https://pub.dartlang.org"
 30 |     source: hosted
 31 |     version: "1.3.1"
 32 |   clock:
 33 |     dependency: transitive
 34 |     description:
 35 |       name: clock
 36 |       url: "https://pub.dartlang.org"
 37 |     source: hosted
 38 |     version: "1.1.0"
 39 |   collection:
 40 |     dependency: transitive
 41 |     description:
 42 |       name: collection
 43 |       url: "https://pub.dartlang.org"
 44 |     source: hosted
 45 |     version: "1.15.0"
 46 |   cupertino_icons:
 47 |     dependency: "direct main"
 48 |     description:
 49 |       name: cupertino_icons
 50 |       url: "https://pub.dartlang.org"
 51 |     source: hosted
 52 |     version: "1.0.4"
 53 |   fake_async:
 54 |     dependency: transitive
 55 |     description:
 56 |       name: fake_async
 57 |       url: "https://pub.dartlang.org"
 58 |     source: hosted
 59 |     version: "1.2.0"
 60 |   flutter:
 61 |     dependency: "direct main"
 62 |     description: flutter
 63 |     source: sdk
 64 |     version: "0.0.0"
 65 |   flutter_dotenv:
 66 |     dependency: "direct main"
 67 |     description:
 68 |       name: flutter_dotenv
 69 |       url: "https://pub.dartlang.org"
 70 |     source: hosted
 71 |     version: "5.0.2"
 72 |   flutter_easyloading:
 73 |     dependency: "direct main"
 74 |     description:
 75 |       name: flutter_easyloading
 76 |       url: "https://pub.dartlang.org"
 77 |     source: hosted
 78 |     version: "3.0.3"
 79 |   flutter_lints:
 80 |     dependency: "direct dev"
 81 |     description:
 82 |       name: flutter_lints
 83 |       url: "https://pub.dartlang.org"
 84 |     source: hosted
 85 |     version: "1.0.4"
 86 |   flutter_spinkit:
 87 |     dependency: transitive
 88 |     description:
 89 |       name: flutter_spinkit
 90 |       url: "https://pub.dartlang.org"
 91 |     source: hosted
 92 |     version: "5.1.0"
 93 |   flutter_test:
 94 |     dependency: "direct dev"
 95 |     description: flutter
 96 |     source: sdk
 97 |     version: "0.0.0"
 98 |   flutter_web_plugins:
 99 |     dependency: transitive
100 |     description: flutter
101 |     source: sdk
102 |     version: "0.0.0"
103 |   fluttertoast:
104 |     dependency: "direct main"
105 |     description:
106 |       name: fluttertoast
107 |       url: "https://pub.dartlang.org"
108 |     source: hosted
109 |     version: "8.0.8"
110 |   get:
111 |     dependency: "direct main"
112 |     description:
113 |       name: get
114 |       url: "https://pub.dartlang.org"
115 |     source: hosted
116 |     version: "4.6.1"
117 |   js:
118 |     dependency: transitive
119 |     description:
120 |       name: js
121 |       url: "https://pub.dartlang.org"
122 |     source: hosted
123 |     version: "0.6.3"
124 |   lints:
125 |     dependency: transitive
126 |     description:
127 |       name: lints
128 |       url: "https://pub.dartlang.org"
129 |     source: hosted
130 |     version: "1.0.1"
131 |   matcher:
132 |     dependency: transitive
133 |     description:
134 |       name: matcher
135 |       url: "https://pub.dartlang.org"
136 |     source: hosted
137 |     version: "0.12.11"
138 |   meta:
139 |     dependency: transitive
140 |     description:
141 |       name: meta
142 |       url: "https://pub.dartlang.org"
143 |     source: hosted
144 |     version: "1.7.0"
145 |   path:
146 |     dependency: transitive
147 |     description:
148 |       name: path
149 |       url: "https://pub.dartlang.org"
150 |     source: hosted
151 |     version: "1.8.0"
152 |   sky_engine:
153 |     dependency: transitive
154 |     description: flutter
155 |     source: sdk
156 |     version: "0.0.99"
157 |   source_span:
158 |     dependency: transitive
159 |     description:
160 |       name: source_span
161 |       url: "https://pub.dartlang.org"
162 |     source: hosted
163 |     version: "1.8.1"
164 |   stack_trace:
165 |     dependency: transitive
166 |     description:
167 |       name: stack_trace
168 |       url: "https://pub.dartlang.org"
169 |     source: hosted
170 |     version: "1.10.0"
171 |   stream_channel:
172 |     dependency: transitive
173 |     description:
174 |       name: stream_channel
175 |       url: "https://pub.dartlang.org"
176 |     source: hosted
177 |     version: "2.1.0"
178 |   string_scanner:
179 |     dependency: transitive
180 |     description:
181 |       name: string_scanner
182 |       url: "https://pub.dartlang.org"
183 |     source: hosted
184 |     version: "1.1.0"
185 |   term_glyph:
186 |     dependency: transitive
187 |     description:
188 |       name: term_glyph
189 |       url: "https://pub.dartlang.org"
190 |     source: hosted
191 |     version: "1.2.0"
192 |   test_api:
193 |     dependency: transitive
194 |     description:
195 |       name: test_api
196 |       url: "https://pub.dartlang.org"
197 |     source: hosted
198 |     version: "0.4.3"
199 |   typed_data:
200 |     dependency: transitive
201 |     description:
202 |       name: typed_data
203 |       url: "https://pub.dartlang.org"
204 |     source: hosted
205 |     version: "1.3.0"
206 |   vector_math:
207 |     dependency: transitive
208 |     description:
209 |       name: vector_math
210 |       url: "https://pub.dartlang.org"
211 |     source: hosted
212 |     version: "2.1.1"
213 | sdks:
214 |   dart: ">=2.15.1 <3.0.0"
215 |   flutter: ">=2.0.0"
216 | 
--------------------------------------------------------------------------------
/pubspec.yaml:
--------------------------------------------------------------------------------
 1 | name: rest_api_test
 2 | description: A new Flutter project.
 3 | 
 4 | # The following line prevents the package from being accidentally published to
 5 | # pub.dev using `flutter pub publish`. This is preferred for private packages.
 6 | publish_to: 'none' # Remove this line if you wish to publish to pub.dev
 7 | 
 8 | # The following defines the version and build number for your application.
 9 | # A version number is three numbers separated by dots, like 1.2.43
10 | # followed by an optional build number separated by a +.
11 | # Both the version and the builder number may be overridden in flutter
12 | # build by specifying --build-name and --build-number, respectively.
13 | # In Android, build-name is used as versionName while build-number used as versionCode.
14 | # Read more about Android versioning at https://developer.android.com/studio/publish/versioning
15 | # In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion.
16 | # Read more about iOS versioning at
17 | # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html
18 | version: 1.0.0+1
19 | 
20 | environment:
21 |   sdk: ">=2.15.1 <3.0.0"
22 | 
23 | # Dependencies specify other packages that your package needs in order to work.
24 | # To automatically upgrade your package dependencies to the latest versions
25 | # consider running `flutter pub upgrade --major-versions`. Alternatively,
26 | # dependencies can be manually updated by changing the version numbers below to
27 | # the latest version available on pub.dev. To see which dependencies have newer
28 | # versions available, run `flutter pub outdated`.
29 | dependencies:
30 |   flutter:
31 |     sdk: flutter
32 |   get: ^4.3.8
33 |   flutter_dotenv: ^5.0.2
34 |   flutter_easyloading: ^3.0.3
35 |   fluttertoast: ^8.0.8
36 | 
37 | 
38 |   # The following adds the Cupertino Icons font to your application.
39 |   # Use with the CupertinoIcons class for iOS style icons.
40 |   cupertino_icons: ^1.0.2
41 | 
42 | dev_dependencies:
43 |   flutter_test:
44 |     sdk: flutter
45 | 
46 |   # The "flutter_lints" package below contains a set of recommended lints to
47 |   # encourage good coding practices. The lint set provided by the package is
48 |   # activated in the `analysis_options.yaml` file located at the root of your
49 |   # package. See that file for information about deactivating specific lint
50 |   # rules and activating additional ones.
51 |   flutter_lints: ^1.0.0
52 | 
53 | # For information on the generic Dart part of this file, see the
54 | # following page: https://dart.dev/tools/pub/pubspec
55 | 
56 | # The following section is specific to Flutter.
57 | flutter:
58 | 
59 |   # The following line ensures that the Material Icons font is
60 |   # included with your application, so that you can use the icons in
61 |   # the material Icons class.
62 |   uses-material-design: true
63 | 
64 |   # To add assets to your application, add an assets section, like this:
65 |   assets:
66 |     - .env.dev
67 | 
68 |   # An image asset can refer to one or more resolution-specific "variants", see
69 |   # https://flutter.dev/assets-and-images/#resolution-aware.
70 | 
71 |   # For details regarding adding assets from package dependencies, see
72 |   # https://flutter.dev/assets-and-images/#from-packages
73 | 
74 |   # To add custom fonts to your application, add a fonts section here,
75 |   # in this "flutter" section. Each entry in this list should have a
76 |   # "family" key with the font family name, and a "fonts" key with a
77 |   # list giving the asset and other descriptors for the font. For
78 |   # example:
79 |   # fonts:
80 |   #   - family: Schyler
81 |   #     fonts:
82 |   #       - asset: fonts/Schyler-Regular.ttf
83 |   #       - asset: fonts/Schyler-Italic.ttf
84 |   #         style: italic
85 |   #   - family: Trajan Pro
86 |   #     fonts:
87 |   #       - asset: fonts/TrajanPro.ttf
88 |   #       - asset: fonts/TrajanPro_Bold.ttf
89 |   #         weight: 700
90 |   #
91 |   # For details regarding fonts from package dependencies,
92 |   # see https://flutter.dev/custom-fonts/#from-packages
93 | 
--------------------------------------------------------------------------------
/test/widget_test.dart:
--------------------------------------------------------------------------------
 1 | // // This is a basic Flutter widget test.
 2 | // //
 3 | // // To perform an interaction with a widget in your test, use the WidgetTester
 4 | // // utility that Flutter provides. For example, you can send tap and scroll
 5 | // // gestures. You can also use WidgetTester to find child widgets in the widget
 6 | // // tree, read text, and verify that the values of widget properties are correct.
 7 | //
 8 | // import 'package:flutter/material.dart';
 9 | // import 'package:flutter_test/flutter_test.dart';
10 | //
11 | // import 'package:rest_api_test/main.dart';
12 | //
13 | // void main() {
14 | //   testWidgets('Counter increments smoke test', (WidgetTester tester) async {
15 | //     // Build our app and trigger a frame.
16 | //     await tester.pumpWidget(const MyApp());
17 | //
18 | //     // Verify that our counter starts at 0.
19 | //     expect(find.text('0'), findsOneWidget);
20 | //     expect(find.text('1'), findsNothing);
21 | //
22 | //     // Tap the '+' icon and trigger a frame.
23 | //     await tester.tap(find.byIcon(Icons.add));
24 | //     await tester.pump();
25 | //
26 | //     // Verify that our counter has incremented.
27 | //     expect(find.text('0'), findsNothing);
28 | //     expect(find.text('1'), findsOneWidget);
29 | //   });
30 | // }
31 | 
--------------------------------------------------------------------------------
/web/favicon.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/web/favicon.png
--------------------------------------------------------------------------------
/web/icons/Icon-192.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/web/icons/Icon-192.png
--------------------------------------------------------------------------------
/web/icons/Icon-512.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/web/icons/Icon-512.png
--------------------------------------------------------------------------------
/web/icons/Icon-maskable-192.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/web/icons/Icon-maskable-192.png
--------------------------------------------------------------------------------
/web/icons/Icon-maskable-512.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/ilyosbekkk/getx-http-request/ee1b30594b3e1be6e58ab1f41a276f4b9980320b/web/icons/Icon-maskable-512.png
--------------------------------------------------------------------------------
/web/index.html:
--------------------------------------------------------------------------------
  1 | 
  2 | 
  3 | 
  4 |   
 17 |   
 18 | 
 19 |   
 20 |   
 21 |   
 22 | 
 23 |   
 24 |   
 25 |   
 26 |   
 27 |   
 28 | 
 29 |   
 30 |   
 31 | 
 32 |   rest_api_test
 33 |   
 34 | 
 35 | 
 36 |   
 39 |   
103 | 
104 | 
105 | 
--------------------------------------------------------------------------------
/web/manifest.json:
--------------------------------------------------------------------------------
 1 | {
 2 |     "name": "rest_api_test",
 3 |     "short_name": "rest_api_test",
 4 |     "start_url": ".",
 5 |     "display": "standalone",
 6 |     "background_color": "#0175C2",
 7 |     "theme_color": "#0175C2",
 8 |     "description": "A new Flutter project.",
 9 |     "orientation": "portrait-primary",
10 |     "prefer_related_applications": false,
11 |     "icons": [
12 |         {
13 |             "src": "icons/Icon-192.png",
14 |             "sizes": "192x192",
15 |             "type": "image/png"
16 |         },
17 |         {
18 |             "src": "icons/Icon-512.png",
19 |             "sizes": "512x512",
20 |             "type": "image/png"
21 |         },
22 |         {
23 |             "src": "icons/Icon-maskable-192.png",
24 |             "sizes": "192x192",
25 |             "type": "image/png",
26 |             "purpose": "maskable"
27 |         },
28 |         {
29 |             "src": "icons/Icon-maskable-512.png",
30 |             "sizes": "512x512",
31 |             "type": "image/png",
32 |             "purpose": "maskable"
33 |         }
34 |     ]
35 | }
36 | 
--------------------------------------------------------------------------------