-
45.gitignore
-
33.metadata
-
3README.md
-
1analysis_options.yaml
-
14android/.gitignore
-
44android/app/build.gradle.kts
-
7android/app/src/debug/AndroidManifest.xml
-
45android/app/src/main/AndroidManifest.xml
-
5android/app/src/main/kotlin/com/example/hadi_hoda_flutter/MainActivity.kt
-
12android/app/src/main/res/drawable-v21/launch_background.xml
-
12android/app/src/main/res/drawable/launch_background.xml
-
BINandroid/app/src/main/res/mipmap-hdpi/ic_launcher.png
-
BINandroid/app/src/main/res/mipmap-mdpi/ic_launcher.png
-
BINandroid/app/src/main/res/mipmap-xhdpi/ic_launcher.png
-
BINandroid/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
-
BINandroid/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
-
18android/app/src/main/res/values-night/styles.xml
-
18android/app/src/main/res/values/styles.xml
-
7android/app/src/profile/AndroidManifest.xml
-
24android/build.gradle.kts
-
3android/gradle.properties
-
5android/gradle/wrapper/gradle-wrapper.properties
-
26android/settings.gradle.kts
-
3devtools_options.yaml
-
34ios/.gitignore
-
26ios/Flutter/AppFrameworkInfo.plist
-
2ios/Flutter/Debug.xcconfig
-
2ios/Flutter/Release.xcconfig
-
43ios/Podfile
-
616ios/Runner.xcodeproj/project.pbxproj
-
7ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata
-
8ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
-
8ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings
-
101ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme
-
7ios/Runner.xcworkspace/contents.xcworkspacedata
-
8ios/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
-
8ios/Runner.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings
-
13ios/Runner/AppDelegate.swift
-
122ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png
-
BINios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png
-
23ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json
-
BINios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png
-
BINios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png
-
BINios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png
-
5ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md
-
37ios/Runner/Base.lproj/LaunchScreen.storyboard
-
26ios/Runner/Base.lproj/Main.storyboard
-
49ios/Runner/Info.plist
-
1ios/Runner/Runner-Bridging-Header.h
-
12ios/RunnerTests/RunnerTests.swift
-
3l10n.yaml
-
7lib/common_ui/resources/my_assets.dart
-
11lib/common_ui/resources/my_colors.dart
-
27lib/common_ui/resources/my_spaces.dart
-
15lib/common_ui/resources/my_text_style.dart
-
32lib/common_ui/theme/my_theme.dart
-
31lib/common_ui/theme/theme_service.dart
-
28lib/core/auth_storage/auth_storage.dart
-
11lib/core/constants/my_api.dart
-
8lib/core/constants/my_constants.dart
-
32lib/core/error_handler/error_handler.dart
-
9lib/core/error_handler/my_exception.dart
-
20lib/core/middleware/auth_middleware.dart
-
63lib/core/network/http_request.dart
-
178lib/core/network/http_request_impl.dart
-
19lib/core/network/interceptors/logging_interceptor.dart
-
10lib/core/network/interceptors/token_interceptor.dart
-
13lib/core/params/sample_params.dart
-
19lib/core/response/base_response.dart
-
29lib/core/routers/my_routes.dart
-
31lib/core/status/base_status.dart
-
6lib/core/usecase/usecase.dart
-
15lib/core/utils/check_platform.dart
-
10lib/core/utils/context_provider.dart
-
22lib/core/utils/data_state.dart
-
8lib/core/utils/gap.dart
-
29lib/core/utils/local_storage.dart
-
61lib/core/utils/my_device.dart
-
6lib/core/utils/my_localization.dart
-
11lib/core/utils/my_scroll_behavior.dart
-
6lib/core/utils/screen_size.dart
-
28lib/features/sample/data/datasource/sample_datasource.dart
-
13lib/features/sample/data/model/sample_model.dart
-
29lib/features/sample/data/repository_impl/sample_repository_impl.dart
-
14lib/features/sample/domain/entity/sample_entity.dart
-
8lib/features/sample/domain/repository/sample_repository.dart
@ -0,0 +1,45 @@ |
|||
# Miscellaneous |
|||
*.class |
|||
*.log |
|||
*.pyc |
|||
*.swp |
|||
.DS_Store |
|||
.atom/ |
|||
.build/ |
|||
.buildlog/ |
|||
.history |
|||
.svn/ |
|||
.swiftpm/ |
|||
migrate_working_dir/ |
|||
|
|||
# IntelliJ related |
|||
*.iml |
|||
*.ipr |
|||
*.iws |
|||
.idea/ |
|||
|
|||
# The .vscode folder contains launch configuration and tasks you configure in |
|||
# VS Code which you may wish to be included in version control, so this line |
|||
# is commented out by default. |
|||
#.vscode/ |
|||
|
|||
# Flutter/Dart/Pub related |
|||
**/doc/api/ |
|||
**/ios/Flutter/.last_build_id |
|||
.dart_tool/ |
|||
.flutter-plugins-dependencies |
|||
.pub-cache/ |
|||
.pub/ |
|||
/build/ |
|||
/coverage/ |
|||
|
|||
# Symbolication related |
|||
app.*.symbols |
|||
|
|||
# Obfuscation related |
|||
app.*.map.json |
|||
|
|||
# Android Studio will place build artifacts here |
|||
/android/app/debug |
|||
/android/app/profile |
|||
/android/app/release |
@ -0,0 +1,33 @@ |
|||
# This file tracks properties of this Flutter project. |
|||
# Used by Flutter tool to assess capabilities and perform upgrades etc. |
|||
# |
|||
# This file should be version controlled and should not be manually edited. |
|||
|
|||
version: |
|||
revision: "d693b4b9dbac2acd4477aea4555ca6dcbea44ba2" |
|||
channel: "stable" |
|||
|
|||
project_type: app |
|||
|
|||
# Tracks metadata for the flutter migrate command |
|||
migration: |
|||
platforms: |
|||
- platform: root |
|||
create_revision: d693b4b9dbac2acd4477aea4555ca6dcbea44ba2 |
|||
base_revision: d693b4b9dbac2acd4477aea4555ca6dcbea44ba2 |
|||
- platform: android |
|||
create_revision: d693b4b9dbac2acd4477aea4555ca6dcbea44ba2 |
|||
base_revision: d693b4b9dbac2acd4477aea4555ca6dcbea44ba2 |
|||
- platform: ios |
|||
create_revision: d693b4b9dbac2acd4477aea4555ca6dcbea44ba2 |
|||
base_revision: d693b4b9dbac2acd4477aea4555ca6dcbea44ba2 |
|||
|
|||
# User provided section |
|||
|
|||
# List of Local paths (relative to this file) that should be |
|||
# ignored by the migrate tool. |
|||
# |
|||
# Files that are not part of the templates will be ignored by default. |
|||
unmanaged_files: |
|||
- 'lib/main.dart' |
|||
- 'ios/Runner.xcodeproj/project.pbxproj' |
@ -0,0 +1,3 @@ |
|||
# hadi_hoda_flutter |
|||
|
|||
A new Flutter project. |
@ -0,0 +1 @@ |
|||
include: package:flutter_lints/flutter.yaml |
@ -0,0 +1,14 @@ |
|||
gradle-wrapper.jar |
|||
/.gradle |
|||
/captures/ |
|||
/gradlew |
|||
/gradlew.bat |
|||
/local.properties |
|||
GeneratedPluginRegistrant.java |
|||
.cxx/ |
|||
|
|||
# Remember to never publicly share your keystore. |
|||
# See https://flutter.dev/to/reference-keystore |
|||
key.properties |
|||
**/*.keystore |
|||
**/*.jks |
@ -0,0 +1,44 @@ |
|||
plugins { |
|||
id("com.android.application") |
|||
id("kotlin-android") |
|||
// The Flutter Gradle Plugin must be applied after the Android and Kotlin Gradle plugins. |
|||
id("dev.flutter.flutter-gradle-plugin") |
|||
} |
|||
|
|||
android { |
|||
namespace = "com.example.hadi_hoda_flutter" |
|||
compileSdk = flutter.compileSdkVersion |
|||
ndkVersion = flutter.ndkVersion |
|||
|
|||
compileOptions { |
|||
sourceCompatibility = JavaVersion.VERSION_11 |
|||
targetCompatibility = JavaVersion.VERSION_11 |
|||
} |
|||
|
|||
kotlinOptions { |
|||
jvmTarget = JavaVersion.VERSION_11.toString() |
|||
} |
|||
|
|||
defaultConfig { |
|||
// TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). |
|||
applicationId = "com.example.hadi_hoda_flutter" |
|||
// You can update the following values to match your application needs. |
|||
// For more information, see: https://flutter.dev/to/review-gradle-config. |
|||
minSdk = flutter.minSdkVersion |
|||
targetSdk = flutter.targetSdkVersion |
|||
versionCode = flutter.versionCode |
|||
versionName = flutter.versionName |
|||
} |
|||
|
|||
buildTypes { |
|||
release { |
|||
// TODO: Add your own signing config for the release build. |
|||
// Signing with the debug keys for now, so `flutter run --release` works. |
|||
signingConfig = signingConfigs.getByName("debug") |
|||
} |
|||
} |
|||
} |
|||
|
|||
flutter { |
|||
source = "../.." |
|||
} |
@ -0,0 +1,7 @@ |
|||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"> |
|||
<!-- The INTERNET permission is required for development. Specifically, |
|||
the Flutter tool needs it to communicate with the running application |
|||
to allow setting breakpoints, to provide hot reload, etc. |
|||
--> |
|||
<uses-permission android:name="android.permission.INTERNET"/> |
|||
</manifest> |
@ -0,0 +1,45 @@ |
|||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"> |
|||
<application |
|||
android:label="hadi_hoda_flutter" |
|||
android:name="${applicationName}" |
|||
android:icon="@mipmap/ic_launcher"> |
|||
<activity |
|||
android:name=".MainActivity" |
|||
android:exported="true" |
|||
android:launchMode="singleTop" |
|||
android:taskAffinity="" |
|||
android:theme="@style/LaunchTheme" |
|||
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode" |
|||
android:hardwareAccelerated="true" |
|||
android:windowSoftInputMode="adjustResize"> |
|||
<!-- Specifies an Android theme to apply to this Activity as soon as |
|||
the Android process has started. This theme is visible to the user |
|||
while the Flutter UI initializes. After that, this theme continues |
|||
to determine the Window background behind the Flutter UI. --> |
|||
<meta-data |
|||
android:name="io.flutter.embedding.android.NormalTheme" |
|||
android:resource="@style/NormalTheme" |
|||
/> |
|||
<intent-filter> |
|||
<action android:name="android.intent.action.MAIN"/> |
|||
<category android:name="android.intent.category.LAUNCHER"/> |
|||
</intent-filter> |
|||
</activity> |
|||
<!-- Don't delete the meta-data below. |
|||
This is used by the Flutter tool to generate GeneratedPluginRegistrant.java --> |
|||
<meta-data |
|||
android:name="flutterEmbedding" |
|||
android:value="2" /> |
|||
</application> |
|||
<!-- Required to query activities that can process text, see: |
|||
https://developer.android.com/training/package-visibility and |
|||
https://developer.android.com/reference/android/content/Intent#ACTION_PROCESS_TEXT. |
|||
|
|||
In particular, this is used by the Flutter engine in io.flutter.plugin.text.ProcessTextPlugin. --> |
|||
<queries> |
|||
<intent> |
|||
<action android:name="android.intent.action.PROCESS_TEXT"/> |
|||
<data android:mimeType="text/plain"/> |
|||
</intent> |
|||
</queries> |
|||
</manifest> |
@ -0,0 +1,5 @@ |
|||
package com.example.hadi_hoda_flutter |
|||
|
|||
import io.flutter.embedding.android.FlutterActivity |
|||
|
|||
class MainActivity : FlutterActivity() |
@ -0,0 +1,12 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<!-- Modify this file to customize your launch splash screen --> |
|||
<layer-list xmlns:android="http://schemas.android.com/apk/res/android"> |
|||
<item android:drawable="?android:colorBackground" /> |
|||
|
|||
<!-- You can insert your own image assets here --> |
|||
<!-- <item> |
|||
<bitmap |
|||
android:gravity="center" |
|||
android:src="@mipmap/launch_image" /> |
|||
</item> --> |
|||
</layer-list> |
@ -0,0 +1,12 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<!-- Modify this file to customize your launch splash screen --> |
|||
<layer-list xmlns:android="http://schemas.android.com/apk/res/android"> |
|||
<item android:drawable="@android:color/white" /> |
|||
|
|||
<!-- You can insert your own image assets here --> |
|||
<!-- <item> |
|||
<bitmap |
|||
android:gravity="center" |
|||
android:src="@mipmap/launch_image" /> |
|||
</item> --> |
|||
</layer-list> |
After Width: 72 | Height: 72 | Size: 544 B |
After Width: 48 | Height: 48 | Size: 442 B |
After Width: 96 | Height: 96 | Size: 721 B |
After Width: 144 | Height: 144 | Size: 1.0 KiB |
After Width: 192 | Height: 192 | Size: 1.4 KiB |
@ -0,0 +1,18 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<resources> |
|||
<!-- Theme applied to the Android Window while the process is starting when the OS's Dark Mode setting is on --> |
|||
<style name="LaunchTheme" parent="@android:style/Theme.Black.NoTitleBar"> |
|||
<!-- Show a splash screen on the activity. Automatically removed when |
|||
the Flutter engine draws its first frame --> |
|||
<item name="android:windowBackground">@drawable/launch_background</item> |
|||
</style> |
|||
<!-- Theme applied to the Android Window as soon as the process has started. |
|||
This theme determines the color of the Android Window while your |
|||
Flutter UI initializes, as well as behind your Flutter UI while its |
|||
running. |
|||
|
|||
This Theme is only used starting with V2 of Flutter's Android embedding. --> |
|||
<style name="NormalTheme" parent="@android:style/Theme.Black.NoTitleBar"> |
|||
<item name="android:windowBackground">?android:colorBackground</item> |
|||
</style> |
|||
</resources> |
@ -0,0 +1,18 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<resources> |
|||
<!-- Theme applied to the Android Window while the process is starting when the OS's Dark Mode setting is off --> |
|||
<style name="LaunchTheme" parent="@android:style/Theme.Light.NoTitleBar"> |
|||
<!-- Show a splash screen on the activity. Automatically removed when |
|||
the Flutter engine draws its first frame --> |
|||
<item name="android:windowBackground">@drawable/launch_background</item> |
|||
</style> |
|||
<!-- Theme applied to the Android Window as soon as the process has started. |
|||
This theme determines the color of the Android Window while your |
|||
Flutter UI initializes, as well as behind your Flutter UI while its |
|||
running. |
|||
|
|||
This Theme is only used starting with V2 of Flutter's Android embedding. --> |
|||
<style name="NormalTheme" parent="@android:style/Theme.Light.NoTitleBar"> |
|||
<item name="android:windowBackground">?android:colorBackground</item> |
|||
</style> |
|||
</resources> |
@ -0,0 +1,7 @@ |
|||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"> |
|||
<!-- The INTERNET permission is required for development. Specifically, |
|||
the Flutter tool needs it to communicate with the running application |
|||
to allow setting breakpoints, to provide hot reload, etc. |
|||
--> |
|||
<uses-permission android:name="android.permission.INTERNET"/> |
|||
</manifest> |
@ -0,0 +1,24 @@ |
|||
allprojects { |
|||
repositories { |
|||
google() |
|||
mavenCentral() |
|||
} |
|||
} |
|||
|
|||
val newBuildDir: Directory = |
|||
rootProject.layout.buildDirectory |
|||
.dir("../../build") |
|||
.get() |
|||
rootProject.layout.buildDirectory.value(newBuildDir) |
|||
|
|||
subprojects { |
|||
val newSubprojectBuildDir: Directory = newBuildDir.dir(project.name) |
|||
project.layout.buildDirectory.value(newSubprojectBuildDir) |
|||
} |
|||
subprojects { |
|||
project.evaluationDependsOn(":app") |
|||
} |
|||
|
|||
tasks.register<Delete>("clean") { |
|||
delete(rootProject.layout.buildDirectory) |
|||
} |
@ -0,0 +1,3 @@ |
|||
org.gradle.jvmargs=-Xmx8G -XX:MaxMetaspaceSize=4G -XX:ReservedCodeCacheSize=512m -XX:+HeapDumpOnOutOfMemoryError |
|||
android.useAndroidX=true |
|||
android.enableJetifier=true |
@ -0,0 +1,5 @@ |
|||
distributionBase=GRADLE_USER_HOME |
|||
distributionPath=wrapper/dists |
|||
zipStoreBase=GRADLE_USER_HOME |
|||
zipStorePath=wrapper/dists |
|||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.12-all.zip |
@ -0,0 +1,26 @@ |
|||
pluginManagement { |
|||
val flutterSdkPath = |
|||
run { |
|||
val properties = java.util.Properties() |
|||
file("local.properties").inputStream().use { properties.load(it) } |
|||
val flutterSdkPath = properties.getProperty("flutter.sdk") |
|||
require(flutterSdkPath != null) { "flutter.sdk not set in local.properties" } |
|||
flutterSdkPath |
|||
} |
|||
|
|||
includeBuild("$flutterSdkPath/packages/flutter_tools/gradle") |
|||
|
|||
repositories { |
|||
google() |
|||
mavenCentral() |
|||
gradlePluginPortal() |
|||
} |
|||
} |
|||
|
|||
plugins { |
|||
id("dev.flutter.flutter-plugin-loader") version "1.0.0" |
|||
id("com.android.application") version "8.9.1" apply false |
|||
id("org.jetbrains.kotlin.android") version "2.1.0" apply false |
|||
} |
|||
|
|||
include(":app") |
@ -0,0 +1,3 @@ |
|||
description: This file stores settings for Dart & Flutter DevTools. |
|||
documentation: https://docs.flutter.dev/tools/devtools/extensions#configure-extension-enablement-states |
|||
extensions: |
@ -0,0 +1,34 @@ |
|||
**/dgph |
|||
*.mode1v3 |
|||
*.mode2v3 |
|||
*.moved-aside |
|||
*.pbxuser |
|||
*.perspectivev3 |
|||
**/*sync/ |
|||
.sconsign.dblite |
|||
.tags* |
|||
**/.vagrant/ |
|||
**/DerivedData/ |
|||
Icon? |
|||
**/Pods/ |
|||
**/.symlinks/ |
|||
profile |
|||
xcuserdata |
|||
**/.generated/ |
|||
Flutter/App.framework |
|||
Flutter/Flutter.framework |
|||
Flutter/Flutter.podspec |
|||
Flutter/Generated.xcconfig |
|||
Flutter/ephemeral/ |
|||
Flutter/app.flx |
|||
Flutter/app.zip |
|||
Flutter/flutter_assets/ |
|||
Flutter/flutter_export_environment.sh |
|||
ServiceDefinitions.json |
|||
Runner/GeneratedPluginRegistrant.* |
|||
|
|||
# Exceptions to above rules. |
|||
!default.mode1v3 |
|||
!default.mode2v3 |
|||
!default.pbxuser |
|||
!default.perspectivev3 |
@ -0,0 +1,26 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> |
|||
<plist version="1.0"> |
|||
<dict> |
|||
<key>CFBundleDevelopmentRegion</key> |
|||
<string>en</string> |
|||
<key>CFBundleExecutable</key> |
|||
<string>App</string> |
|||
<key>CFBundleIdentifier</key> |
|||
<string>io.flutter.flutter.app</string> |
|||
<key>CFBundleInfoDictionaryVersion</key> |
|||
<string>6.0</string> |
|||
<key>CFBundleName</key> |
|||
<string>App</string> |
|||
<key>CFBundlePackageType</key> |
|||
<string>FMWK</string> |
|||
<key>CFBundleShortVersionString</key> |
|||
<string>1.0</string> |
|||
<key>CFBundleSignature</key> |
|||
<string>????</string> |
|||
<key>CFBundleVersion</key> |
|||
<string>1.0</string> |
|||
<key>MinimumOSVersion</key> |
|||
<string>13.0</string> |
|||
</dict> |
|||
</plist> |
@ -0,0 +1,2 @@ |
|||
#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig" |
|||
#include "Generated.xcconfig" |
@ -0,0 +1,2 @@ |
|||
#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig" |
|||
#include "Generated.xcconfig" |
@ -0,0 +1,43 @@ |
|||
# Uncomment this line to define a global platform for your project |
|||
# platform :ios, '13.0' |
|||
|
|||
# CocoaPods analytics sends network stats synchronously affecting flutter build latency. |
|||
ENV['COCOAPODS_DISABLE_STATS'] = 'true' |
|||
|
|||
project 'Runner', { |
|||
'Debug' => :debug, |
|||
'Profile' => :release, |
|||
'Release' => :release, |
|||
} |
|||
|
|||
def flutter_root |
|||
generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'Generated.xcconfig'), __FILE__) |
|||
unless File.exist?(generated_xcode_build_settings_path) |
|||
raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure flutter pub get is executed first" |
|||
end |
|||
|
|||
File.foreach(generated_xcode_build_settings_path) do |line| |
|||
matches = line.match(/FLUTTER_ROOT\=(.*)/) |
|||
return matches[1].strip if matches |
|||
end |
|||
raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Generated.xcconfig, then run flutter pub get" |
|||
end |
|||
|
|||
require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root) |
|||
|
|||
flutter_ios_podfile_setup |
|||
|
|||
target 'Runner' do |
|||
use_frameworks! |
|||
|
|||
flutter_install_all_ios_pods File.dirname(File.realpath(__FILE__)) |
|||
target 'RunnerTests' do |
|||
inherit! :search_paths |
|||
end |
|||
end |
|||
|
|||
post_install do |installer| |
|||
installer.pods_project.targets.each do |target| |
|||
flutter_additional_ios_build_settings(target) |
|||
end |
|||
end |
@ -0,0 +1,616 @@ |
|||
// !$*UTF8*$! |
|||
{ |
|||
archiveVersion = 1; |
|||
classes = { |
|||
}; |
|||
objectVersion = 54; |
|||
objects = { |
|||
|
|||
/* Begin PBXBuildFile section */ |
|||
1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; }; |
|||
331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; }; |
|||
3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; }; |
|||
74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; }; |
|||
97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; }; |
|||
97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; }; |
|||
97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; }; |
|||
/* End PBXBuildFile section */ |
|||
|
|||
/* Begin PBXContainerItemProxy section */ |
|||
331C8085294A63A400263BE5 /* PBXContainerItemProxy */ = { |
|||
isa = PBXContainerItemProxy; |
|||
containerPortal = 97C146E61CF9000F007C117D /* Project object */; |
|||
proxyType = 1; |
|||
remoteGlobalIDString = 97C146ED1CF9000F007C117D; |
|||
remoteInfo = Runner; |
|||
}; |
|||
/* End PBXContainerItemProxy section */ |
|||
|
|||
/* Begin PBXCopyFilesBuildPhase section */ |
|||
9705A1C41CF9048500538489 /* Embed Frameworks */ = { |
|||
isa = PBXCopyFilesBuildPhase; |
|||
buildActionMask = 2147483647; |
|||
dstPath = ""; |
|||
dstSubfolderSpec = 10; |
|||
files = ( |
|||
); |
|||
name = "Embed Frameworks"; |
|||
runOnlyForDeploymentPostprocessing = 0; |
|||
}; |
|||
/* End PBXCopyFilesBuildPhase section */ |
|||
|
|||
/* Begin PBXFileReference section */ |
|||
1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = "<group>"; }; |
|||
1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = "<group>"; }; |
|||
331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = "<group>"; }; |
|||
331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; |
|||
3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; }; |
|||
74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = "<group>"; }; |
|||
74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; }; |
|||
7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = "<group>"; }; |
|||
9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = "<group>"; }; |
|||
9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = "<group>"; }; |
|||
97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; }; |
|||
97C146FB1CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = "<group>"; }; |
|||
97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; }; |
|||
97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; }; |
|||
97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; }; |
|||
/* End PBXFileReference section */ |
|||
|
|||
/* Begin PBXFrameworksBuildPhase section */ |
|||
97C146EB1CF9000F007C117D /* Frameworks */ = { |
|||
isa = PBXFrameworksBuildPhase; |
|||
buildActionMask = 2147483647; |
|||
files = ( |
|||
); |
|||
runOnlyForDeploymentPostprocessing = 0; |
|||
}; |
|||
/* End PBXFrameworksBuildPhase section */ |
|||
|
|||
/* Begin PBXGroup section */ |
|||
331C8082294A63A400263BE5 /* RunnerTests */ = { |
|||
isa = PBXGroup; |
|||
children = ( |
|||
331C807B294A618700263BE5 /* RunnerTests.swift */, |
|||
); |
|||
path = RunnerTests; |
|||
sourceTree = "<group>"; |
|||
}; |
|||
9740EEB11CF90186004384FC /* Flutter */ = { |
|||
isa = PBXGroup; |
|||
children = ( |
|||
3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */, |
|||
9740EEB21CF90195004384FC /* Debug.xcconfig */, |
|||
7AFA3C8E1D35360C0083082E /* Release.xcconfig */, |
|||
9740EEB31CF90195004384FC /* Generated.xcconfig */, |
|||
); |
|||
name = Flutter; |
|||
sourceTree = "<group>"; |
|||
}; |
|||
97C146E51CF9000F007C117D = { |
|||
isa = PBXGroup; |
|||
children = ( |
|||
9740EEB11CF90186004384FC /* Flutter */, |
|||
97C146F01CF9000F007C117D /* Runner */, |
|||
97C146EF1CF9000F007C117D /* Products */, |
|||
331C8082294A63A400263BE5 /* RunnerTests */, |
|||
); |
|||
sourceTree = "<group>"; |
|||
}; |
|||
97C146EF1CF9000F007C117D /* Products */ = { |
|||
isa = PBXGroup; |
|||
children = ( |
|||
97C146EE1CF9000F007C117D /* Runner.app */, |
|||
331C8081294A63A400263BE5 /* RunnerTests.xctest */, |
|||
); |
|||
name = Products; |
|||
sourceTree = "<group>"; |
|||
}; |
|||
97C146F01CF9000F007C117D /* Runner */ = { |
|||
isa = PBXGroup; |
|||
children = ( |
|||
97C146FA1CF9000F007C117D /* Main.storyboard */, |
|||
97C146FD1CF9000F007C117D /* Assets.xcassets */, |
|||
97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */, |
|||
97C147021CF9000F007C117D /* Info.plist */, |
|||
1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */, |
|||
1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */, |
|||
74858FAE1ED2DC5600515810 /* AppDelegate.swift */, |
|||
74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */, |
|||
); |
|||
path = Runner; |
|||
sourceTree = "<group>"; |
|||
}; |
|||
/* End PBXGroup section */ |
|||
|
|||
/* Begin PBXNativeTarget section */ |
|||
331C8080294A63A400263BE5 /* RunnerTests */ = { |
|||
isa = PBXNativeTarget; |
|||
buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */; |
|||
buildPhases = ( |
|||
331C807D294A63A400263BE5 /* Sources */, |
|||
331C807F294A63A400263BE5 /* Resources */, |
|||
); |
|||
buildRules = ( |
|||
); |
|||
dependencies = ( |
|||
331C8086294A63A400263BE5 /* PBXTargetDependency */, |
|||
); |
|||
name = RunnerTests; |
|||
productName = RunnerTests; |
|||
productReference = 331C8081294A63A400263BE5 /* RunnerTests.xctest */; |
|||
productType = "com.apple.product-type.bundle.unit-test"; |
|||
}; |
|||
97C146ED1CF9000F007C117D /* Runner */ = { |
|||
isa = PBXNativeTarget; |
|||
buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */; |
|||
buildPhases = ( |
|||
9740EEB61CF901F6004384FC /* Run Script */, |
|||
97C146EA1CF9000F007C117D /* Sources */, |
|||
97C146EB1CF9000F007C117D /* Frameworks */, |
|||
97C146EC1CF9000F007C117D /* Resources */, |
|||
9705A1C41CF9048500538489 /* Embed Frameworks */, |
|||
3B06AD1E1E4923F5004D2608 /* Thin Binary */, |
|||
); |
|||
buildRules = ( |
|||
); |
|||
dependencies = ( |
|||
); |
|||
name = Runner; |
|||
productName = Runner; |
|||
productReference = 97C146EE1CF9000F007C117D /* Runner.app */; |
|||
productType = "com.apple.product-type.application"; |
|||
}; |
|||
/* End PBXNativeTarget section */ |
|||
|
|||
/* Begin PBXProject section */ |
|||
97C146E61CF9000F007C117D /* Project object */ = { |
|||
isa = PBXProject; |
|||
attributes = { |
|||
BuildIndependentTargetsInParallel = YES; |
|||
LastUpgradeCheck = 1510; |
|||
ORGANIZATIONNAME = ""; |
|||
TargetAttributes = { |
|||
331C8080294A63A400263BE5 = { |
|||
CreatedOnToolsVersion = 14.0; |
|||
TestTargetID = 97C146ED1CF9000F007C117D; |
|||
}; |
|||
97C146ED1CF9000F007C117D = { |
|||
CreatedOnToolsVersion = 7.3.1; |
|||
LastSwiftMigration = 1100; |
|||
}; |
|||
}; |
|||
}; |
|||
buildConfigurationList = 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */; |
|||
compatibilityVersion = "Xcode 9.3"; |
|||
developmentRegion = en; |
|||
hasScannedForEncodings = 0; |
|||
knownRegions = ( |
|||
en, |
|||
Base, |
|||
); |
|||
mainGroup = 97C146E51CF9000F007C117D; |
|||
productRefGroup = 97C146EF1CF9000F007C117D /* Products */; |
|||
projectDirPath = ""; |
|||
projectRoot = ""; |
|||
targets = ( |
|||
97C146ED1CF9000F007C117D /* Runner */, |
|||
331C8080294A63A400263BE5 /* RunnerTests */, |
|||
); |
|||
}; |
|||
/* End PBXProject section */ |
|||
|
|||
/* Begin PBXResourcesBuildPhase section */ |
|||
331C807F294A63A400263BE5 /* Resources */ = { |
|||
isa = PBXResourcesBuildPhase; |
|||
buildActionMask = 2147483647; |
|||
files = ( |
|||
); |
|||
runOnlyForDeploymentPostprocessing = 0; |
|||
}; |
|||
97C146EC1CF9000F007C117D /* Resources */ = { |
|||
isa = PBXResourcesBuildPhase; |
|||
buildActionMask = 2147483647; |
|||
files = ( |
|||
97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */, |
|||
3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */, |
|||
97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */, |
|||
97C146FC1CF9000F007C117D /* Main.storyboard in Resources */, |
|||
); |
|||
runOnlyForDeploymentPostprocessing = 0; |
|||
}; |
|||
/* End PBXResourcesBuildPhase section */ |
|||
|
|||
/* Begin PBXShellScriptBuildPhase section */ |
|||
3B06AD1E1E4923F5004D2608 /* Thin Binary */ = { |
|||
isa = PBXShellScriptBuildPhase; |
|||
alwaysOutOfDate = 1; |
|||
buildActionMask = 2147483647; |
|||
files = ( |
|||
); |
|||
inputPaths = ( |
|||
"${TARGET_BUILD_DIR}/${INFOPLIST_PATH}", |
|||
); |
|||
name = "Thin Binary"; |
|||
outputPaths = ( |
|||
); |
|||
runOnlyForDeploymentPostprocessing = 0; |
|||
shellPath = /bin/sh; |
|||
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin"; |
|||
}; |
|||
9740EEB61CF901F6004384FC /* Run Script */ = { |
|||
isa = PBXShellScriptBuildPhase; |
|||
alwaysOutOfDate = 1; |
|||
buildActionMask = 2147483647; |
|||
files = ( |
|||
); |
|||
inputPaths = ( |
|||
); |
|||
name = "Run Script"; |
|||
outputPaths = ( |
|||
); |
|||
runOnlyForDeploymentPostprocessing = 0; |
|||
shellPath = /bin/sh; |
|||
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build"; |
|||
}; |
|||
/* End PBXShellScriptBuildPhase section */ |
|||
|
|||
/* Begin PBXSourcesBuildPhase section */ |
|||
331C807D294A63A400263BE5 /* Sources */ = { |
|||
isa = PBXSourcesBuildPhase; |
|||
buildActionMask = 2147483647; |
|||
files = ( |
|||
331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */, |
|||
); |
|||
runOnlyForDeploymentPostprocessing = 0; |
|||
}; |
|||
97C146EA1CF9000F007C117D /* Sources */ = { |
|||
isa = PBXSourcesBuildPhase; |
|||
buildActionMask = 2147483647; |
|||
files = ( |
|||
74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */, |
|||
1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */, |
|||
); |
|||
runOnlyForDeploymentPostprocessing = 0; |
|||
}; |
|||
/* End PBXSourcesBuildPhase section */ |
|||
|
|||
/* Begin PBXTargetDependency section */ |
|||
331C8086294A63A400263BE5 /* PBXTargetDependency */ = { |
|||
isa = PBXTargetDependency; |
|||
target = 97C146ED1CF9000F007C117D /* Runner */; |
|||
targetProxy = 331C8085294A63A400263BE5 /* PBXContainerItemProxy */; |
|||
}; |
|||
/* End PBXTargetDependency section */ |
|||
|
|||
/* Begin PBXVariantGroup section */ |
|||
97C146FA1CF9000F007C117D /* Main.storyboard */ = { |
|||
isa = PBXVariantGroup; |
|||
children = ( |
|||
97C146FB1CF9000F007C117D /* Base */, |
|||
); |
|||
name = Main.storyboard; |
|||
sourceTree = "<group>"; |
|||
}; |
|||
97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */ = { |
|||
isa = PBXVariantGroup; |
|||
children = ( |
|||
97C147001CF9000F007C117D /* Base */, |
|||
); |
|||
name = LaunchScreen.storyboard; |
|||
sourceTree = "<group>"; |
|||
}; |
|||
/* End PBXVariantGroup section */ |
|||
|
|||
/* Begin XCBuildConfiguration section */ |
|||
249021D3217E4FDB00AE95B9 /* Profile */ = { |
|||
isa = XCBuildConfiguration; |
|||
buildSettings = { |
|||
ALWAYS_SEARCH_USER_PATHS = NO; |
|||
ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; |
|||
CLANG_ANALYZER_NONNULL = YES; |
|||
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; |
|||
CLANG_CXX_LIBRARY = "libc++"; |
|||
CLANG_ENABLE_MODULES = YES; |
|||
CLANG_ENABLE_OBJC_ARC = YES; |
|||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; |
|||
CLANG_WARN_BOOL_CONVERSION = YES; |
|||
CLANG_WARN_COMMA = YES; |
|||
CLANG_WARN_CONSTANT_CONVERSION = YES; |
|||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; |
|||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; |
|||
CLANG_WARN_EMPTY_BODY = YES; |
|||
CLANG_WARN_ENUM_CONVERSION = YES; |
|||
CLANG_WARN_INFINITE_RECURSION = YES; |
|||
CLANG_WARN_INT_CONVERSION = YES; |
|||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; |
|||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; |
|||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; |
|||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; |
|||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; |
|||
CLANG_WARN_STRICT_PROTOTYPES = YES; |
|||
CLANG_WARN_SUSPICIOUS_MOVE = YES; |
|||
CLANG_WARN_UNREACHABLE_CODE = YES; |
|||
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; |
|||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; |
|||
COPY_PHASE_STRIP = NO; |
|||
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; |
|||
ENABLE_NS_ASSERTIONS = NO; |
|||
ENABLE_STRICT_OBJC_MSGSEND = YES; |
|||
ENABLE_USER_SCRIPT_SANDBOXING = NO; |
|||
GCC_C_LANGUAGE_STANDARD = gnu99; |
|||
GCC_NO_COMMON_BLOCKS = YES; |
|||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES; |
|||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; |
|||
GCC_WARN_UNDECLARED_SELECTOR = YES; |
|||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; |
|||
GCC_WARN_UNUSED_FUNCTION = YES; |
|||
GCC_WARN_UNUSED_VARIABLE = YES; |
|||
IPHONEOS_DEPLOYMENT_TARGET = 13.0; |
|||
MTL_ENABLE_DEBUG_INFO = NO; |
|||
SDKROOT = iphoneos; |
|||
SUPPORTED_PLATFORMS = iphoneos; |
|||
TARGETED_DEVICE_FAMILY = "1,2"; |
|||
VALIDATE_PRODUCT = YES; |
|||
}; |
|||
name = Profile; |
|||
}; |
|||
249021D4217E4FDB00AE95B9 /* Profile */ = { |
|||
isa = XCBuildConfiguration; |
|||
baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */; |
|||
buildSettings = { |
|||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; |
|||
CLANG_ENABLE_MODULES = YES; |
|||
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; |
|||
ENABLE_BITCODE = NO; |
|||
INFOPLIST_FILE = Runner/Info.plist; |
|||
LD_RUNPATH_SEARCH_PATHS = ( |
|||
"$(inherited)", |
|||
"@executable_path/Frameworks", |
|||
); |
|||
PRODUCT_BUNDLE_IDENTIFIER = com.example.hadiHodaFlutter; |
|||
PRODUCT_NAME = "$(TARGET_NAME)"; |
|||
SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; |
|||
SWIFT_VERSION = 5.0; |
|||
VERSIONING_SYSTEM = "apple-generic"; |
|||
}; |
|||
name = Profile; |
|||
}; |
|||
331C8088294A63A400263BE5 /* Debug */ = { |
|||
isa = XCBuildConfiguration; |
|||
buildSettings = { |
|||
BUNDLE_LOADER = "$(TEST_HOST)"; |
|||
CODE_SIGN_STYLE = Automatic; |
|||
CURRENT_PROJECT_VERSION = 1; |
|||
GENERATE_INFOPLIST_FILE = YES; |
|||
MARKETING_VERSION = 1.0; |
|||
PRODUCT_BUNDLE_IDENTIFIER = com.example.hadiHodaFlutter.RunnerTests; |
|||
PRODUCT_NAME = "$(TARGET_NAME)"; |
|||
SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; |
|||
SWIFT_OPTIMIZATION_LEVEL = "-Onone"; |
|||
SWIFT_VERSION = 5.0; |
|||
TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner"; |
|||
}; |
|||
name = Debug; |
|||
}; |
|||
331C8089294A63A400263BE5 /* Release */ = { |
|||
isa = XCBuildConfiguration; |
|||
buildSettings = { |
|||
BUNDLE_LOADER = "$(TEST_HOST)"; |
|||
CODE_SIGN_STYLE = Automatic; |
|||
CURRENT_PROJECT_VERSION = 1; |
|||
GENERATE_INFOPLIST_FILE = YES; |
|||
MARKETING_VERSION = 1.0; |
|||
PRODUCT_BUNDLE_IDENTIFIER = com.example.hadiHodaFlutter.RunnerTests; |
|||
PRODUCT_NAME = "$(TARGET_NAME)"; |
|||
SWIFT_VERSION = 5.0; |
|||
TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner"; |
|||
}; |
|||
name = Release; |
|||
}; |
|||
331C808A294A63A400263BE5 /* Profile */ = { |
|||
isa = XCBuildConfiguration; |
|||
buildSettings = { |
|||
BUNDLE_LOADER = "$(TEST_HOST)"; |
|||
CODE_SIGN_STYLE = Automatic; |
|||
CURRENT_PROJECT_VERSION = 1; |
|||
GENERATE_INFOPLIST_FILE = YES; |
|||
MARKETING_VERSION = 1.0; |
|||
PRODUCT_BUNDLE_IDENTIFIER = com.example.hadiHodaFlutter.RunnerTests; |
|||
PRODUCT_NAME = "$(TARGET_NAME)"; |
|||
SWIFT_VERSION = 5.0; |
|||
TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner"; |
|||
}; |
|||
name = Profile; |
|||
}; |
|||
97C147031CF9000F007C117D /* Debug */ = { |
|||
isa = XCBuildConfiguration; |
|||
buildSettings = { |
|||
ALWAYS_SEARCH_USER_PATHS = NO; |
|||
ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; |
|||
CLANG_ANALYZER_NONNULL = YES; |
|||
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; |
|||
CLANG_CXX_LIBRARY = "libc++"; |
|||
CLANG_ENABLE_MODULES = YES; |
|||
CLANG_ENABLE_OBJC_ARC = YES; |
|||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; |
|||
CLANG_WARN_BOOL_CONVERSION = YES; |
|||
CLANG_WARN_COMMA = YES; |
|||
CLANG_WARN_CONSTANT_CONVERSION = YES; |
|||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; |
|||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; |
|||
CLANG_WARN_EMPTY_BODY = YES; |
|||
CLANG_WARN_ENUM_CONVERSION = YES; |
|||
CLANG_WARN_INFINITE_RECURSION = YES; |
|||
CLANG_WARN_INT_CONVERSION = YES; |
|||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; |
|||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; |
|||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; |
|||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; |
|||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; |
|||
CLANG_WARN_STRICT_PROTOTYPES = YES; |
|||
CLANG_WARN_SUSPICIOUS_MOVE = YES; |
|||
CLANG_WARN_UNREACHABLE_CODE = YES; |
|||
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; |
|||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; |
|||
COPY_PHASE_STRIP = NO; |
|||
DEBUG_INFORMATION_FORMAT = dwarf; |
|||
ENABLE_STRICT_OBJC_MSGSEND = YES; |
|||
ENABLE_TESTABILITY = YES; |
|||
ENABLE_USER_SCRIPT_SANDBOXING = NO; |
|||
GCC_C_LANGUAGE_STANDARD = gnu99; |
|||
GCC_DYNAMIC_NO_PIC = NO; |
|||
GCC_NO_COMMON_BLOCKS = YES; |
|||
GCC_OPTIMIZATION_LEVEL = 0; |
|||
GCC_PREPROCESSOR_DEFINITIONS = ( |
|||
"DEBUG=1", |
|||
"$(inherited)", |
|||
); |
|||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES; |
|||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; |
|||
GCC_WARN_UNDECLARED_SELECTOR = YES; |
|||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; |
|||
GCC_WARN_UNUSED_FUNCTION = YES; |
|||
GCC_WARN_UNUSED_VARIABLE = YES; |
|||
IPHONEOS_DEPLOYMENT_TARGET = 13.0; |
|||
MTL_ENABLE_DEBUG_INFO = YES; |
|||
ONLY_ACTIVE_ARCH = YES; |
|||
SDKROOT = iphoneos; |
|||
TARGETED_DEVICE_FAMILY = "1,2"; |
|||
}; |
|||
name = Debug; |
|||
}; |
|||
97C147041CF9000F007C117D /* Release */ = { |
|||
isa = XCBuildConfiguration; |
|||
buildSettings = { |
|||
ALWAYS_SEARCH_USER_PATHS = NO; |
|||
ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; |
|||
CLANG_ANALYZER_NONNULL = YES; |
|||
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; |
|||
CLANG_CXX_LIBRARY = "libc++"; |
|||
CLANG_ENABLE_MODULES = YES; |
|||
CLANG_ENABLE_OBJC_ARC = YES; |
|||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; |
|||
CLANG_WARN_BOOL_CONVERSION = YES; |
|||
CLANG_WARN_COMMA = YES; |
|||
CLANG_WARN_CONSTANT_CONVERSION = YES; |
|||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; |
|||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; |
|||
CLANG_WARN_EMPTY_BODY = YES; |
|||
CLANG_WARN_ENUM_CONVERSION = YES; |
|||
CLANG_WARN_INFINITE_RECURSION = YES; |
|||
CLANG_WARN_INT_CONVERSION = YES; |
|||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; |
|||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; |
|||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; |
|||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; |
|||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; |
|||
CLANG_WARN_STRICT_PROTOTYPES = YES; |
|||
CLANG_WARN_SUSPICIOUS_MOVE = YES; |
|||
CLANG_WARN_UNREACHABLE_CODE = YES; |
|||
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; |
|||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; |
|||
COPY_PHASE_STRIP = NO; |
|||
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; |
|||
ENABLE_NS_ASSERTIONS = NO; |
|||
ENABLE_STRICT_OBJC_MSGSEND = YES; |
|||
ENABLE_USER_SCRIPT_SANDBOXING = NO; |
|||
GCC_C_LANGUAGE_STANDARD = gnu99; |
|||
GCC_NO_COMMON_BLOCKS = YES; |
|||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES; |
|||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; |
|||
GCC_WARN_UNDECLARED_SELECTOR = YES; |
|||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; |
|||
GCC_WARN_UNUSED_FUNCTION = YES; |
|||
GCC_WARN_UNUSED_VARIABLE = YES; |
|||
IPHONEOS_DEPLOYMENT_TARGET = 13.0; |
|||
MTL_ENABLE_DEBUG_INFO = NO; |
|||
SDKROOT = iphoneos; |
|||
SUPPORTED_PLATFORMS = iphoneos; |
|||
SWIFT_COMPILATION_MODE = wholemodule; |
|||
SWIFT_OPTIMIZATION_LEVEL = "-O"; |
|||
TARGETED_DEVICE_FAMILY = "1,2"; |
|||
VALIDATE_PRODUCT = YES; |
|||
}; |
|||
name = Release; |
|||
}; |
|||
97C147061CF9000F007C117D /* Debug */ = { |
|||
isa = XCBuildConfiguration; |
|||
baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */; |
|||
buildSettings = { |
|||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; |
|||
CLANG_ENABLE_MODULES = YES; |
|||
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; |
|||
ENABLE_BITCODE = NO; |
|||
INFOPLIST_FILE = Runner/Info.plist; |
|||
LD_RUNPATH_SEARCH_PATHS = ( |
|||
"$(inherited)", |
|||
"@executable_path/Frameworks", |
|||
); |
|||
PRODUCT_BUNDLE_IDENTIFIER = com.example.hadiHodaFlutter; |
|||
PRODUCT_NAME = "$(TARGET_NAME)"; |
|||
SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; |
|||
SWIFT_OPTIMIZATION_LEVEL = "-Onone"; |
|||
SWIFT_VERSION = 5.0; |
|||
VERSIONING_SYSTEM = "apple-generic"; |
|||
}; |
|||
name = Debug; |
|||
}; |
|||
97C147071CF9000F007C117D /* Release */ = { |
|||
isa = XCBuildConfiguration; |
|||
baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */; |
|||
buildSettings = { |
|||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; |
|||
CLANG_ENABLE_MODULES = YES; |
|||
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; |
|||
ENABLE_BITCODE = NO; |
|||
INFOPLIST_FILE = Runner/Info.plist; |
|||
LD_RUNPATH_SEARCH_PATHS = ( |
|||
"$(inherited)", |
|||
"@executable_path/Frameworks", |
|||
); |
|||
PRODUCT_BUNDLE_IDENTIFIER = com.example.hadiHodaFlutter; |
|||
PRODUCT_NAME = "$(TARGET_NAME)"; |
|||
SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; |
|||
SWIFT_VERSION = 5.0; |
|||
VERSIONING_SYSTEM = "apple-generic"; |
|||
}; |
|||
name = Release; |
|||
}; |
|||
/* End XCBuildConfiguration section */ |
|||
|
|||
/* Begin XCConfigurationList section */ |
|||
331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */ = { |
|||
isa = XCConfigurationList; |
|||
buildConfigurations = ( |
|||
331C8088294A63A400263BE5 /* Debug */, |
|||
331C8089294A63A400263BE5 /* Release */, |
|||
331C808A294A63A400263BE5 /* Profile */, |
|||
); |
|||
defaultConfigurationIsVisible = 0; |
|||
defaultConfigurationName = Release; |
|||
}; |
|||
97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */ = { |
|||
isa = XCConfigurationList; |
|||
buildConfigurations = ( |
|||
97C147031CF9000F007C117D /* Debug */, |
|||
97C147041CF9000F007C117D /* Release */, |
|||
249021D3217E4FDB00AE95B9 /* Profile */, |
|||
); |
|||
defaultConfigurationIsVisible = 0; |
|||
defaultConfigurationName = Release; |
|||
}; |
|||
97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */ = { |
|||
isa = XCConfigurationList; |
|||
buildConfigurations = ( |
|||
97C147061CF9000F007C117D /* Debug */, |
|||
97C147071CF9000F007C117D /* Release */, |
|||
249021D4217E4FDB00AE95B9 /* Profile */, |
|||
); |
|||
defaultConfigurationIsVisible = 0; |
|||
defaultConfigurationName = Release; |
|||
}; |
|||
/* End XCConfigurationList section */ |
|||
}; |
|||
rootObject = 97C146E61CF9000F007C117D /* Project object */; |
|||
} |
@ -0,0 +1,7 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<Workspace |
|||
version = "1.0"> |
|||
<FileRef |
|||
location = "self:"> |
|||
</FileRef> |
|||
</Workspace> |
@ -0,0 +1,8 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> |
|||
<plist version="1.0"> |
|||
<dict> |
|||
<key>IDEDidComputeMac32BitWarning</key> |
|||
<true/> |
|||
</dict> |
|||
</plist> |
@ -0,0 +1,8 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> |
|||
<plist version="1.0"> |
|||
<dict> |
|||
<key>PreviewsEnabled</key> |
|||
<false/> |
|||
</dict> |
|||
</plist> |
@ -0,0 +1,101 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<Scheme |
|||
LastUpgradeVersion = "1510" |
|||
version = "1.3"> |
|||
<BuildAction |
|||
parallelizeBuildables = "YES" |
|||
buildImplicitDependencies = "YES"> |
|||
<BuildActionEntries> |
|||
<BuildActionEntry |
|||
buildForTesting = "YES" |
|||
buildForRunning = "YES" |
|||
buildForProfiling = "YES" |
|||
buildForArchiving = "YES" |
|||
buildForAnalyzing = "YES"> |
|||
<BuildableReference |
|||
BuildableIdentifier = "primary" |
|||
BlueprintIdentifier = "97C146ED1CF9000F007C117D" |
|||
BuildableName = "Runner.app" |
|||
BlueprintName = "Runner" |
|||
ReferencedContainer = "container:Runner.xcodeproj"> |
|||
</BuildableReference> |
|||
</BuildActionEntry> |
|||
</BuildActionEntries> |
|||
</BuildAction> |
|||
<TestAction |
|||
buildConfiguration = "Debug" |
|||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" |
|||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" |
|||
customLLDBInitFile = "$(SRCROOT)/Flutter/ephemeral/flutter_lldbinit" |
|||
shouldUseLaunchSchemeArgsEnv = "YES"> |
|||
<MacroExpansion> |
|||
<BuildableReference |
|||
BuildableIdentifier = "primary" |
|||
BlueprintIdentifier = "97C146ED1CF9000F007C117D" |
|||
BuildableName = "Runner.app" |
|||
BlueprintName = "Runner" |
|||
ReferencedContainer = "container:Runner.xcodeproj"> |
|||
</BuildableReference> |
|||
</MacroExpansion> |
|||
<Testables> |
|||
<TestableReference |
|||
skipped = "NO" |
|||
parallelizable = "YES"> |
|||
<BuildableReference |
|||
BuildableIdentifier = "primary" |
|||
BlueprintIdentifier = "331C8080294A63A400263BE5" |
|||
BuildableName = "RunnerTests.xctest" |
|||
BlueprintName = "RunnerTests" |
|||
ReferencedContainer = "container:Runner.xcodeproj"> |
|||
</BuildableReference> |
|||
</TestableReference> |
|||
</Testables> |
|||
</TestAction> |
|||
<LaunchAction |
|||
buildConfiguration = "Debug" |
|||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" |
|||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" |
|||
customLLDBInitFile = "$(SRCROOT)/Flutter/ephemeral/flutter_lldbinit" |
|||
launchStyle = "0" |
|||
useCustomWorkingDirectory = "NO" |
|||
ignoresPersistentStateOnLaunch = "NO" |
|||
debugDocumentVersioning = "YES" |
|||
debugServiceExtension = "internal" |
|||
enableGPUValidationMode = "1" |
|||
allowLocationSimulation = "YES"> |
|||
<BuildableProductRunnable |
|||
runnableDebuggingMode = "0"> |
|||
<BuildableReference |
|||
BuildableIdentifier = "primary" |
|||
BlueprintIdentifier = "97C146ED1CF9000F007C117D" |
|||
BuildableName = "Runner.app" |
|||
BlueprintName = "Runner" |
|||
ReferencedContainer = "container:Runner.xcodeproj"> |
|||
</BuildableReference> |
|||
</BuildableProductRunnable> |
|||
</LaunchAction> |
|||
<ProfileAction |
|||
buildConfiguration = "Profile" |
|||
shouldUseLaunchSchemeArgsEnv = "YES" |
|||
savedToolIdentifier = "" |
|||
useCustomWorkingDirectory = "NO" |
|||
debugDocumentVersioning = "YES"> |
|||
<BuildableProductRunnable |
|||
runnableDebuggingMode = "0"> |
|||
<BuildableReference |
|||
BuildableIdentifier = "primary" |
|||
BlueprintIdentifier = "97C146ED1CF9000F007C117D" |
|||
BuildableName = "Runner.app" |
|||
BlueprintName = "Runner" |
|||
ReferencedContainer = "container:Runner.xcodeproj"> |
|||
</BuildableReference> |
|||
</BuildableProductRunnable> |
|||
</ProfileAction> |
|||
<AnalyzeAction |
|||
buildConfiguration = "Debug"> |
|||
</AnalyzeAction> |
|||
<ArchiveAction |
|||
buildConfiguration = "Release" |
|||
revealArchiveInOrganizer = "YES"> |
|||
</ArchiveAction> |
|||
</Scheme> |
@ -0,0 +1,7 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<Workspace |
|||
version = "1.0"> |
|||
<FileRef |
|||
location = "group:Runner.xcodeproj"> |
|||
</FileRef> |
|||
</Workspace> |
@ -0,0 +1,8 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> |
|||
<plist version="1.0"> |
|||
<dict> |
|||
<key>IDEDidComputeMac32BitWarning</key> |
|||
<true/> |
|||
</dict> |
|||
</plist> |
@ -0,0 +1,8 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> |
|||
<plist version="1.0"> |
|||
<dict> |
|||
<key>PreviewsEnabled</key> |
|||
<false/> |
|||
</dict> |
|||
</plist> |
@ -0,0 +1,13 @@ |
|||
import Flutter |
|||
import UIKit |
|||
|
|||
@main |
|||
@objc class AppDelegate: FlutterAppDelegate { |
|||
override func application( |
|||
_ application: UIApplication, |
|||
didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]? |
|||
) -> Bool { |
|||
GeneratedPluginRegistrant.register(with: self) |
|||
return super.application(application, didFinishLaunchingWithOptions: launchOptions) |
|||
} |
|||
} |
@ -0,0 +1,122 @@ |
|||
{ |
|||
"images" : [ |
|||
{ |
|||
"size" : "20x20", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-20x20@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "20x20", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-20x20@3x.png", |
|||
"scale" : "3x" |
|||
}, |
|||
{ |
|||
"size" : "29x29", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-29x29@1x.png", |
|||
"scale" : "1x" |
|||
}, |
|||
{ |
|||
"size" : "29x29", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-29x29@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "29x29", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-29x29@3x.png", |
|||
"scale" : "3x" |
|||
}, |
|||
{ |
|||
"size" : "40x40", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-40x40@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "40x40", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-40x40@3x.png", |
|||
"scale" : "3x" |
|||
}, |
|||
{ |
|||
"size" : "60x60", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-60x60@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "60x60", |
|||
"idiom" : "iphone", |
|||
"filename" : "Icon-App-60x60@3x.png", |
|||
"scale" : "3x" |
|||
}, |
|||
{ |
|||
"size" : "20x20", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-20x20@1x.png", |
|||
"scale" : "1x" |
|||
}, |
|||
{ |
|||
"size" : "20x20", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-20x20@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "29x29", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-29x29@1x.png", |
|||
"scale" : "1x" |
|||
}, |
|||
{ |
|||
"size" : "29x29", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-29x29@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "40x40", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-40x40@1x.png", |
|||
"scale" : "1x" |
|||
}, |
|||
{ |
|||
"size" : "40x40", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-40x40@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "76x76", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-76x76@1x.png", |
|||
"scale" : "1x" |
|||
}, |
|||
{ |
|||
"size" : "76x76", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-76x76@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "83.5x83.5", |
|||
"idiom" : "ipad", |
|||
"filename" : "Icon-App-83.5x83.5@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"size" : "1024x1024", |
|||
"idiom" : "ios-marketing", |
|||
"filename" : "Icon-App-1024x1024@1x.png", |
|||
"scale" : "1x" |
|||
} |
|||
], |
|||
"info" : { |
|||
"version" : 1, |
|||
"author" : "xcode" |
|||
} |
|||
} |
After Width: 1024 | Height: 1024 | Size: 11 KiB |
After Width: 20 | Height: 20 | Size: 295 B |
After Width: 40 | Height: 40 | Size: 406 B |
After Width: 60 | Height: 60 | Size: 450 B |
After Width: 29 | Height: 29 | Size: 282 B |
After Width: 58 | Height: 58 | Size: 462 B |
After Width: 87 | Height: 87 | Size: 704 B |
After Width: 40 | Height: 40 | Size: 406 B |
After Width: 80 | Height: 80 | Size: 586 B |
After Width: 120 | Height: 120 | Size: 862 B |
After Width: 120 | Height: 120 | Size: 862 B |
After Width: 180 | Height: 180 | Size: 1.6 KiB |
After Width: 76 | Height: 76 | Size: 762 B |
After Width: 152 | Height: 152 | Size: 1.2 KiB |
After Width: 167 | Height: 167 | Size: 1.4 KiB |
@ -0,0 +1,23 @@ |
|||
{ |
|||
"images" : [ |
|||
{ |
|||
"idiom" : "universal", |
|||
"filename" : "LaunchImage.png", |
|||
"scale" : "1x" |
|||
}, |
|||
{ |
|||
"idiom" : "universal", |
|||
"filename" : "LaunchImage@2x.png", |
|||
"scale" : "2x" |
|||
}, |
|||
{ |
|||
"idiom" : "universal", |
|||
"filename" : "LaunchImage@3x.png", |
|||
"scale" : "3x" |
|||
} |
|||
], |
|||
"info" : { |
|||
"version" : 1, |
|||
"author" : "xcode" |
|||
} |
|||
} |
After Width: 1 | Height: 1 | Size: 68 B |
After Width: 1 | Height: 1 | Size: 68 B |
After Width: 1 | Height: 1 | Size: 68 B |
@ -0,0 +1,5 @@ |
|||
# Launch Screen Assets |
|||
|
|||
You can customize the launch screen with your own desired assets by replacing the image files in this directory. |
|||
|
|||
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. |
@ -0,0 +1,37 @@ |
|||
<?xml version="1.0" encoding="UTF-8" standalone="no"?> |
|||
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="12121" systemVersion="16G29" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" colorMatched="YES" initialViewController="01J-lp-oVM"> |
|||
<dependencies> |
|||
<deployment identifier="iOS"/> |
|||
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="12089"/> |
|||
</dependencies> |
|||
<scenes> |
|||
<!--View Controller--> |
|||
<scene sceneID="EHf-IW-A2E"> |
|||
<objects> |
|||
<viewController id="01J-lp-oVM" sceneMemberID="viewController"> |
|||
<layoutGuides> |
|||
<viewControllerLayoutGuide type="top" id="Ydg-fD-yQy"/> |
|||
<viewControllerLayoutGuide type="bottom" id="xbc-2k-c8Z"/> |
|||
</layoutGuides> |
|||
<view key="view" contentMode="scaleToFill" id="Ze5-6b-2t3"> |
|||
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/> |
|||
<subviews> |
|||
<imageView opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" image="LaunchImage" translatesAutoresizingMaskIntoConstraints="NO" id="YRO-k0-Ey4"> |
|||
</imageView> |
|||
</subviews> |
|||
<color key="backgroundColor" red="1" green="1" blue="1" alpha="1" colorSpace="custom" customColorSpace="sRGB"/> |
|||
<constraints> |
|||
<constraint firstItem="YRO-k0-Ey4" firstAttribute="centerX" secondItem="Ze5-6b-2t3" secondAttribute="centerX" id="1a2-6s-vTC"/> |
|||
<constraint firstItem="YRO-k0-Ey4" firstAttribute="centerY" secondItem="Ze5-6b-2t3" secondAttribute="centerY" id="4X2-HB-R7a"/> |
|||
</constraints> |
|||
</view> |
|||
</viewController> |
|||
<placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/> |
|||
</objects> |
|||
<point key="canvasLocation" x="53" y="375"/> |
|||
</scene> |
|||
</scenes> |
|||
<resources> |
|||
<image name="LaunchImage" width="168" height="185"/> |
|||
</resources> |
|||
</document> |
@ -0,0 +1,26 @@ |
|||
<?xml version="1.0" encoding="UTF-8" standalone="no"?> |
|||
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="10117" systemVersion="15F34" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" initialViewController="BYZ-38-t0r"> |
|||
<dependencies> |
|||
<deployment identifier="iOS"/> |
|||
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="10085"/> |
|||
</dependencies> |
|||
<scenes> |
|||
<!--Flutter View Controller--> |
|||
<scene sceneID="tne-QT-ifu"> |
|||
<objects> |
|||
<viewController id="BYZ-38-t0r" customClass="FlutterViewController" sceneMemberID="viewController"> |
|||
<layoutGuides> |
|||
<viewControllerLayoutGuide type="top" id="y3c-jy-aDJ"/> |
|||
<viewControllerLayoutGuide type="bottom" id="wfy-db-euE"/> |
|||
</layoutGuides> |
|||
<view key="view" contentMode="scaleToFill" id="8bC-Xf-vdC"> |
|||
<rect key="frame" x="0.0" y="0.0" width="600" height="600"/> |
|||
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/> |
|||
<color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="calibratedWhite"/> |
|||
</view> |
|||
</viewController> |
|||
<placeholder placeholderIdentifier="IBFirstResponder" id="dkx-z0-nzr" sceneMemberID="firstResponder"/> |
|||
</objects> |
|||
</scene> |
|||
</scenes> |
|||
</document> |
@ -0,0 +1,49 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> |
|||
<plist version="1.0"> |
|||
<dict> |
|||
<key>CFBundleDevelopmentRegion</key> |
|||
<string>$(DEVELOPMENT_LANGUAGE)</string> |
|||
<key>CFBundleDisplayName</key> |
|||
<string>Hadi Hoda Flutter</string> |
|||
<key>CFBundleExecutable</key> |
|||
<string>$(EXECUTABLE_NAME)</string> |
|||
<key>CFBundleIdentifier</key> |
|||
<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string> |
|||
<key>CFBundleInfoDictionaryVersion</key> |
|||
<string>6.0</string> |
|||
<key>CFBundleName</key> |
|||
<string>hadi_hoda_flutter</string> |
|||
<key>CFBundlePackageType</key> |
|||
<string>APPL</string> |
|||
<key>CFBundleShortVersionString</key> |
|||
<string>$(FLUTTER_BUILD_NAME)</string> |
|||
<key>CFBundleSignature</key> |
|||
<string>????</string> |
|||
<key>CFBundleVersion</key> |
|||
<string>$(FLUTTER_BUILD_NUMBER)</string> |
|||
<key>LSRequiresIPhoneOS</key> |
|||
<true/> |
|||
<key>UILaunchStoryboardName</key> |
|||
<string>LaunchScreen</string> |
|||
<key>UIMainStoryboardFile</key> |
|||
<string>Main</string> |
|||
<key>UISupportedInterfaceOrientations</key> |
|||
<array> |
|||
<string>UIInterfaceOrientationPortrait</string> |
|||
<string>UIInterfaceOrientationLandscapeLeft</string> |
|||
<string>UIInterfaceOrientationLandscapeRight</string> |
|||
</array> |
|||
<key>UISupportedInterfaceOrientations~ipad</key> |
|||
<array> |
|||
<string>UIInterfaceOrientationPortrait</string> |
|||
<string>UIInterfaceOrientationPortraitUpsideDown</string> |
|||
<string>UIInterfaceOrientationLandscapeLeft</string> |
|||
<string>UIInterfaceOrientationLandscapeRight</string> |
|||
</array> |
|||
<key>CADisableMinimumFrameDurationOnPhone</key> |
|||
<true/> |
|||
<key>UIApplicationSupportsIndirectInputEvents</key> |
|||
<true/> |
|||
</dict> |
|||
</plist> |
@ -0,0 +1 @@ |
|||
#import "GeneratedPluginRegistrant.h" |
@ -0,0 +1,12 @@ |
|||
import Flutter |
|||
import UIKit |
|||
import XCTest |
|||
|
|||
class RunnerTests: XCTestCase { |
|||
|
|||
func testExample() { |
|||
// If you add code to the Runner application, consider adding tests here. |
|||
// See https://developer.apple.com/documentation/xctest for more information about using XCTest. |
|||
} |
|||
|
|||
} |
@ -0,0 +1,3 @@ |
|||
arb-dir: lib/l10n |
|||
template-arb-file: app_en.arb |
|||
output-localization-file: app_localizations.dart |
@ -0,0 +1,7 @@ |
|||
class MyAssets { |
|||
static const MyAssets _i = MyAssets._internal(); |
|||
const MyAssets._internal(); |
|||
factory MyAssets() => _i; |
|||
|
|||
static const String sample = 'assets/image/sample.png'; |
|||
} |
@ -0,0 +1,11 @@ |
|||
import 'package:flutter/material.dart'; |
|||
|
|||
class MyColors { |
|||
static const MyColors _i = MyColors._internal(); |
|||
const MyColors._internal(); |
|||
factory MyColors() => _i; |
|||
|
|||
static const Color white = Colors.white; |
|||
static const Color black = Colors.black; |
|||
static const Color transparent = Colors.transparent; |
|||
} |
@ -0,0 +1,27 @@ |
|||
class MySpaces { |
|||
static const MySpaces _i = MySpaces._internal(); |
|||
const MySpaces._internal(); |
|||
factory MySpaces() => _i; |
|||
|
|||
static const double s0 = 0; |
|||
static const double s2 = 2; |
|||
static const double s4 = 4; |
|||
static const double s6 = 6; |
|||
static const double s8 = 8; |
|||
static const double s10 = 10; |
|||
static const double s12 = 12; |
|||
static const double s14 = 14; |
|||
static const double s16 = 16; |
|||
static const double s18 = 18; |
|||
static const double s20 = 20; |
|||
static const double s22 = 22; |
|||
static const double s24 = 24; |
|||
static const double s26 = 26; |
|||
static const double s28 = 28; |
|||
static const double s30 = 30; |
|||
static const double s32 = 32; |
|||
static const double s34 = 34; |
|||
static const double s36 = 36; |
|||
static const double s38 = 38; |
|||
static const double s40 = 40; |
|||
} |
@ -0,0 +1,15 @@ |
|||
import 'package:flutter/material.dart'; |
|||
|
|||
class MyTextStyle { |
|||
static const MyTextStyle _i = MyTextStyle._internal(); |
|||
const MyTextStyle._internal(); |
|||
factory MyTextStyle() => _i; |
|||
|
|||
static const String fontFamily = ''; |
|||
|
|||
static const TextStyle lightXS = TextStyle( |
|||
fontFamily: fontFamily, |
|||
fontSize: 10, |
|||
fontWeight: FontWeight.w400, |
|||
); |
|||
} |
@ -0,0 +1,32 @@ |
|||
import 'package:hadi_hoda_flutter/core/utils/context_provider.dart'; |
|||
import 'package:flutter/material.dart'; |
|||
import 'package:hadi_hoda_flutter/common_ui/resources/my_colors.dart'; |
|||
|
|||
enum ColorsName { primaryColor } |
|||
|
|||
class MyTheme { |
|||
static const MyTheme _i = MyTheme._internal(); |
|||
const MyTheme._internal(); |
|||
factory MyTheme() => _i; |
|||
|
|||
static final ThemeData light = ThemeData(brightness: Brightness.light); |
|||
|
|||
static final ThemeData dark = ThemeData(brightness: Brightness.dark); |
|||
|
|||
static Map<ColorsName, Color> get lightColors => { |
|||
ColorsName.primaryColor: MyColors.white, |
|||
}; |
|||
|
|||
static Map<ColorsName, Color> get darkColors => { |
|||
ColorsName.primaryColor: MyColors.black, |
|||
}; |
|||
} |
|||
|
|||
extension ThemeExtension on BuildContext { |
|||
Map<ColorsName, Color> get customColors => |
|||
Theme.of(ContextProvider.context!).brightness == Brightness.dark |
|||
? MyTheme.darkColors |
|||
: MyTheme.lightColors; |
|||
|
|||
Color get primaryColor => customColors[ColorsName.primaryColor]!; |
|||
} |
@ -0,0 +1,31 @@ |
|||
import 'package:hadi_hoda_flutter/core/constants/my_constants.dart'; |
|||
import 'package:hadi_hoda_flutter/core/utils/local_storage.dart'; |
|||
import 'package:flutter/material.dart'; |
|||
|
|||
class ThemeService { |
|||
static const ThemeService _i = ThemeService._internal(); |
|||
const ThemeService._internal(); |
|||
factory ThemeService() => _i; |
|||
|
|||
static void changeTheme({required ThemeMode themeMode}) { |
|||
switch (themeMode) { |
|||
case ThemeMode.dark: |
|||
LocalStorage.saveData(key: MyConstants.theme, value: 'dark'); |
|||
case ThemeMode.light: |
|||
LocalStorage.saveData(key: MyConstants.theme, value: 'light'); |
|||
default: |
|||
LocalStorage.saveData(key: MyConstants.theme, value: 'system'); |
|||
} |
|||
} |
|||
|
|||
static ThemeMode getTheme() { |
|||
switch (LocalStorage.readData(key: MyConstants.theme)) { |
|||
case 'dark': |
|||
return ThemeMode.dark; |
|||
case 'light': |
|||
return ThemeMode.light; |
|||
default: |
|||
return ThemeMode.system; |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,28 @@ |
|||
import 'package:hadi_hoda_flutter/core/constants/my_constants.dart'; |
|||
import 'package:hadi_hoda_flutter/core/utils/local_storage.dart'; |
|||
|
|||
class AuthStorage { |
|||
static const AuthStorage _i = AuthStorage._internal(); |
|||
const AuthStorage._internal(); |
|||
factory AuthStorage() => _i; |
|||
|
|||
static String token = ''; |
|||
|
|||
static Future<void> saveData({required String newTokenParams}) async { |
|||
await LocalStorage.saveData(key: MyConstants.token, value: newTokenParams); |
|||
token = newTokenParams; |
|||
} |
|||
|
|||
static Future<void> deleteData() async { |
|||
await LocalStorage.deleteData(key: MyConstants.token); |
|||
token = ''; |
|||
} |
|||
|
|||
static void loadData() { |
|||
token = LocalStorage.readData(key: MyConstants.token); |
|||
} |
|||
|
|||
static bool isLogin() { |
|||
return token.isNotEmpty; |
|||
} |
|||
} |
@ -0,0 +1,11 @@ |
|||
class MyApi { |
|||
static const MyApi _i = MyApi._internal(); |
|||
const MyApi._internal(); |
|||
factory MyApi() => _i; |
|||
|
|||
static const Duration timeOut = Duration(seconds: 30); |
|||
static const String contentType = 'application/json'; |
|||
static const String defaultError = 'An unexpected error has occurred.'; |
|||
|
|||
static const String baseUrl = 'https://api.BASE_URL.com'; |
|||
} |
@ -0,0 +1,8 @@ |
|||
class MyConstants { |
|||
static const MyConstants _i = MyConstants._internal(); |
|||
const MyConstants._internal(); |
|||
factory MyConstants() => _i; |
|||
|
|||
static const String token = 'TOKEN'; |
|||
static const String theme = 'THEME'; |
|||
} |
@ -0,0 +1,32 @@ |
|||
import 'package:hadi_hoda_flutter/core/constants/my_api.dart'; |
|||
import 'package:dio/dio.dart'; |
|||
import 'package:hadi_hoda_flutter/core/error_handler/my_exception.dart'; |
|||
|
|||
class ErrorHandler { |
|||
static const ErrorHandler _i = ErrorHandler._internal(); |
|||
const ErrorHandler._internal(); |
|||
factory ErrorHandler() => _i; |
|||
|
|||
static void handleError(DioException e) { |
|||
if (e.response == null) { |
|||
throw MyException( |
|||
errorMessage: e.message ?? MyApi.defaultError, |
|||
statusCode: e.response?.statusCode, |
|||
); |
|||
} else { |
|||
if (e.response?.data['message'] == null) { |
|||
throw MyException( |
|||
errorMessage: |
|||
e.response?.statusMessage ?? e.message ?? MyApi.defaultError, |
|||
statusCode: e.response?.statusCode, |
|||
); |
|||
} else { |
|||
throw MyException( |
|||
errorMessage: |
|||
e.response?.data['message'] ?? e.message ?? MyApi.defaultError, |
|||
statusCode: e.response?.statusCode, |
|||
); |
|||
} |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,9 @@ |
|||
class MyException implements Exception { |
|||
final String errorMessage; |
|||
final int? statusCode; |
|||
|
|||
const MyException({ |
|||
this.errorMessage = 'An unexpected error has occurred.', |
|||
this.statusCode, |
|||
}); |
|||
} |
@ -0,0 +1,20 @@ |
|||
import 'dart:async'; |
|||
|
|||
import 'package:flutter/material.dart'; |
|||
import 'package:hadi_hoda_flutter/core/auth_storage/auth_storage.dart'; |
|||
import 'package:hadi_hoda_flutter/core/routers/my_routes.dart'; |
|||
import 'package:go_router/go_router.dart'; |
|||
|
|||
class AuthMiddleware { |
|||
static const AuthMiddleware _i = AuthMiddleware._internal(); |
|||
const AuthMiddleware._internal(); |
|||
factory AuthMiddleware() => _i; |
|||
|
|||
static FutureOr<String?> redirect(BuildContext context, GoRouterState state) async { |
|||
if (AuthStorage.isLogin()) { |
|||
return Routes.samplePage; |
|||
} else { |
|||
return null; |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,63 @@ |
|||
import 'package:dio/dio.dart'; |
|||
|
|||
abstract class IHttpRequest { |
|||
Future<dynamic> get({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}); |
|||
|
|||
Future<dynamic> post({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}); |
|||
|
|||
Future<dynamic> put({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}); |
|||
|
|||
Future<dynamic> patch({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}); |
|||
|
|||
Future<dynamic> delete({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}); |
|||
|
|||
Future<dynamic> upload({ |
|||
required String method, |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
void Function(int count, int total)? onSendProgress, |
|||
CancelToken? cancelToken, |
|||
}); |
|||
|
|||
Future download({ |
|||
required String urlPath, |
|||
required String savePath, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
void Function(int count, int total)? onReceive, |
|||
CancelToken? cancelToken, |
|||
}); |
|||
} |
@ -0,0 +1,178 @@ |
|||
import 'package:dio/dio.dart'; |
|||
import 'package:hadi_hoda_flutter/core/constants/my_api.dart'; |
|||
import 'package:hadi_hoda_flutter/core/error_handler/error_handler.dart'; |
|||
import 'package:hadi_hoda_flutter/core/network/http_request.dart'; |
|||
import 'package:hadi_hoda_flutter/core/network/interceptors/logging_interceptor.dart'; |
|||
import 'package:hadi_hoda_flutter/core/network/interceptors/token_interceptor.dart'; |
|||
|
|||
class HttpRequestImpl implements IHttpRequest { |
|||
final Dio _dio = Dio( |
|||
BaseOptions( |
|||
baseUrl: MyApi.baseUrl, |
|||
sendTimeout: MyApi.timeOut, |
|||
receiveTimeout: MyApi.timeOut, |
|||
connectTimeout: MyApi.timeOut, |
|||
contentType: MyApi.contentType, |
|||
responseType: ResponseType.json, |
|||
), |
|||
)..interceptors.addAll([ |
|||
LoggingInterceptor.prettyDioLogger, |
|||
TokenInterceptor(), |
|||
]); |
|||
|
|||
|
|||
@override |
|||
Future get({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}) async { |
|||
try { |
|||
final Response response = await _dio.get( |
|||
path, |
|||
data: data, |
|||
queryParameters: queryParameters, |
|||
options: Options(headers: header, responseType: responseType), |
|||
); |
|||
return response.data; |
|||
} on DioException catch (e) { |
|||
ErrorHandler.handleError(e); |
|||
} |
|||
} |
|||
|
|||
@override |
|||
Future post({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}) async { |
|||
try { |
|||
final Response response = await _dio.post( |
|||
path, |
|||
data: data, |
|||
queryParameters: queryParameters, |
|||
options: Options(headers: header, responseType: responseType), |
|||
); |
|||
return response.data; |
|||
} on DioException catch (e) { |
|||
ErrorHandler.handleError(e); |
|||
} |
|||
} |
|||
|
|||
@override |
|||
Future put({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}) async { |
|||
try { |
|||
final Response response = await _dio.put( |
|||
path, |
|||
data: data, |
|||
queryParameters: queryParameters, |
|||
options: Options(headers: header, responseType: responseType), |
|||
); |
|||
return response.data; |
|||
} on DioException catch (e) { |
|||
ErrorHandler.handleError(e); |
|||
} |
|||
} |
|||
|
|||
@override |
|||
Future patch({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}) async { |
|||
try { |
|||
final Response response = await _dio.patch( |
|||
path, |
|||
data: data, |
|||
queryParameters: queryParameters, |
|||
options: Options(headers: header, responseType: responseType), |
|||
); |
|||
return response.data; |
|||
} on DioException catch (e) { |
|||
ErrorHandler.handleError(e); |
|||
} |
|||
} |
|||
|
|||
@override |
|||
Future delete({ |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
ResponseType? responseType, |
|||
}) async { |
|||
try { |
|||
final Response response = await _dio.delete( |
|||
path, |
|||
data: data, |
|||
queryParameters: queryParameters, |
|||
options: Options(headers: header, responseType: responseType), |
|||
); |
|||
return response.data; |
|||
} on DioException catch (e) { |
|||
ErrorHandler.handleError(e); |
|||
} |
|||
} |
|||
|
|||
@override |
|||
Future upload({ |
|||
required String method, |
|||
required String path, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
void Function(int count, int total)? onSendProgress, |
|||
CancelToken? cancelToken, |
|||
}) async { |
|||
try { |
|||
final Response response = await _dio.request( |
|||
path, |
|||
data: data, |
|||
queryParameters: queryParameters, |
|||
options: Options(headers: header, method: method), |
|||
onSendProgress: onSendProgress, |
|||
cancelToken: cancelToken, |
|||
); |
|||
return response.data; |
|||
} on DioException catch (e) { |
|||
ErrorHandler.handleError(e); |
|||
} |
|||
} |
|||
|
|||
@override |
|||
Future download({ |
|||
required String urlPath, |
|||
required String savePath, |
|||
Object? data, |
|||
Map<String, dynamic>? queryParameters, |
|||
Map<String, dynamic>? header, |
|||
void Function(int count, int total)? onReceive, |
|||
CancelToken? cancelToken, |
|||
}) async { |
|||
try { |
|||
await _dio.download( |
|||
urlPath, |
|||
savePath, |
|||
data: data, |
|||
queryParameters: queryParameters, |
|||
options: Options(headers: header), |
|||
onReceiveProgress: onReceive, |
|||
cancelToken: cancelToken, |
|||
); |
|||
} on DioException catch (e) { |
|||
ErrorHandler.handleError(e); |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,19 @@ |
|||
import 'package:flutter/foundation.dart'; |
|||
import 'package:pretty_dio_logger/pretty_dio_logger.dart'; |
|||
|
|||
class LoggingInterceptor { |
|||
static const LoggingInterceptor _i = LoggingInterceptor._internal(); |
|||
const LoggingInterceptor._internal(); |
|||
factory LoggingInterceptor() => _i; |
|||
|
|||
static final PrettyDioLogger prettyDioLogger = PrettyDioLogger( |
|||
requestHeader: true, |
|||
requestBody: true, |
|||
responseBody: true, |
|||
responseHeader: false, |
|||
error: true, |
|||
compact: true, |
|||
maxWidth: 90, |
|||
enabled: kDebugMode, |
|||
); |
|||
} |
@ -0,0 +1,10 @@ |
|||
import 'package:dio/dio.dart'; |
|||
import 'package:hadi_hoda_flutter/core/auth_storage/auth_storage.dart'; |
|||
|
|||
class TokenInterceptor extends Interceptor { |
|||
@override |
|||
void onRequest(RequestOptions options, RequestInterceptorHandler handler) { |
|||
options.headers['Authorization'] = 'Bearer ${AuthStorage.token}'; |
|||
handler.next(options); |
|||
} |
|||
} |
@ -0,0 +1,13 @@ |
|||
class SampleParams { |
|||
int? id; |
|||
|
|||
SampleParams({this.id}); |
|||
|
|||
SampleParams copyWith({ |
|||
int? id, |
|||
}) { |
|||
return SampleParams( |
|||
id: id ?? this.id, |
|||
); |
|||
} |
|||
} |
@ -0,0 +1,19 @@ |
|||
class BaseResponse { |
|||
static const BaseResponse _i = BaseResponse._internal(); |
|||
const BaseResponse._internal(); |
|||
factory BaseResponse() => _i; |
|||
|
|||
static T getData<T>( |
|||
dynamic response, |
|||
T Function(Map<String, dynamic> json) bodyBuilder, |
|||
) { |
|||
return bodyBuilder.call(response ?? {}); |
|||
} |
|||
|
|||
static List<T> getDataList<T>( |
|||
dynamic response, |
|||
T Function(Map<String, dynamic> json) bodyBuilder, |
|||
) { |
|||
return response?.map<T>((e) => bodyBuilder.call(e)).toList(); |
|||
} |
|||
} |
@ -0,0 +1,29 @@ |
|||
import 'package:hadi_hoda_flutter/core/utils/context_provider.dart'; |
|||
import 'package:hadi_hoda_flutter/features/sample/presentation/bloc/sample_bloc.dart'; |
|||
import 'package:hadi_hoda_flutter/features/sample/presentation/ui/sample_page.dart'; |
|||
import 'package:hadi_hoda_flutter/init_bindings.dart'; |
|||
import 'package:flutter_bloc/flutter_bloc.dart'; |
|||
import 'package:go_router/go_router.dart'; |
|||
|
|||
class Routes { |
|||
static const Routes _i = Routes._internal(); |
|||
const Routes._internal(); |
|||
factory Routes() => _i; |
|||
|
|||
static const String samplePage = '/sample_page'; |
|||
} |
|||
|
|||
GoRouter get appPages => GoRouter( |
|||
initialLocation: Routes.samplePage, |
|||
navigatorKey: ContextProvider.navigatorKey, |
|||
routes: [ |
|||
GoRoute( |
|||
name: Routes.samplePage, |
|||
path: Routes.samplePage, |
|||
builder: (context, state) => BlocProvider( |
|||
create: (context) => SampleBloc(locator()), |
|||
child: const SamplePage(), |
|||
), |
|||
), |
|||
], |
|||
); |
@ -0,0 +1,31 @@ |
|||
sealed class BaseStatus { |
|||
const BaseStatus(); |
|||
} |
|||
|
|||
class BaseInit extends BaseStatus { |
|||
const BaseInit(); |
|||
} |
|||
|
|||
class BaseLoading extends BaseStatus { |
|||
const BaseLoading(); |
|||
} |
|||
|
|||
class BaseEmpty extends BaseStatus { |
|||
const BaseEmpty(); |
|||
} |
|||
|
|||
class BaseNotAuth extends BaseStatus { |
|||
const BaseNotAuth(); |
|||
} |
|||
|
|||
class BaseComplete<T> extends BaseStatus { |
|||
final T data; |
|||
|
|||
const BaseComplete(this.data); |
|||
} |
|||
|
|||
class BaseError extends BaseStatus { |
|||
final String errorMessage; |
|||
|
|||
const BaseError(this.errorMessage); |
|||
} |
@ -0,0 +1,6 @@ |
|||
import 'package:hadi_hoda_flutter/core/error_handler/my_exception.dart'; |
|||
import 'package:hadi_hoda_flutter/core/utils/data_state.dart'; |
|||
|
|||
abstract class UseCase<T, P> { |
|||
Future<DataState<T, MyException>> call(P params); |
|||
} |
@ -0,0 +1,15 @@ |
|||
import 'package:hadi_hoda_flutter/core/utils/my_device.dart'; |
|||
|
|||
dynamic checkPlatform({ |
|||
dynamic android, |
|||
dynamic iOS, |
|||
dynamic web, |
|||
}) { |
|||
if (MyDevice.isAndroid()) { |
|||
return android; |
|||
} else if (MyDevice.isIOS()) { |
|||
return iOS; |
|||
} else if (MyDevice.isWeb()) { |
|||
return web; |
|||
} |
|||
} |
@ -0,0 +1,10 @@ |
|||
import 'package:flutter/cupertino.dart'; |
|||
|
|||
class ContextProvider { |
|||
static const ContextProvider _i = ContextProvider._internal(); |
|||
const ContextProvider._internal(); |
|||
factory ContextProvider() => _i; |
|||
|
|||
static GlobalKey<NavigatorState> navigatorKey = GlobalKey<NavigatorState>(); |
|||
static BuildContext? context = navigatorKey.currentContext; |
|||
} |
@ -0,0 +1,22 @@ |
|||
class DataState<T, V> { |
|||
final T? data; |
|||
final V? error; |
|||
|
|||
const DataState(this.data, this.error); |
|||
|
|||
bool get isSuccess => error == null; |
|||
|
|||
bool get isError => error != null; |
|||
|
|||
factory DataState.success(T data) => DataState(data, null); |
|||
|
|||
factory DataState.error(V error) => DataState(null, error); |
|||
|
|||
void fold<R>(R Function(T data) onSuccess, R Function(V error) onError) { |
|||
if (isSuccess) { |
|||
onSuccess(data as T); |
|||
} else { |
|||
onError(error as V); |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,8 @@ |
|||
import 'package:flutter/material.dart'; |
|||
|
|||
extension Gap on double { |
|||
Widget get gapWidth => SizedBox(width: this); |
|||
Widget get gapHeight => SizedBox(height: this); |
|||
Widget get gapSliverWidth => SliverToBoxAdapter(child: SizedBox(width: this)); |
|||
Widget get gapSliverHeight => SliverToBoxAdapter(child: SizedBox(height: this)); |
|||
} |
@ -0,0 +1,29 @@ |
|||
import 'package:shared_preferences/shared_preferences.dart'; |
|||
|
|||
class LocalStorage { |
|||
static const LocalStorage _i = LocalStorage._internal(); |
|||
const LocalStorage._internal(); |
|||
factory LocalStorage() => _i; |
|||
|
|||
static late final SharedPreferences _box; |
|||
|
|||
static Future<void> init() async { |
|||
_box = await SharedPreferences.getInstance(); |
|||
} |
|||
|
|||
static Future<void> saveData({required String key, required dynamic value}) async { |
|||
await _box.setString(key, value); |
|||
} |
|||
|
|||
static String readData({required String key}) { |
|||
return _box.getString(key) ?? ''; |
|||
} |
|||
|
|||
static Future<void> deleteData({required String key}) async { |
|||
await _box.remove(key); |
|||
} |
|||
|
|||
static Future<void> clearAll() async { |
|||
await _box.clear(); |
|||
} |
|||
} |
@ -0,0 +1,61 @@ |
|||
import 'package:flutter/foundation.dart'; |
|||
import 'package:flutter/material.dart'; |
|||
|
|||
class MyDevice { |
|||
static const MyDevice _i = MyDevice._internal(); |
|||
const MyDevice._internal(); |
|||
factory MyDevice() => _i; |
|||
|
|||
/// Device size |
|||
static const double tabletWidth = 754; |
|||
static const double tabletHeight = 658; |
|||
static const double desktopWidth = 1020; |
|||
static const double desktopHeight = 784; |
|||
|
|||
/// Get Device based on width |
|||
static bool isMobile(BuildContext context) { |
|||
return MediaQuery.sizeOf(context).width < 600; |
|||
} |
|||
|
|||
static bool isTablet(BuildContext context) { |
|||
return MediaQuery.sizeOf(context).width >= 600 && MediaQuery.sizeOf(context).width < 1200; |
|||
} |
|||
|
|||
static bool isDesktop(BuildContext context) { |
|||
return MediaQuery.sizeOf(context).width >= 1200; |
|||
} |
|||
|
|||
/// Get device size |
|||
static double? getDeviceWidth(BuildContext context) { |
|||
if (isMobile(context)) { |
|||
return null; |
|||
} else if (isTablet(context)) { |
|||
return tabletWidth; |
|||
} else { |
|||
return desktopWidth; |
|||
} |
|||
} |
|||
|
|||
static double? getDeviceHeight(BuildContext context) { |
|||
if (isMobile(context)) { |
|||
return null; |
|||
} else if (isTablet(context)) { |
|||
return tabletHeight; |
|||
} else { |
|||
return desktopHeight; |
|||
} |
|||
} |
|||
|
|||
/// Get Device based on platform |
|||
static bool isIOS() { |
|||
return defaultTargetPlatform == TargetPlatform.iOS; |
|||
} |
|||
|
|||
static bool isAndroid() { |
|||
return defaultTargetPlatform == TargetPlatform.android; |
|||
} |
|||
|
|||
static bool isWeb() { |
|||
return kIsWeb; |
|||
} |
|||
} |
@ -0,0 +1,6 @@ |
|||
import 'package:hadi_hoda_flutter/l10n/app_localizations.dart'; |
|||
import 'package:flutter/material.dart'; |
|||
|
|||
extension MyLocalization on BuildContext { |
|||
AppLocalizations get translate => AppLocalizations.of(this)!; |
|||
} |
@ -0,0 +1,11 @@ |
|||
import 'package:flutter/gestures.dart'; |
|||
import 'package:flutter/material.dart'; |
|||
|
|||
class MyScrollBehavior extends ScrollBehavior { |
|||
@override |
|||
Set<PointerDeviceKind> get dragDevices => { |
|||
PointerDeviceKind.touch, |
|||
PointerDeviceKind.mouse, |
|||
PointerDeviceKind.trackpad, |
|||
}; |
|||
} |
@ -0,0 +1,6 @@ |
|||
import 'package:flutter/material.dart'; |
|||
|
|||
extension ScreenSize on BuildContext { |
|||
double get widthScreen => MediaQuery.sizeOf(this).width; |
|||
double get heightScreen => MediaQuery.sizeOf(this).height; |
|||
} |
@ -0,0 +1,28 @@ |
|||
import 'package:hadi_hoda_flutter/core/constants/my_api.dart'; |
|||
import 'package:hadi_hoda_flutter/core/network/http_request.dart'; |
|||
import 'package:hadi_hoda_flutter/core/params/sample_params.dart'; |
|||
import 'package:hadi_hoda_flutter/core/response/base_response.dart'; |
|||
import 'package:hadi_hoda_flutter/features/sample/data/model/sample_model.dart'; |
|||
import 'package:hadi_hoda_flutter/features/sample/domain/entity/sample_entity.dart'; |
|||
|
|||
abstract class ISampleDatasource { |
|||
Future<SampleEntity> getData({required SampleParams params}); |
|||
} |
|||
|
|||
class SampleDatasourceImpl implements ISampleDatasource { |
|||
final IHttpRequest httpRequest; |
|||
|
|||
const SampleDatasourceImpl(this.httpRequest); |
|||
|
|||
@override |
|||
Future<SampleEntity> getData({required SampleParams params}) async { |
|||
final response = await httpRequest.get( |
|||
path: MyApi.baseUrl, |
|||
); |
|||
|
|||
return BaseResponse.getData<SampleEntity>( |
|||
response?['data'], |
|||
(json) => SampleModel.fromJson(json), |
|||
); |
|||
} |
|||
} |
@ -0,0 +1,13 @@ |
|||
import 'package:hadi_hoda_flutter/features/sample/domain/entity/sample_entity.dart'; |
|||
|
|||
class SampleModel extends SampleEntity { |
|||
const SampleModel({ |
|||
super.id, |
|||
}); |
|||
|
|||
factory SampleModel.fromJson(Map<String, dynamic> json) { |
|||
return SampleModel( |
|||
id: json['id'], |
|||
); |
|||
} |
|||
} |
@ -0,0 +1,29 @@ |
|||
import 'package:hadi_hoda_flutter/core/params/sample_params.dart'; |
|||
import 'package:flutter/foundation.dart'; |
|||
import 'package:hadi_hoda_flutter/core/error_handler/my_exception.dart'; |
|||
import 'package:hadi_hoda_flutter/core/utils/data_state.dart'; |
|||
import 'package:hadi_hoda_flutter/features/sample/data/datasource/sample_datasource.dart'; |
|||
import 'package:hadi_hoda_flutter/features/sample/domain/entity/sample_entity.dart'; |
|||
import 'package:hadi_hoda_flutter/features/sample/domain/repository/sample_repository.dart'; |
|||
|
|||
class SampleRepositoryImpl implements ISampleRepository { |
|||
final ISampleDatasource datasource; |
|||
|
|||
const SampleRepositoryImpl(this.datasource); |
|||
|
|||
@override |
|||
Future<DataState<SampleEntity, MyException>> getData({required SampleParams params}) async { |
|||
try { |
|||
final SampleEntity response = await datasource.getData(params: params); |
|||
return DataState.success(response); |
|||
} on MyException catch (e) { |
|||
return DataState.error(e); |
|||
} catch (e) { |
|||
if (kDebugMode) { |
|||
rethrow; |
|||
} else { |
|||
return DataState.error(MyException(errorMessage: '$e')); |
|||
} |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,14 @@ |
|||
import 'package:equatable/equatable.dart'; |
|||
|
|||
class SampleEntity extends Equatable { |
|||
final int? id; |
|||
|
|||
const SampleEntity({ |
|||
this.id, |
|||
}); |
|||
|
|||
@override |
|||
List<Object?> get props => [ |
|||
id, |
|||
]; |
|||
} |
@ -0,0 +1,8 @@ |
|||
import 'package:hadi_hoda_flutter/core/error_handler/my_exception.dart'; |
|||
import 'package:hadi_hoda_flutter/core/params/sample_params.dart'; |
|||
import 'package:hadi_hoda_flutter/core/utils/data_state.dart'; |
|||
import 'package:hadi_hoda_flutter/features/sample/domain/entity/sample_entity.dart'; |
|||
|
|||
abstract class ISampleRepository { |
|||
Future<DataState<SampleEntity, MyException>> getData({required SampleParams params}); |
|||
} |