-
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}); |
||||
|
} |