├── .gitignore
├── .metadata
├── CHANGELOG.md
├── LICENSE
├── README.md
├── analysis_options.yaml
├── android
├── .gitignore
├── app
│ └── src
│ │ └── main
│ │ └── java
│ │ └── io
│ │ └── flutter
│ │ └── plugins
│ │ └── GeneratedPluginRegistrant.java
├── build.gradle
├── settings.gradle
└── src
│ ├── main
│ ├── AndroidManifest.xml
│ └── kotlin
│ │ └── com
│ │ └── example
│ │ └── flutter_popup
│ │ └── FlutterPopupPlugin.kt
│ └── test
│ └── kotlin
│ └── com
│ └── example
│ └── flutter_popup
│ └── FlutterPopupPluginTest.kt
├── example
├── .gitignore
├── README.md
├── analysis_options.yaml
├── android
│ ├── .gitignore
│ ├── app
│ │ ├── build.gradle
│ │ └── src
│ │ │ ├── debug
│ │ │ └── AndroidManifest.xml
│ │ │ ├── main
│ │ │ ├── AndroidManifest.xml
│ │ │ ├── kotlin
│ │ │ │ └── com
│ │ │ │ │ └── example
│ │ │ │ │ └── flutter_popup_example
│ │ │ │ │ └── MainActivity.kt
│ │ │ └── res
│ │ │ │ ├── drawable-v21
│ │ │ │ └── launch_background.xml
│ │ │ │ ├── drawable
│ │ │ │ └── launch_background.xml
│ │ │ │ ├── mipmap-hdpi
│ │ │ │ └── ic_launcher.png
│ │ │ │ ├── mipmap-mdpi
│ │ │ │ └── ic_launcher.png
│ │ │ │ ├── mipmap-xhdpi
│ │ │ │ └── ic_launcher.png
│ │ │ │ ├── mipmap-xxhdpi
│ │ │ │ └── ic_launcher.png
│ │ │ │ ├── mipmap-xxxhdpi
│ │ │ │ └── ic_launcher.png
│ │ │ │ ├── values-night
│ │ │ │ └── styles.xml
│ │ │ │ └── values
│ │ │ │ └── styles.xml
│ │ │ └── profile
│ │ │ └── AndroidManifest.xml
│ ├── build.gradle
│ ├── gradle.properties
│ ├── gradle
│ │ └── wrapper
│ │ │ └── gradle-wrapper.properties
│ └── settings.gradle
├── ios
│ ├── .gitignore
│ ├── Flutter
│ │ ├── AppFrameworkInfo.plist
│ │ ├── Debug.xcconfig
│ │ └── Release.xcconfig
│ ├── Podfile
│ ├── Podfile.lock
│ ├── Runner.xcodeproj
│ │ ├── project.pbxproj
│ │ ├── project.xcworkspace
│ │ │ ├── contents.xcworkspacedata
│ │ │ └── xcshareddata
│ │ │ │ ├── IDEWorkspaceChecks.plist
│ │ │ │ └── WorkspaceSettings.xcsettings
│ │ └── xcshareddata
│ │ │ └── xcschemes
│ │ │ └── Runner.xcscheme
│ ├── Runner.xcworkspace
│ │ ├── contents.xcworkspacedata
│ │ └── xcshareddata
│ │ │ ├── IDEWorkspaceChecks.plist
│ │ │ └── WorkspaceSettings.xcsettings
│ ├── Runner
│ │ ├── AppDelegate.swift
│ │ ├── Assets.xcassets
│ │ │ ├── AppIcon.appiconset
│ │ │ │ ├── Contents.json
│ │ │ │ ├── Icon-App-1024x1024@1x.png
│ │ │ │ ├── Icon-App-20x20@1x.png
│ │ │ │ ├── Icon-App-20x20@2x.png
│ │ │ │ ├── Icon-App-20x20@3x.png
│ │ │ │ ├── Icon-App-29x29@1x.png
│ │ │ │ ├── Icon-App-29x29@2x.png
│ │ │ │ ├── Icon-App-29x29@3x.png
│ │ │ │ ├── Icon-App-40x40@1x.png
│ │ │ │ ├── Icon-App-40x40@2x.png
│ │ │ │ ├── Icon-App-40x40@3x.png
│ │ │ │ ├── Icon-App-60x60@2x.png
│ │ │ │ ├── Icon-App-60x60@3x.png
│ │ │ │ ├── Icon-App-76x76@1x.png
│ │ │ │ ├── Icon-App-76x76@2x.png
│ │ │ │ └── Icon-App-83.5x83.5@2x.png
│ │ │ └── LaunchImage.imageset
│ │ │ │ ├── Contents.json
│ │ │ │ ├── LaunchImage.png
│ │ │ │ ├── LaunchImage@2x.png
│ │ │ │ ├── LaunchImage@3x.png
│ │ │ │ └── README.md
│ │ ├── Base.lproj
│ │ │ ├── LaunchScreen.storyboard
│ │ │ └── Main.storyboard
│ │ ├── Info.plist
│ │ └── Runner-Bridging-Header.h
│ └── RunnerTests
│ │ └── RunnerTests.swift
├── lib
│ └── main.dart
├── pubspec.lock
└── pubspec.yaml
├── ios
├── .gitignore
├── Assets
│ └── .gitkeep
├── Classes
│ └── FlutterPopupPlugin.swift
└── flutter_popup.podspec
├── lib
├── flutter_popup.dart
└── src
│ ├── popup.dart
│ └── screen.dart
└── pubspec.yaml
/.gitignore:
--------------------------------------------------------------------------------
1 | # Miscellaneous
2 | *.class
3 | *.log
4 | *.pyc
5 | *.swp
6 | .DS_Store
7 | .atom/
8 | .buildlog/
9 | .history
10 | .svn/
11 | migrate_working_dir/
12 |
13 | # IntelliJ related
14 | *.iml
15 | *.ipr
16 | *.iws
17 | .idea/
18 |
19 | # The .vscode folder contains launch configuration and tasks you configure in
20 | # VS Code which you may wish to be included in version control, so this line
21 | # is commented out by default.
22 | #.vscode/
23 |
24 | # Flutter/Dart/Pub related
25 | # Libraries should not include pubspec.lock, per https://dart.dev/guides/libraries/private-files#pubspeclock.
26 | /pubspec.lock
27 | **/doc/api/
28 | .dart_tool/
29 | .packages
30 | build/
31 | .vscode/
32 | .vscode/settings.json
--------------------------------------------------------------------------------
/.metadata:
--------------------------------------------------------------------------------
1 | # This file tracks properties of this Flutter project.
2 | # Used by Flutter tool to assess capabilities and perform upgrades etc.
3 | #
4 | # This file should be version controlled and should not be manually edited.
5 |
6 | version:
7 | revision: "6c4930c4ac86fb286f30e31d0ec8bffbcbb9953e"
8 | channel: "stable"
9 |
10 | project_type: plugin
11 |
12 | # Tracks metadata for the flutter migrate command
13 | migration:
14 | platforms:
15 | - platform: root
16 | create_revision: 6c4930c4ac86fb286f30e31d0ec8bffbcbb9953e
17 | base_revision: 6c4930c4ac86fb286f30e31d0ec8bffbcbb9953e
18 | - platform: android
19 | create_revision: 6c4930c4ac86fb286f30e31d0ec8bffbcbb9953e
20 | base_revision: 6c4930c4ac86fb286f30e31d0ec8bffbcbb9953e
21 | - platform: ios
22 | create_revision: 6c4930c4ac86fb286f30e31d0ec8bffbcbb9953e
23 | base_revision: 6c4930c4ac86fb286f30e31d0ec8bffbcbb9953e
24 |
25 | # User provided section
26 |
27 | # List of Local paths (relative to this file) that should be
28 | # ignored by the migrate tool.
29 | #
30 | # Files that are not part of the templates will be ignored by default.
31 | unmanaged_files:
32 | - 'lib/main.dart'
33 | - 'ios/Runner.xcodeproj/project.pbxproj'
34 |
--------------------------------------------------------------------------------
/CHANGELOG.md:
--------------------------------------------------------------------------------
1 | ## 1.0.0
2 |
3 | * TODO: Describe initial release.
4 | ## 3.3.7
5 |
6 | * TODO: Describe initial release.
7 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2023 mopriestt
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # flutter_popup
2 | The flutter_popup package is a convenient tool that enables you to display a straightforward and customizable popup within your Flutter application. It offers a highlight feature that can be utilized to direct the user's attention to a specific area as needed.
3 |
4 | ## Getting Started
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 | ## How to use
13 | ```
14 | dependencies:
15 | flutter_popup: ^latest_version
16 | ```
17 |
18 | ```
19 | import 'package:flutter_popup/flutter_popup.dart';
20 | ```
21 | ```dart
22 | // easy to use
23 | CustomPopup(
24 | content: Text('George says everything looks fine'),
25 | child: Icon(Icons.help),
26 | ),
27 |
28 | CustomPopup(
29 | arrowColor: Colors.orange,
30 | barrierColor: Colors.green.withOpacity(0.1),
31 | backgroundColor: Colors.white,
32 | content: Text('George says everything looks fine'),
33 | child: Icon(Icons.help),
34 | ),
35 |
36 | CustomPopup(
37 | content: _Slider(),
38 | position: PopupPosition.top,
39 | child:Text('slider'),
40 | )
41 |
42 | CustomPopup(
43 | content: Column(
44 | mainAxisSize: MainAxisSize.min,
45 | children: List.generate(5, (index) => Text('menu$index')),
46 | ),
47 | child: const Icon(Icons.add_circle_outline),
48 | )
49 |
50 | Container(
51 | decoration: BoxDecoration(color: Colors.white),
52 | padding: EdgeInsets.symmetric(vertical: 10),
53 | child: Row(
54 | mainAxisAlignment: MainAxisAlignment.spaceAround,
55 | children: [
56 | CustomPopup(
57 | showArrow: false,
58 | contentPadding:EdgeInsets.symmetric(horizontal: 30, vertical: 10),
59 | barrierColor: Colors.transparent,
60 | contentDecoration: BoxDecoration(
61 | color: Colors.white,
62 | ),
63 | content: SizedBox(
64 | width: double.infinity,
65 | child: Column(
66 | mainAxisSize: MainAxisSize.min,
67 | crossAxisAlignment: CrossAxisAlignment.start,
68 | children: List.generate(4,(index) => Text('item$index'),),),),
69 | child: Text('filter1'),
70 | ),
71 | Text('filter2'),
72 | Text('filter3'),
73 | ],
74 | ),
75 | )
76 | ```
77 |
78 |
79 | ## last
80 |
Our full-stack freelance team is opening to new projects
81 | If you are interested in purchasing demo projects or outsourcing projects, please contact me: QQ: 965471570, Gmail: herowws90@gmail.com.
82 | 如果你想要购买演示项目,或者外包项目,请联系我: QQ:965471570 Gmail:herowws90@gmail.com
83 |
--------------------------------------------------------------------------------
/analysis_options.yaml:
--------------------------------------------------------------------------------
1 | include: package:flutter_lints/flutter.yaml
2 |
3 | # Additional information about this file can be found at
4 | # https://dart.dev/guides/language/analysis-options
5 |
--------------------------------------------------------------------------------
/android/.gitignore:
--------------------------------------------------------------------------------
1 | *.iml
2 | .gradle
3 | /local.properties
4 | /.idea/workspace.xml
5 | /.idea/libraries
6 | .DS_Store
7 | /build
8 | /captures
9 | .cxx
10 |
--------------------------------------------------------------------------------
/android/app/src/main/java/io/flutter/plugins/GeneratedPluginRegistrant.java:
--------------------------------------------------------------------------------
1 | package io.flutter.plugins;
2 |
3 | import io.flutter.plugin.common.PluginRegistry;
4 |
5 | /**
6 | * Generated file. Do not edit.
7 | */
8 | public final class GeneratedPluginRegistrant {
9 | public static void registerWith(PluginRegistry registry) {
10 | if (alreadyRegisteredWith(registry)) {
11 | return;
12 | }
13 | }
14 |
15 | private static boolean alreadyRegisteredWith(PluginRegistry registry) {
16 | final String key = GeneratedPluginRegistrant.class.getCanonicalName();
17 | if (registry.hasPlugin(key)) {
18 | return true;
19 | }
20 | registry.registrarFor(key);
21 | return false;
22 | }
23 | }
24 |
--------------------------------------------------------------------------------
/android/build.gradle:
--------------------------------------------------------------------------------
1 | group 'com.example.flutter_popup'
2 | version '1.0-SNAPSHOT'
3 |
4 | buildscript {
5 | ext.kotlin_version = '1.7.10'
6 | repositories {
7 | google()
8 | mavenCentral()
9 | }
10 |
11 | dependencies {
12 | classpath 'com.android.tools.build:gradle:7.3.0'
13 | classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
14 | }
15 | }
16 |
17 | allprojects {
18 | repositories {
19 | google()
20 | mavenCentral()
21 | }
22 | }
23 |
24 | apply plugin: 'com.android.library'
25 | apply plugin: 'kotlin-android'
26 |
27 | android {
28 | if (project.android.hasProperty("namespace")) {
29 | namespace 'com.example.flutter_popup'
30 | }
31 |
32 | compileSdkVersion 33
33 |
34 | compileOptions {
35 | sourceCompatibility JavaVersion.VERSION_1_8
36 | targetCompatibility JavaVersion.VERSION_1_8
37 | }
38 |
39 | kotlinOptions {
40 | jvmTarget = '1.8'
41 | }
42 |
43 | sourceSets {
44 | main.java.srcDirs += 'src/main/kotlin'
45 | test.java.srcDirs += 'src/test/kotlin'
46 | }
47 |
48 | defaultConfig {
49 | minSdkVersion 19
50 | }
51 |
52 | dependencies {
53 | testImplementation 'org.jetbrains.kotlin:kotlin-test'
54 | testImplementation 'org.mockito:mockito-core:5.0.0'
55 | }
56 |
57 | testOptions {
58 | unitTests.all {
59 | useJUnitPlatform()
60 |
61 | testLogging {
62 | events "passed", "skipped", "failed", "standardOut", "standardError"
63 | outputs.upToDateWhen {false}
64 | showStandardStreams = true
65 | }
66 | }
67 | }
68 | }
69 |
--------------------------------------------------------------------------------
/android/settings.gradle:
--------------------------------------------------------------------------------
1 | rootProject.name = 'flutter_popup'
2 |
--------------------------------------------------------------------------------
/android/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
3 |
4 |
--------------------------------------------------------------------------------
/android/src/main/kotlin/com/example/flutter_popup/FlutterPopupPlugin.kt:
--------------------------------------------------------------------------------
1 | package com.example.flutter_popup
2 |
3 | import androidx.annotation.NonNull
4 |
5 | import io.flutter.embedding.engine.plugins.FlutterPlugin
6 | import io.flutter.plugin.common.MethodCall
7 | import io.flutter.plugin.common.MethodChannel
8 | import io.flutter.plugin.common.MethodChannel.MethodCallHandler
9 | import io.flutter.plugin.common.MethodChannel.Result
10 |
11 | /** FlutterPopupPlugin */
12 | class FlutterPopupPlugin: FlutterPlugin, MethodCallHandler {
13 | /// The MethodChannel that will the communication between Flutter and native Android
14 | ///
15 | /// This local reference serves to register the plugin with the Flutter Engine and unregister it
16 | /// when the Flutter Engine is detached from the Activity
17 | private lateinit var channel : MethodChannel
18 |
19 | override fun onAttachedToEngine(flutterPluginBinding: FlutterPlugin.FlutterPluginBinding) {
20 | channel = MethodChannel(flutterPluginBinding.binaryMessenger, "flutter_popup")
21 | channel.setMethodCallHandler(this)
22 | }
23 |
24 | override fun onMethodCall(call: MethodCall, result: Result) {
25 | if (call.method == "getPlatformVersion") {
26 | result.success("Android ${android.os.Build.VERSION.RELEASE}")
27 | } else {
28 | result.notImplemented()
29 | }
30 | }
31 |
32 | override fun onDetachedFromEngine(binding: FlutterPlugin.FlutterPluginBinding) {
33 | channel.setMethodCallHandler(null)
34 | }
35 | }
36 |
--------------------------------------------------------------------------------
/android/src/test/kotlin/com/example/flutter_popup/FlutterPopupPluginTest.kt:
--------------------------------------------------------------------------------
1 | package com.example.flutter_popup
2 |
3 | import io.flutter.plugin.common.MethodCall
4 | import io.flutter.plugin.common.MethodChannel
5 | import kotlin.test.Test
6 | import org.mockito.Mockito
7 |
8 | /*
9 | * This demonstrates a simple unit test of the Kotlin portion of this plugin's implementation.
10 | *
11 | * Once you have built the plugin's example app, you can run these tests from the command
12 | * line by running `./gradlew testDebugUnitTest` in the `example/android/` directory, or
13 | * you can run them directly from IDEs that support JUnit such as Android Studio.
14 | */
15 |
16 | internal class FlutterPopupPluginTest {
17 | @Test
18 | fun onMethodCall_getPlatformVersion_returnsExpectedValue() {
19 | val plugin = FlutterPopupPlugin()
20 |
21 | val call = MethodCall("getPlatformVersion", null)
22 | val mockResult: MethodChannel.Result = Mockito.mock(MethodChannel.Result::class.java)
23 | plugin.onMethodCall(call, mockResult)
24 |
25 | Mockito.verify(mockResult).success("Android " + android.os.Build.VERSION.RELEASE)
26 | }
27 | }
28 |
--------------------------------------------------------------------------------
/example/.gitignore:
--------------------------------------------------------------------------------
1 | # Miscellaneous
2 | *.class
3 | *.log
4 | *.pyc
5 | *.swp
6 | .DS_Store
7 | .atom/
8 | .build/
9 | .buildlog/
10 | .history
11 | .svn/
12 | .swiftpm/
13 | migrate_working_dir/
14 |
15 | # IntelliJ related
16 | *.iml
17 | *.ipr
18 | *.iws
19 | .idea/
20 |
21 | # The .vscode folder contains launch configuration and tasks you configure in
22 | # VS Code which you may wish to be included in version control, so this line
23 | # is commented out by default.
24 | #.vscode/
25 |
26 | # Flutter/Dart/Pub related
27 | **/doc/api/
28 | **/ios/Flutter/.last_build_id
29 | .dart_tool/
30 | .flutter-plugins
31 | .flutter-plugins-dependencies
32 | .packages
33 | .pub-cache/
34 | .pub/
35 | /build/
36 |
37 | # Symbolication related
38 | app.*.symbols
39 |
40 | # Obfuscation related
41 | app.*.map.json
42 |
43 | # Android Studio will place build artifacts here
44 | /android/app/debug
45 | /android/app/profile
46 | /android/app/release
47 |
--------------------------------------------------------------------------------
/example/README.md:
--------------------------------------------------------------------------------
1 | # flutter_popup_example
2 |
3 | Demonstrates how to use the flutter_popup plugin.
4 |
5 | ## Getting Started
6 |
7 | This project is a starting point for a Flutter application.
8 |
9 | A few resources to get you started if this is your first Flutter project:
10 |
11 | - [Lab: Write your first Flutter app](https://docs.flutter.dev/get-started/codelab)
12 | - [Cookbook: Useful Flutter samples](https://docs.flutter.dev/cookbook)
13 |
14 | For help getting started with Flutter development, view the
15 | [online documentation](https://docs.flutter.dev/), which offers tutorials,
16 | samples, guidance on mobile development, and a full API reference.
17 |
--------------------------------------------------------------------------------
/example/analysis_options.yaml:
--------------------------------------------------------------------------------
1 | # This file configures the analyzer, which statically analyzes Dart code to
2 | # check for errors, warnings, and lints.
3 | #
4 | # The issues identified by the analyzer are surfaced in the UI of Dart-enabled
5 | # IDEs (https://dart.dev/tools#ides-and-editors). The analyzer can also be
6 | # invoked from the command line by running `flutter analyze`.
7 |
8 | # The following line activates a set of recommended lints for Flutter apps,
9 | # packages, and plugins designed to encourage good coding practices.
10 | #include: package:flutter_lints/flutter.yaml
11 |
12 | linter:
13 | # The lint rules applied to this project can be customized in the
14 | # section below to disable rules from the `package:flutter_lints/flutter.yaml`
15 | # included above or to enable additional rules. A list of all available lints
16 | # and their documentation is published at https://dart.dev/lints.
17 | #
18 | # Instead of disabling a lint rule for the entire project in the
19 | # section below, it can also be suppressed for a single line of code
20 | # or a specific dart file by using the `// ignore: name_of_lint` and
21 | # `// ignore_for_file: name_of_lint` syntax on the line or in the file
22 | # producing the lint.
23 | rules:
24 | # avoid_print: false # Uncomment to disable the `avoid_print` rule
25 | # prefer_single_quotes: true # Uncomment to enable the `prefer_single_quotes` rule
26 |
27 | # Additional information about this file can be found at
28 | # https://dart.dev/guides/language/analysis-options
29 |
--------------------------------------------------------------------------------
/example/android/.gitignore:
--------------------------------------------------------------------------------
1 | gradle-wrapper.jar
2 | /.gradle
3 | /captures/
4 | /gradlew
5 | /gradlew.bat
6 | /local.properties
7 | GeneratedPluginRegistrant.java
8 |
9 | # Remember to never publicly share your keystore.
10 | # See https://flutter.dev/docs/deployment/android#reference-the-keystore-from-the-app
11 | key.properties
12 | **/*.keystore
13 | **/*.jks
14 |
--------------------------------------------------------------------------------
/example/android/app/build.gradle:
--------------------------------------------------------------------------------
1 | plugins {
2 | id "com.android.application"
3 | id "kotlin-android"
4 | id "dev.flutter.flutter-gradle-plugin"
5 | }
6 |
7 | def localProperties = new Properties()
8 | def localPropertiesFile = rootProject.file('local.properties')
9 | if (localPropertiesFile.exists()) {
10 | localPropertiesFile.withReader('UTF-8') { reader ->
11 | localProperties.load(reader)
12 | }
13 | }
14 |
15 | def flutterVersionCode = localProperties.getProperty('flutter.versionCode')
16 | if (flutterVersionCode == null) {
17 | flutterVersionCode = '1'
18 | }
19 |
20 | def flutterVersionName = localProperties.getProperty('flutter.versionName')
21 | if (flutterVersionName == null) {
22 | flutterVersionName = '1.0'
23 | }
24 |
25 | android {
26 | namespace "com.example.flutter_popup_example"
27 | compileSdkVersion flutter.compileSdkVersion
28 | ndkVersion flutter.ndkVersion
29 |
30 | compileOptions {
31 | sourceCompatibility JavaVersion.VERSION_1_8
32 | targetCompatibility JavaVersion.VERSION_1_8
33 | }
34 |
35 | kotlinOptions {
36 | jvmTarget = '1.8'
37 | }
38 |
39 | sourceSets {
40 | main.java.srcDirs += 'src/main/kotlin'
41 | }
42 |
43 | defaultConfig {
44 | // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
45 | applicationId "com.example.flutter_popup_example"
46 | // You can update the following values to match your application needs.
47 | // For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-gradle-build-configuration.
48 | minSdkVersion flutter.minSdkVersion
49 | targetSdkVersion flutter.targetSdkVersion
50 | versionCode flutterVersionCode.toInteger()
51 | versionName flutterVersionName
52 | }
53 |
54 | buildTypes {
55 | release {
56 | // TODO: Add your own signing config for the release build.
57 | // Signing with the debug keys for now, so `flutter run --release` works.
58 | signingConfig signingConfigs.debug
59 | }
60 | }
61 | }
62 |
63 | flutter {
64 | source '../..'
65 | }
66 |
67 | dependencies {}
68 |
--------------------------------------------------------------------------------
/example/android/app/src/debug/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
2 |
6 |
7 |
8 |
--------------------------------------------------------------------------------
/example/android/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
2 |
6 |
14 |
18 |
22 |
23 |
24 |
25 |
26 |
27 |
29 |
32 |
33 |
34 |
--------------------------------------------------------------------------------
/example/android/app/src/main/kotlin/com/example/flutter_popup_example/MainActivity.kt:
--------------------------------------------------------------------------------
1 | package com.example.flutter_popup_example
2 |
3 | import io.flutter.embedding.android.FlutterActivity
4 |
5 | class MainActivity: FlutterActivity() {
6 | }
7 |
--------------------------------------------------------------------------------
/example/android/app/src/main/res/drawable-v21/launch_background.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
12 |
13 |
--------------------------------------------------------------------------------
/example/android/app/src/main/res/drawable/launch_background.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
12 |
13 |
--------------------------------------------------------------------------------
/example/android/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/example/android/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/example/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/example/android/app/src/main/res/values-night/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
9 |
15 |
18 |
19 |
--------------------------------------------------------------------------------
/example/android/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
9 |
15 |
18 |
19 |
--------------------------------------------------------------------------------
/example/android/app/src/profile/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
2 |
6 |
7 |
8 |
--------------------------------------------------------------------------------
/example/android/build.gradle:
--------------------------------------------------------------------------------
1 | buildscript {
2 | ext.kotlin_version = '1.7.10'
3 | repositories {
4 | google()
5 | mavenCentral()
6 | }
7 |
8 | dependencies {
9 | classpath 'com.android.tools.build:gradle:7.3.0'
10 | classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
11 | }
12 | }
13 |
14 | allprojects {
15 | repositories {
16 | google()
17 | mavenCentral()
18 | }
19 | }
20 |
21 | rootProject.buildDir = '../build'
22 | subprojects {
23 | project.buildDir = "${rootProject.buildDir}/${project.name}"
24 | }
25 | subprojects {
26 | project.evaluationDependsOn(':app')
27 | }
28 |
29 | tasks.register("clean", Delete) {
30 | delete rootProject.buildDir
31 | }
32 |
--------------------------------------------------------------------------------
/example/android/gradle.properties:
--------------------------------------------------------------------------------
1 | org.gradle.jvmargs=-Xmx1536M
2 | android.useAndroidX=true
3 | android.enableJetifier=true
4 |
--------------------------------------------------------------------------------
/example/android/gradle/wrapper/gradle-wrapper.properties:
--------------------------------------------------------------------------------
1 | distributionBase=GRADLE_USER_HOME
2 | distributionPath=wrapper/dists
3 | zipStoreBase=GRADLE_USER_HOME
4 | zipStorePath=wrapper/dists
5 | distributionUrl=https\://services.gradle.org/distributions/gradle-7.5-all.zip
6 |
--------------------------------------------------------------------------------
/example/android/settings.gradle:
--------------------------------------------------------------------------------
1 | pluginManagement {
2 | def flutterSdkPath = {
3 | def properties = new Properties()
4 | file("local.properties").withInputStream { properties.load(it) }
5 | def flutterSdkPath = properties.getProperty("flutter.sdk")
6 | assert flutterSdkPath != null, "flutter.sdk not set in local.properties"
7 | return flutterSdkPath
8 | }
9 | settings.ext.flutterSdkPath = flutterSdkPath()
10 |
11 | includeBuild("${settings.ext.flutterSdkPath}/packages/flutter_tools/gradle")
12 |
13 | plugins {
14 | id "dev.flutter.flutter-gradle-plugin" version "1.0.0" apply false
15 | }
16 | }
17 |
18 | include ":app"
19 |
20 | apply from: "${settings.ext.flutterSdkPath}/packages/flutter_tools/gradle/app_plugin_loader.gradle"
21 |
--------------------------------------------------------------------------------
/example/ios/.gitignore:
--------------------------------------------------------------------------------
1 | **/dgph
2 | *.mode1v3
3 | *.mode2v3
4 | *.moved-aside
5 | *.pbxuser
6 | *.perspectivev3
7 | **/*sync/
8 | .sconsign.dblite
9 | .tags*
10 | **/.vagrant/
11 | **/DerivedData/
12 | Icon?
13 | **/Pods/
14 | **/.symlinks/
15 | profile
16 | xcuserdata
17 | **/.generated/
18 | Flutter/App.framework
19 | Flutter/Flutter.framework
20 | Flutter/Flutter.podspec
21 | Flutter/Generated.xcconfig
22 | Flutter/ephemeral/
23 | Flutter/app.flx
24 | Flutter/app.zip
25 | Flutter/flutter_assets/
26 | Flutter/flutter_export_environment.sh
27 | ServiceDefinitions.json
28 | Runner/GeneratedPluginRegistrant.*
29 |
30 | # Exceptions to above rules.
31 | !default.mode1v3
32 | !default.mode2v3
33 | !default.pbxuser
34 | !default.perspectivev3
35 |
--------------------------------------------------------------------------------
/example/ios/Flutter/AppFrameworkInfo.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleExecutable
8 | App
9 | CFBundleIdentifier
10 | io.flutter.flutter.app
11 | CFBundleInfoDictionaryVersion
12 | 6.0
13 | CFBundleName
14 | App
15 | CFBundlePackageType
16 | FMWK
17 | CFBundleShortVersionString
18 | 1.0
19 | CFBundleSignature
20 | ????
21 | CFBundleVersion
22 | 1.0
23 | MinimumOSVersion
24 | 12.0
25 |
26 |
27 |
--------------------------------------------------------------------------------
/example/ios/Flutter/Debug.xcconfig:
--------------------------------------------------------------------------------
1 | #include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"
2 | #include "Generated.xcconfig"
3 |
--------------------------------------------------------------------------------
/example/ios/Flutter/Release.xcconfig:
--------------------------------------------------------------------------------
1 | #include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"
2 | #include "Generated.xcconfig"
3 |
--------------------------------------------------------------------------------
/example/ios/Podfile:
--------------------------------------------------------------------------------
1 | # Uncomment this line to define a global platform for your project
2 | # platform :ios, '12.0'
3 |
4 | # CocoaPods analytics sends network stats synchronously affecting flutter build latency.
5 | ENV['COCOAPODS_DISABLE_STATS'] = 'true'
6 |
7 | project 'Runner', {
8 | 'Debug' => :debug,
9 | 'Profile' => :release,
10 | 'Release' => :release,
11 | }
12 |
13 | def flutter_root
14 | generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'Generated.xcconfig'), __FILE__)
15 | unless File.exist?(generated_xcode_build_settings_path)
16 | raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure flutter pub get is executed first"
17 | end
18 |
19 | File.foreach(generated_xcode_build_settings_path) do |line|
20 | matches = line.match(/FLUTTER_ROOT\=(.*)/)
21 | return matches[1].strip if matches
22 | end
23 | raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Generated.xcconfig, then run flutter pub get"
24 | end
25 |
26 | require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root)
27 |
28 | flutter_ios_podfile_setup
29 |
30 | target 'Runner' do
31 | use_frameworks!
32 | use_modular_headers!
33 |
34 | flutter_install_all_ios_pods File.dirname(File.realpath(__FILE__))
35 | target 'RunnerTests' do
36 | inherit! :search_paths
37 | end
38 | end
39 |
40 | post_install do |installer|
41 | installer.pods_project.targets.each do |target|
42 | flutter_additional_ios_build_settings(target)
43 | end
44 | end
45 |
--------------------------------------------------------------------------------
/example/ios/Podfile.lock:
--------------------------------------------------------------------------------
1 | PODS:
2 | - Flutter (1.0.0)
3 | - integration_test (0.0.1):
4 | - Flutter
5 |
6 | DEPENDENCIES:
7 | - Flutter (from `Flutter`)
8 | - integration_test (from `.symlinks/plugins/integration_test/ios`)
9 |
10 | EXTERNAL SOURCES:
11 | Flutter:
12 | :path: Flutter
13 | integration_test:
14 | :path: ".symlinks/plugins/integration_test/ios"
15 |
16 | SPEC CHECKSUMS:
17 | Flutter: f04841e97a9d0b0a8025694d0796dd46242b2854
18 | integration_test: 2d03ab552da9a1f408709a6acf3d7ca4cb3cb307
19 |
20 | PODFILE CHECKSUM: 819463e6a0290f5a72f145ba7cde16e8b6ef0796
21 |
22 | COCOAPODS: 1.16.2
23 |
--------------------------------------------------------------------------------
/example/ios/Runner.xcodeproj/project.pbxproj:
--------------------------------------------------------------------------------
1 | // !$*UTF8*$!
2 | {
3 | archiveVersion = 1;
4 | classes = {
5 | };
6 | objectVersion = 54;
7 | objects = {
8 |
9 | /* Begin PBXBuildFile section */
10 | 1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };
11 | 331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; };
12 | 3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };
13 | 74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; };
14 | 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; };
15 | 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; };
16 | 97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; };
17 | A09FCB0ACE0399F8484DC8F0 /* Pods_RunnerTests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = E33CFDEC900BDDCB65E1D896 /* Pods_RunnerTests.framework */; };
18 | C8412E8B9226D3E4941CB04A /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = EB8781E5D827654613DA3F03 /* Pods_Runner.framework */; };
19 | /* End PBXBuildFile section */
20 |
21 | /* Begin PBXContainerItemProxy section */
22 | 331C8085294A63A400263BE5 /* PBXContainerItemProxy */ = {
23 | isa = PBXContainerItemProxy;
24 | containerPortal = 97C146E61CF9000F007C117D /* Project object */;
25 | proxyType = 1;
26 | remoteGlobalIDString = 97C146ED1CF9000F007C117D;
27 | remoteInfo = Runner;
28 | };
29 | /* End PBXContainerItemProxy section */
30 |
31 | /* Begin PBXCopyFilesBuildPhase section */
32 | 9705A1C41CF9048500538489 /* Embed Frameworks */ = {
33 | isa = PBXCopyFilesBuildPhase;
34 | buildActionMask = 2147483647;
35 | dstPath = "";
36 | dstSubfolderSpec = 10;
37 | files = (
38 | );
39 | name = "Embed Frameworks";
40 | runOnlyForDeploymentPostprocessing = 0;
41 | };
42 | /* End PBXCopyFilesBuildPhase section */
43 |
44 | /* Begin PBXFileReference section */
45 | 0CCC7CD7633C88CE7CE3D591 /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = ""; };
46 | 1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = ""; };
47 | 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = ""; };
48 | 331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = ""; };
49 | 331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
50 | 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = ""; };
51 | 46624F75224D0DA99863E41F /* Pods-RunnerTests.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.profile.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.profile.xcconfig"; sourceTree = ""; };
52 | 4A10A920FFCEE6E51CDA8EB0 /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = ""; };
53 | 74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = ""; };
54 | 74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; };
55 | 7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = ""; };
56 | 890E367A852DC1171B44EBDF /* Pods-RunnerTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.release.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.release.xcconfig"; sourceTree = ""; };
57 | 9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = ""; };
58 | 9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = ""; };
59 | 97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };
60 | 97C146FB1CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; };
61 | 97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; };
62 | 97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; };
63 | 97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
64 | A891E0476C925DD7908B5E73 /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = ""; };
65 | D6CCD6F2473ADDD18FC27CE2 /* Pods-RunnerTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.debug.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.debug.xcconfig"; sourceTree = ""; };
66 | E33CFDEC900BDDCB65E1D896 /* Pods_RunnerTests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RunnerTests.framework; sourceTree = BUILT_PRODUCTS_DIR; };
67 | EB8781E5D827654613DA3F03 /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; };
68 | /* End PBXFileReference section */
69 |
70 | /* Begin PBXFrameworksBuildPhase section */
71 | 97C146EB1CF9000F007C117D /* Frameworks */ = {
72 | isa = PBXFrameworksBuildPhase;
73 | buildActionMask = 2147483647;
74 | files = (
75 | C8412E8B9226D3E4941CB04A /* Pods_Runner.framework in Frameworks */,
76 | );
77 | runOnlyForDeploymentPostprocessing = 0;
78 | };
79 | D1D26699D6FEAE7BD05A0013 /* Frameworks */ = {
80 | isa = PBXFrameworksBuildPhase;
81 | buildActionMask = 2147483647;
82 | files = (
83 | A09FCB0ACE0399F8484DC8F0 /* Pods_RunnerTests.framework in Frameworks */,
84 | );
85 | runOnlyForDeploymentPostprocessing = 0;
86 | };
87 | /* End PBXFrameworksBuildPhase section */
88 |
89 | /* Begin PBXGroup section */
90 | 1C21F3FB9E4A36B7CDCEB300 /* Frameworks */ = {
91 | isa = PBXGroup;
92 | children = (
93 | EB8781E5D827654613DA3F03 /* Pods_Runner.framework */,
94 | E33CFDEC900BDDCB65E1D896 /* Pods_RunnerTests.framework */,
95 | );
96 | name = Frameworks;
97 | sourceTree = "";
98 | };
99 | 331C8082294A63A400263BE5 /* RunnerTests */ = {
100 | isa = PBXGroup;
101 | children = (
102 | 331C807B294A618700263BE5 /* RunnerTests.swift */,
103 | );
104 | path = RunnerTests;
105 | sourceTree = "";
106 | };
107 | 4052FFF8ED0C0F48BC731BCB /* Pods */ = {
108 | isa = PBXGroup;
109 | children = (
110 | 0CCC7CD7633C88CE7CE3D591 /* Pods-Runner.debug.xcconfig */,
111 | 4A10A920FFCEE6E51CDA8EB0 /* Pods-Runner.release.xcconfig */,
112 | A891E0476C925DD7908B5E73 /* Pods-Runner.profile.xcconfig */,
113 | D6CCD6F2473ADDD18FC27CE2 /* Pods-RunnerTests.debug.xcconfig */,
114 | 890E367A852DC1171B44EBDF /* Pods-RunnerTests.release.xcconfig */,
115 | 46624F75224D0DA99863E41F /* Pods-RunnerTests.profile.xcconfig */,
116 | );
117 | name = Pods;
118 | path = Pods;
119 | sourceTree = "";
120 | };
121 | 9740EEB11CF90186004384FC /* Flutter */ = {
122 | isa = PBXGroup;
123 | children = (
124 | 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */,
125 | 9740EEB21CF90195004384FC /* Debug.xcconfig */,
126 | 7AFA3C8E1D35360C0083082E /* Release.xcconfig */,
127 | 9740EEB31CF90195004384FC /* Generated.xcconfig */,
128 | );
129 | name = Flutter;
130 | sourceTree = "";
131 | };
132 | 97C146E51CF9000F007C117D = {
133 | isa = PBXGroup;
134 | children = (
135 | 9740EEB11CF90186004384FC /* Flutter */,
136 | 97C146F01CF9000F007C117D /* Runner */,
137 | 97C146EF1CF9000F007C117D /* Products */,
138 | 331C8082294A63A400263BE5 /* RunnerTests */,
139 | 4052FFF8ED0C0F48BC731BCB /* Pods */,
140 | 1C21F3FB9E4A36B7CDCEB300 /* Frameworks */,
141 | );
142 | sourceTree = "";
143 | };
144 | 97C146EF1CF9000F007C117D /* Products */ = {
145 | isa = PBXGroup;
146 | children = (
147 | 97C146EE1CF9000F007C117D /* Runner.app */,
148 | 331C8081294A63A400263BE5 /* RunnerTests.xctest */,
149 | );
150 | name = Products;
151 | sourceTree = "";
152 | };
153 | 97C146F01CF9000F007C117D /* Runner */ = {
154 | isa = PBXGroup;
155 | children = (
156 | 97C146FA1CF9000F007C117D /* Main.storyboard */,
157 | 97C146FD1CF9000F007C117D /* Assets.xcassets */,
158 | 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */,
159 | 97C147021CF9000F007C117D /* Info.plist */,
160 | 1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */,
161 | 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */,
162 | 74858FAE1ED2DC5600515810 /* AppDelegate.swift */,
163 | 74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */,
164 | );
165 | path = Runner;
166 | sourceTree = "";
167 | };
168 | /* End PBXGroup section */
169 |
170 | /* Begin PBXNativeTarget section */
171 | 331C8080294A63A400263BE5 /* RunnerTests */ = {
172 | isa = PBXNativeTarget;
173 | buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */;
174 | buildPhases = (
175 | 3E1E5EBDF02EEA8250755616 /* [CP] Check Pods Manifest.lock */,
176 | 331C807D294A63A400263BE5 /* Sources */,
177 | 331C807F294A63A400263BE5 /* Resources */,
178 | D1D26699D6FEAE7BD05A0013 /* Frameworks */,
179 | );
180 | buildRules = (
181 | );
182 | dependencies = (
183 | 331C8086294A63A400263BE5 /* PBXTargetDependency */,
184 | );
185 | name = RunnerTests;
186 | productName = RunnerTests;
187 | productReference = 331C8081294A63A400263BE5 /* RunnerTests.xctest */;
188 | productType = "com.apple.product-type.bundle.unit-test";
189 | };
190 | 97C146ED1CF9000F007C117D /* Runner */ = {
191 | isa = PBXNativeTarget;
192 | buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
193 | buildPhases = (
194 | D748D3762ED91B6B6A9B7E0C /* [CP] Check Pods Manifest.lock */,
195 | 9740EEB61CF901F6004384FC /* Run Script */,
196 | 97C146EA1CF9000F007C117D /* Sources */,
197 | 97C146EB1CF9000F007C117D /* Frameworks */,
198 | 97C146EC1CF9000F007C117D /* Resources */,
199 | 9705A1C41CF9048500538489 /* Embed Frameworks */,
200 | 3B06AD1E1E4923F5004D2608 /* Thin Binary */,
201 | C4C5A5B7E35F01B6D5ACDFBC /* [CP] Embed Pods Frameworks */,
202 | );
203 | buildRules = (
204 | );
205 | dependencies = (
206 | );
207 | name = Runner;
208 | productName = Runner;
209 | productReference = 97C146EE1CF9000F007C117D /* Runner.app */;
210 | productType = "com.apple.product-type.application";
211 | };
212 | /* End PBXNativeTarget section */
213 |
214 | /* Begin PBXProject section */
215 | 97C146E61CF9000F007C117D /* Project object */ = {
216 | isa = PBXProject;
217 | attributes = {
218 | BuildIndependentTargetsInParallel = YES;
219 | LastUpgradeCheck = 1430;
220 | ORGANIZATIONNAME = "";
221 | TargetAttributes = {
222 | 331C8080294A63A400263BE5 = {
223 | CreatedOnToolsVersion = 14.0;
224 | TestTargetID = 97C146ED1CF9000F007C117D;
225 | };
226 | 97C146ED1CF9000F007C117D = {
227 | CreatedOnToolsVersion = 7.3.1;
228 | LastSwiftMigration = 1100;
229 | };
230 | };
231 | };
232 | buildConfigurationList = 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */;
233 | compatibilityVersion = "Xcode 9.3";
234 | developmentRegion = en;
235 | hasScannedForEncodings = 0;
236 | knownRegions = (
237 | en,
238 | Base,
239 | );
240 | mainGroup = 97C146E51CF9000F007C117D;
241 | productRefGroup = 97C146EF1CF9000F007C117D /* Products */;
242 | projectDirPath = "";
243 | projectRoot = "";
244 | targets = (
245 | 97C146ED1CF9000F007C117D /* Runner */,
246 | 331C8080294A63A400263BE5 /* RunnerTests */,
247 | );
248 | };
249 | /* End PBXProject section */
250 |
251 | /* Begin PBXResourcesBuildPhase section */
252 | 331C807F294A63A400263BE5 /* Resources */ = {
253 | isa = PBXResourcesBuildPhase;
254 | buildActionMask = 2147483647;
255 | files = (
256 | );
257 | runOnlyForDeploymentPostprocessing = 0;
258 | };
259 | 97C146EC1CF9000F007C117D /* Resources */ = {
260 | isa = PBXResourcesBuildPhase;
261 | buildActionMask = 2147483647;
262 | files = (
263 | 97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */,
264 | 3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */,
265 | 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */,
266 | 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */,
267 | );
268 | runOnlyForDeploymentPostprocessing = 0;
269 | };
270 | /* End PBXResourcesBuildPhase section */
271 |
272 | /* Begin PBXShellScriptBuildPhase section */
273 | 3B06AD1E1E4923F5004D2608 /* Thin Binary */ = {
274 | isa = PBXShellScriptBuildPhase;
275 | alwaysOutOfDate = 1;
276 | buildActionMask = 2147483647;
277 | files = (
278 | );
279 | inputPaths = (
280 | "${TARGET_BUILD_DIR}/${INFOPLIST_PATH}",
281 | );
282 | name = "Thin Binary";
283 | outputPaths = (
284 | );
285 | runOnlyForDeploymentPostprocessing = 0;
286 | shellPath = /bin/sh;
287 | shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin";
288 | };
289 | 3E1E5EBDF02EEA8250755616 /* [CP] Check Pods Manifest.lock */ = {
290 | isa = PBXShellScriptBuildPhase;
291 | buildActionMask = 2147483647;
292 | files = (
293 | );
294 | inputFileListPaths = (
295 | );
296 | inputPaths = (
297 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
298 | "${PODS_ROOT}/Manifest.lock",
299 | );
300 | name = "[CP] Check Pods Manifest.lock";
301 | outputFileListPaths = (
302 | );
303 | outputPaths = (
304 | "$(DERIVED_FILE_DIR)/Pods-RunnerTests-checkManifestLockResult.txt",
305 | );
306 | runOnlyForDeploymentPostprocessing = 0;
307 | shellPath = /bin/sh;
308 | shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
309 | showEnvVarsInLog = 0;
310 | };
311 | 9740EEB61CF901F6004384FC /* Run Script */ = {
312 | isa = PBXShellScriptBuildPhase;
313 | alwaysOutOfDate = 1;
314 | buildActionMask = 2147483647;
315 | files = (
316 | );
317 | inputPaths = (
318 | );
319 | name = "Run Script";
320 | outputPaths = (
321 | );
322 | runOnlyForDeploymentPostprocessing = 0;
323 | shellPath = /bin/sh;
324 | shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build";
325 | };
326 | C4C5A5B7E35F01B6D5ACDFBC /* [CP] Embed Pods Frameworks */ = {
327 | isa = PBXShellScriptBuildPhase;
328 | buildActionMask = 2147483647;
329 | files = (
330 | );
331 | inputFileListPaths = (
332 | "${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-input-files.xcfilelist",
333 | );
334 | name = "[CP] Embed Pods Frameworks";
335 | outputFileListPaths = (
336 | "${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-output-files.xcfilelist",
337 | );
338 | runOnlyForDeploymentPostprocessing = 0;
339 | shellPath = /bin/sh;
340 | shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh\"\n";
341 | showEnvVarsInLog = 0;
342 | };
343 | D748D3762ED91B6B6A9B7E0C /* [CP] Check Pods Manifest.lock */ = {
344 | isa = PBXShellScriptBuildPhase;
345 | buildActionMask = 2147483647;
346 | files = (
347 | );
348 | inputFileListPaths = (
349 | );
350 | inputPaths = (
351 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
352 | "${PODS_ROOT}/Manifest.lock",
353 | );
354 | name = "[CP] Check Pods Manifest.lock";
355 | outputFileListPaths = (
356 | );
357 | outputPaths = (
358 | "$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt",
359 | );
360 | runOnlyForDeploymentPostprocessing = 0;
361 | shellPath = /bin/sh;
362 | shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
363 | showEnvVarsInLog = 0;
364 | };
365 | /* End PBXShellScriptBuildPhase section */
366 |
367 | /* Begin PBXSourcesBuildPhase section */
368 | 331C807D294A63A400263BE5 /* Sources */ = {
369 | isa = PBXSourcesBuildPhase;
370 | buildActionMask = 2147483647;
371 | files = (
372 | 331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */,
373 | );
374 | runOnlyForDeploymentPostprocessing = 0;
375 | };
376 | 97C146EA1CF9000F007C117D /* Sources */ = {
377 | isa = PBXSourcesBuildPhase;
378 | buildActionMask = 2147483647;
379 | files = (
380 | 74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */,
381 | 1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */,
382 | );
383 | runOnlyForDeploymentPostprocessing = 0;
384 | };
385 | /* End PBXSourcesBuildPhase section */
386 |
387 | /* Begin PBXTargetDependency section */
388 | 331C8086294A63A400263BE5 /* PBXTargetDependency */ = {
389 | isa = PBXTargetDependency;
390 | target = 97C146ED1CF9000F007C117D /* Runner */;
391 | targetProxy = 331C8085294A63A400263BE5 /* PBXContainerItemProxy */;
392 | };
393 | /* End PBXTargetDependency section */
394 |
395 | /* Begin PBXVariantGroup section */
396 | 97C146FA1CF9000F007C117D /* Main.storyboard */ = {
397 | isa = PBXVariantGroup;
398 | children = (
399 | 97C146FB1CF9000F007C117D /* Base */,
400 | );
401 | name = Main.storyboard;
402 | sourceTree = "";
403 | };
404 | 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */ = {
405 | isa = PBXVariantGroup;
406 | children = (
407 | 97C147001CF9000F007C117D /* Base */,
408 | );
409 | name = LaunchScreen.storyboard;
410 | sourceTree = "";
411 | };
412 | /* End PBXVariantGroup section */
413 |
414 | /* Begin XCBuildConfiguration section */
415 | 249021D3217E4FDB00AE95B9 /* Profile */ = {
416 | isa = XCBuildConfiguration;
417 | buildSettings = {
418 | ALWAYS_SEARCH_USER_PATHS = NO;
419 | CLANG_ANALYZER_NONNULL = YES;
420 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
421 | CLANG_CXX_LIBRARY = "libc++";
422 | CLANG_ENABLE_MODULES = YES;
423 | CLANG_ENABLE_OBJC_ARC = YES;
424 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
425 | CLANG_WARN_BOOL_CONVERSION = YES;
426 | CLANG_WARN_COMMA = YES;
427 | CLANG_WARN_CONSTANT_CONVERSION = YES;
428 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
429 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
430 | CLANG_WARN_EMPTY_BODY = YES;
431 | CLANG_WARN_ENUM_CONVERSION = YES;
432 | CLANG_WARN_INFINITE_RECURSION = YES;
433 | CLANG_WARN_INT_CONVERSION = YES;
434 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
435 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
436 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
437 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
438 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
439 | CLANG_WARN_STRICT_PROTOTYPES = YES;
440 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
441 | CLANG_WARN_UNREACHABLE_CODE = YES;
442 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
443 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
444 | COPY_PHASE_STRIP = NO;
445 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
446 | ENABLE_NS_ASSERTIONS = NO;
447 | ENABLE_STRICT_OBJC_MSGSEND = YES;
448 | GCC_C_LANGUAGE_STANDARD = gnu99;
449 | GCC_NO_COMMON_BLOCKS = YES;
450 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
451 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
452 | GCC_WARN_UNDECLARED_SELECTOR = YES;
453 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
454 | GCC_WARN_UNUSED_FUNCTION = YES;
455 | GCC_WARN_UNUSED_VARIABLE = YES;
456 | IPHONEOS_DEPLOYMENT_TARGET = 12.0;
457 | MTL_ENABLE_DEBUG_INFO = NO;
458 | SDKROOT = iphoneos;
459 | SUPPORTED_PLATFORMS = iphoneos;
460 | TARGETED_DEVICE_FAMILY = "1,2";
461 | VALIDATE_PRODUCT = YES;
462 | };
463 | name = Profile;
464 | };
465 | 249021D4217E4FDB00AE95B9 /* Profile */ = {
466 | isa = XCBuildConfiguration;
467 | baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
468 | buildSettings = {
469 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
470 | CLANG_ENABLE_MODULES = YES;
471 | CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
472 | DEVELOPMENT_TEAM = 3563963V57;
473 | ENABLE_BITCODE = NO;
474 | INFOPLIST_FILE = Runner/Info.plist;
475 | LD_RUNPATH_SEARCH_PATHS = (
476 | "$(inherited)",
477 | "@executable_path/Frameworks",
478 | );
479 | PRODUCT_BUNDLE_IDENTIFIER = com.example.flutterPopupExample;
480 | PRODUCT_NAME = "$(TARGET_NAME)";
481 | SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
482 | SWIFT_VERSION = 5.0;
483 | VERSIONING_SYSTEM = "apple-generic";
484 | };
485 | name = Profile;
486 | };
487 | 331C8088294A63A400263BE5 /* Debug */ = {
488 | isa = XCBuildConfiguration;
489 | baseConfigurationReference = D6CCD6F2473ADDD18FC27CE2 /* Pods-RunnerTests.debug.xcconfig */;
490 | buildSettings = {
491 | BUNDLE_LOADER = "$(TEST_HOST)";
492 | CODE_SIGN_STYLE = Automatic;
493 | CURRENT_PROJECT_VERSION = 1;
494 | GENERATE_INFOPLIST_FILE = YES;
495 | MARKETING_VERSION = 1.0;
496 | PRODUCT_BUNDLE_IDENTIFIER = com.example.flutterPopupExample.RunnerTests;
497 | PRODUCT_NAME = "$(TARGET_NAME)";
498 | SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
499 | SWIFT_OPTIMIZATION_LEVEL = "-Onone";
500 | SWIFT_VERSION = 5.0;
501 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner";
502 | };
503 | name = Debug;
504 | };
505 | 331C8089294A63A400263BE5 /* Release */ = {
506 | isa = XCBuildConfiguration;
507 | baseConfigurationReference = 890E367A852DC1171B44EBDF /* Pods-RunnerTests.release.xcconfig */;
508 | buildSettings = {
509 | BUNDLE_LOADER = "$(TEST_HOST)";
510 | CODE_SIGN_STYLE = Automatic;
511 | CURRENT_PROJECT_VERSION = 1;
512 | GENERATE_INFOPLIST_FILE = YES;
513 | MARKETING_VERSION = 1.0;
514 | PRODUCT_BUNDLE_IDENTIFIER = com.example.flutterPopupExample.RunnerTests;
515 | PRODUCT_NAME = "$(TARGET_NAME)";
516 | SWIFT_VERSION = 5.0;
517 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner";
518 | };
519 | name = Release;
520 | };
521 | 331C808A294A63A400263BE5 /* Profile */ = {
522 | isa = XCBuildConfiguration;
523 | baseConfigurationReference = 46624F75224D0DA99863E41F /* Pods-RunnerTests.profile.xcconfig */;
524 | buildSettings = {
525 | BUNDLE_LOADER = "$(TEST_HOST)";
526 | CODE_SIGN_STYLE = Automatic;
527 | CURRENT_PROJECT_VERSION = 1;
528 | GENERATE_INFOPLIST_FILE = YES;
529 | MARKETING_VERSION = 1.0;
530 | PRODUCT_BUNDLE_IDENTIFIER = com.example.flutterPopupExample.RunnerTests;
531 | PRODUCT_NAME = "$(TARGET_NAME)";
532 | SWIFT_VERSION = 5.0;
533 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner";
534 | };
535 | name = Profile;
536 | };
537 | 97C147031CF9000F007C117D /* Debug */ = {
538 | isa = XCBuildConfiguration;
539 | buildSettings = {
540 | ALWAYS_SEARCH_USER_PATHS = NO;
541 | CLANG_ANALYZER_NONNULL = YES;
542 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
543 | CLANG_CXX_LIBRARY = "libc++";
544 | CLANG_ENABLE_MODULES = YES;
545 | CLANG_ENABLE_OBJC_ARC = YES;
546 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
547 | CLANG_WARN_BOOL_CONVERSION = YES;
548 | CLANG_WARN_COMMA = YES;
549 | CLANG_WARN_CONSTANT_CONVERSION = YES;
550 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
551 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
552 | CLANG_WARN_EMPTY_BODY = YES;
553 | CLANG_WARN_ENUM_CONVERSION = YES;
554 | CLANG_WARN_INFINITE_RECURSION = YES;
555 | CLANG_WARN_INT_CONVERSION = YES;
556 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
557 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
558 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
559 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
560 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
561 | CLANG_WARN_STRICT_PROTOTYPES = YES;
562 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
563 | CLANG_WARN_UNREACHABLE_CODE = YES;
564 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
565 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
566 | COPY_PHASE_STRIP = NO;
567 | DEBUG_INFORMATION_FORMAT = dwarf;
568 | ENABLE_STRICT_OBJC_MSGSEND = YES;
569 | ENABLE_TESTABILITY = YES;
570 | GCC_C_LANGUAGE_STANDARD = gnu99;
571 | GCC_DYNAMIC_NO_PIC = NO;
572 | GCC_NO_COMMON_BLOCKS = YES;
573 | GCC_OPTIMIZATION_LEVEL = 0;
574 | GCC_PREPROCESSOR_DEFINITIONS = (
575 | "DEBUG=1",
576 | "$(inherited)",
577 | );
578 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
579 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
580 | GCC_WARN_UNDECLARED_SELECTOR = YES;
581 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
582 | GCC_WARN_UNUSED_FUNCTION = YES;
583 | GCC_WARN_UNUSED_VARIABLE = YES;
584 | IPHONEOS_DEPLOYMENT_TARGET = 12.0;
585 | MTL_ENABLE_DEBUG_INFO = YES;
586 | ONLY_ACTIVE_ARCH = YES;
587 | SDKROOT = iphoneos;
588 | TARGETED_DEVICE_FAMILY = "1,2";
589 | };
590 | name = Debug;
591 | };
592 | 97C147041CF9000F007C117D /* Release */ = {
593 | isa = XCBuildConfiguration;
594 | buildSettings = {
595 | ALWAYS_SEARCH_USER_PATHS = NO;
596 | CLANG_ANALYZER_NONNULL = YES;
597 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
598 | CLANG_CXX_LIBRARY = "libc++";
599 | CLANG_ENABLE_MODULES = YES;
600 | CLANG_ENABLE_OBJC_ARC = YES;
601 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
602 | CLANG_WARN_BOOL_CONVERSION = YES;
603 | CLANG_WARN_COMMA = YES;
604 | CLANG_WARN_CONSTANT_CONVERSION = YES;
605 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
606 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
607 | CLANG_WARN_EMPTY_BODY = YES;
608 | CLANG_WARN_ENUM_CONVERSION = YES;
609 | CLANG_WARN_INFINITE_RECURSION = YES;
610 | CLANG_WARN_INT_CONVERSION = YES;
611 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
612 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
613 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
614 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
615 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
616 | CLANG_WARN_STRICT_PROTOTYPES = YES;
617 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
618 | CLANG_WARN_UNREACHABLE_CODE = YES;
619 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
620 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
621 | COPY_PHASE_STRIP = NO;
622 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
623 | ENABLE_NS_ASSERTIONS = NO;
624 | ENABLE_STRICT_OBJC_MSGSEND = YES;
625 | GCC_C_LANGUAGE_STANDARD = gnu99;
626 | GCC_NO_COMMON_BLOCKS = YES;
627 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
628 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
629 | GCC_WARN_UNDECLARED_SELECTOR = YES;
630 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
631 | GCC_WARN_UNUSED_FUNCTION = YES;
632 | GCC_WARN_UNUSED_VARIABLE = YES;
633 | IPHONEOS_DEPLOYMENT_TARGET = 12.0;
634 | MTL_ENABLE_DEBUG_INFO = NO;
635 | SDKROOT = iphoneos;
636 | SUPPORTED_PLATFORMS = iphoneos;
637 | SWIFT_COMPILATION_MODE = wholemodule;
638 | SWIFT_OPTIMIZATION_LEVEL = "-O";
639 | TARGETED_DEVICE_FAMILY = "1,2";
640 | VALIDATE_PRODUCT = YES;
641 | };
642 | name = Release;
643 | };
644 | 97C147061CF9000F007C117D /* Debug */ = {
645 | isa = XCBuildConfiguration;
646 | baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */;
647 | buildSettings = {
648 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
649 | CLANG_ENABLE_MODULES = YES;
650 | CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
651 | DEVELOPMENT_TEAM = 3563963V57;
652 | ENABLE_BITCODE = NO;
653 | INFOPLIST_FILE = Runner/Info.plist;
654 | LD_RUNPATH_SEARCH_PATHS = (
655 | "$(inherited)",
656 | "@executable_path/Frameworks",
657 | );
658 | PRODUCT_BUNDLE_IDENTIFIER = com.example.flutterPopupExample;
659 | PRODUCT_NAME = "$(TARGET_NAME)";
660 | SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
661 | SWIFT_OPTIMIZATION_LEVEL = "-Onone";
662 | SWIFT_VERSION = 5.0;
663 | VERSIONING_SYSTEM = "apple-generic";
664 | };
665 | name = Debug;
666 | };
667 | 97C147071CF9000F007C117D /* Release */ = {
668 | isa = XCBuildConfiguration;
669 | baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
670 | buildSettings = {
671 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
672 | CLANG_ENABLE_MODULES = YES;
673 | CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
674 | DEVELOPMENT_TEAM = 3563963V57;
675 | ENABLE_BITCODE = NO;
676 | INFOPLIST_FILE = Runner/Info.plist;
677 | LD_RUNPATH_SEARCH_PATHS = (
678 | "$(inherited)",
679 | "@executable_path/Frameworks",
680 | );
681 | PRODUCT_BUNDLE_IDENTIFIER = com.example.flutterPopupExample;
682 | PRODUCT_NAME = "$(TARGET_NAME)";
683 | SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
684 | SWIFT_VERSION = 5.0;
685 | VERSIONING_SYSTEM = "apple-generic";
686 | };
687 | name = Release;
688 | };
689 | /* End XCBuildConfiguration section */
690 |
691 | /* Begin XCConfigurationList section */
692 | 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */ = {
693 | isa = XCConfigurationList;
694 | buildConfigurations = (
695 | 331C8088294A63A400263BE5 /* Debug */,
696 | 331C8089294A63A400263BE5 /* Release */,
697 | 331C808A294A63A400263BE5 /* Profile */,
698 | );
699 | defaultConfigurationIsVisible = 0;
700 | defaultConfigurationName = Release;
701 | };
702 | 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */ = {
703 | isa = XCConfigurationList;
704 | buildConfigurations = (
705 | 97C147031CF9000F007C117D /* Debug */,
706 | 97C147041CF9000F007C117D /* Release */,
707 | 249021D3217E4FDB00AE95B9 /* Profile */,
708 | );
709 | defaultConfigurationIsVisible = 0;
710 | defaultConfigurationName = Release;
711 | };
712 | 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */ = {
713 | isa = XCConfigurationList;
714 | buildConfigurations = (
715 | 97C147061CF9000F007C117D /* Debug */,
716 | 97C147071CF9000F007C117D /* Release */,
717 | 249021D4217E4FDB00AE95B9 /* Profile */,
718 | );
719 | defaultConfigurationIsVisible = 0;
720 | defaultConfigurationName = Release;
721 | };
722 | /* End XCConfigurationList section */
723 | };
724 | rootObject = 97C146E61CF9000F007C117D /* Project object */;
725 | }
726 |
--------------------------------------------------------------------------------
/example/ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata:
--------------------------------------------------------------------------------
1 |
2 |
4 |
6 |
7 |
8 |
--------------------------------------------------------------------------------
/example/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | IDEDidComputeMac32BitWarning
6 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/example/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | PreviewsEnabled
6 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme:
--------------------------------------------------------------------------------
1 |
2 |
5 |
8 |
9 |
15 |
21 |
22 |
23 |
24 |
25 |
30 |
31 |
37 |
38 |
39 |
40 |
43 |
49 |
50 |
51 |
52 |
53 |
63 |
65 |
71 |
72 |
73 |
74 |
80 |
82 |
88 |
89 |
90 |
91 |
93 |
94 |
97 |
98 |
99 |
--------------------------------------------------------------------------------
/example/ios/Runner.xcworkspace/contents.xcworkspacedata:
--------------------------------------------------------------------------------
1 |
2 |
4 |
6 |
7 |
9 |
10 |
11 |
--------------------------------------------------------------------------------
/example/ios/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | IDEDidComputeMac32BitWarning
6 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/example/ios/Runner.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | PreviewsEnabled
6 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/example/ios/Runner/AppDelegate.swift:
--------------------------------------------------------------------------------
1 | import UIKit
2 | import Flutter
3 |
4 | @main
5 | @objc class AppDelegate: FlutterAppDelegate {
6 | override func application(
7 | _ application: UIApplication,
8 | didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
9 | ) -> Bool {
10 | GeneratedPluginRegistrant.register(with: self)
11 | return super.application(application, didFinishLaunchingWithOptions: launchOptions)
12 | }
13 | }
14 |
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json:
--------------------------------------------------------------------------------
1 | {
2 | "images" : [
3 | {
4 | "size" : "20x20",
5 | "idiom" : "iphone",
6 | "filename" : "Icon-App-20x20@2x.png",
7 | "scale" : "2x"
8 | },
9 | {
10 | "size" : "20x20",
11 | "idiom" : "iphone",
12 | "filename" : "Icon-App-20x20@3x.png",
13 | "scale" : "3x"
14 | },
15 | {
16 | "size" : "29x29",
17 | "idiom" : "iphone",
18 | "filename" : "Icon-App-29x29@1x.png",
19 | "scale" : "1x"
20 | },
21 | {
22 | "size" : "29x29",
23 | "idiom" : "iphone",
24 | "filename" : "Icon-App-29x29@2x.png",
25 | "scale" : "2x"
26 | },
27 | {
28 | "size" : "29x29",
29 | "idiom" : "iphone",
30 | "filename" : "Icon-App-29x29@3x.png",
31 | "scale" : "3x"
32 | },
33 | {
34 | "size" : "40x40",
35 | "idiom" : "iphone",
36 | "filename" : "Icon-App-40x40@2x.png",
37 | "scale" : "2x"
38 | },
39 | {
40 | "size" : "40x40",
41 | "idiom" : "iphone",
42 | "filename" : "Icon-App-40x40@3x.png",
43 | "scale" : "3x"
44 | },
45 | {
46 | "size" : "60x60",
47 | "idiom" : "iphone",
48 | "filename" : "Icon-App-60x60@2x.png",
49 | "scale" : "2x"
50 | },
51 | {
52 | "size" : "60x60",
53 | "idiom" : "iphone",
54 | "filename" : "Icon-App-60x60@3x.png",
55 | "scale" : "3x"
56 | },
57 | {
58 | "size" : "20x20",
59 | "idiom" : "ipad",
60 | "filename" : "Icon-App-20x20@1x.png",
61 | "scale" : "1x"
62 | },
63 | {
64 | "size" : "20x20",
65 | "idiom" : "ipad",
66 | "filename" : "Icon-App-20x20@2x.png",
67 | "scale" : "2x"
68 | },
69 | {
70 | "size" : "29x29",
71 | "idiom" : "ipad",
72 | "filename" : "Icon-App-29x29@1x.png",
73 | "scale" : "1x"
74 | },
75 | {
76 | "size" : "29x29",
77 | "idiom" : "ipad",
78 | "filename" : "Icon-App-29x29@2x.png",
79 | "scale" : "2x"
80 | },
81 | {
82 | "size" : "40x40",
83 | "idiom" : "ipad",
84 | "filename" : "Icon-App-40x40@1x.png",
85 | "scale" : "1x"
86 | },
87 | {
88 | "size" : "40x40",
89 | "idiom" : "ipad",
90 | "filename" : "Icon-App-40x40@2x.png",
91 | "scale" : "2x"
92 | },
93 | {
94 | "size" : "76x76",
95 | "idiom" : "ipad",
96 | "filename" : "Icon-App-76x76@1x.png",
97 | "scale" : "1x"
98 | },
99 | {
100 | "size" : "76x76",
101 | "idiom" : "ipad",
102 | "filename" : "Icon-App-76x76@2x.png",
103 | "scale" : "2x"
104 | },
105 | {
106 | "size" : "83.5x83.5",
107 | "idiom" : "ipad",
108 | "filename" : "Icon-App-83.5x83.5@2x.png",
109 | "scale" : "2x"
110 | },
111 | {
112 | "size" : "1024x1024",
113 | "idiom" : "ios-marketing",
114 | "filename" : "Icon-App-1024x1024@1x.png",
115 | "scale" : "1x"
116 | }
117 | ],
118 | "info" : {
119 | "version" : 1,
120 | "author" : "xcode"
121 | }
122 | }
123 |
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json:
--------------------------------------------------------------------------------
1 | {
2 | "images" : [
3 | {
4 | "idiom" : "universal",
5 | "filename" : "LaunchImage.png",
6 | "scale" : "1x"
7 | },
8 | {
9 | "idiom" : "universal",
10 | "filename" : "LaunchImage@2x.png",
11 | "scale" : "2x"
12 | },
13 | {
14 | "idiom" : "universal",
15 | "filename" : "LaunchImage@3x.png",
16 | "scale" : "3x"
17 | }
18 | ],
19 | "info" : {
20 | "version" : 1,
21 | "author" : "xcode"
22 | }
23 | }
24 |
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png
--------------------------------------------------------------------------------
/example/ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md:
--------------------------------------------------------------------------------
1 | # Launch Screen Assets
2 |
3 | You can customize the launch screen with your own desired assets by replacing the image files in this directory.
4 |
5 | You can also do it by opening your Flutter project's Xcode project with `open ios/Runner.xcworkspace`, selecting `Runner/Assets.xcassets` in the Project Navigator and dropping in the desired images.
--------------------------------------------------------------------------------
/example/ios/Runner/Base.lproj/LaunchScreen.storyboard:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 |
37 |
38 |
--------------------------------------------------------------------------------
/example/ios/Runner/Base.lproj/Main.storyboard:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
--------------------------------------------------------------------------------
/example/ios/Runner/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | $(DEVELOPMENT_LANGUAGE)
7 | CFBundleDisplayName
8 | Flutter Popup
9 | CFBundleExecutable
10 | $(EXECUTABLE_NAME)
11 | CFBundleIdentifier
12 | $(PRODUCT_BUNDLE_IDENTIFIER)
13 | CFBundleInfoDictionaryVersion
14 | 6.0
15 | CFBundleName
16 | flutter_popup_example
17 | CFBundlePackageType
18 | APPL
19 | CFBundleShortVersionString
20 | $(FLUTTER_BUILD_NAME)
21 | CFBundleSignature
22 | ????
23 | CFBundleVersion
24 | $(FLUTTER_BUILD_NUMBER)
25 | LSRequiresIPhoneOS
26 |
27 | UILaunchStoryboardName
28 | LaunchScreen
29 | UIMainStoryboardFile
30 | Main
31 | UISupportedInterfaceOrientations
32 |
33 | UIInterfaceOrientationPortrait
34 | UIInterfaceOrientationLandscapeLeft
35 | UIInterfaceOrientationLandscapeRight
36 |
37 | UISupportedInterfaceOrientations~ipad
38 |
39 | UIInterfaceOrientationPortrait
40 | UIInterfaceOrientationPortraitUpsideDown
41 | UIInterfaceOrientationLandscapeLeft
42 | UIInterfaceOrientationLandscapeRight
43 |
44 | CADisableMinimumFrameDurationOnPhone
45 |
46 | UIApplicationSupportsIndirectInputEvents
47 |
48 |
49 |
50 |
--------------------------------------------------------------------------------
/example/ios/Runner/Runner-Bridging-Header.h:
--------------------------------------------------------------------------------
1 | #import "GeneratedPluginRegistrant.h"
2 |
--------------------------------------------------------------------------------
/example/ios/RunnerTests/RunnerTests.swift:
--------------------------------------------------------------------------------
1 | import Flutter
2 | import UIKit
3 | import XCTest
4 |
5 | @testable import flutter_popup
6 |
7 | // This demonstrates a simple unit test of the Swift portion of this plugin's implementation.
8 | //
9 | // See https://developer.apple.com/documentation/xctest for more information about using XCTest.
10 |
11 | class RunnerTests: XCTestCase {
12 |
13 | func testGetPlatformVersion() {
14 | let plugin = FlutterPopupPlugin()
15 |
16 | let call = FlutterMethodCall(methodName: "getPlatformVersion", arguments: [])
17 |
18 | let resultExpectation = expectation(description: "result block must be called.")
19 | plugin.handle(call) { result in
20 | XCTAssertEqual(result as! String, "iOS " + UIDevice.current.systemVersion)
21 | resultExpectation.fulfill()
22 | }
23 | waitForExpectations(timeout: 1)
24 | }
25 |
26 | }
27 |
--------------------------------------------------------------------------------
/example/lib/main.dart:
--------------------------------------------------------------------------------
1 | import 'package:flutter/material.dart';
2 | import 'package:flutter_popup/flutter_popup.dart';
3 |
4 | void main() => runApp(const MyApp());
5 |
6 | class MyApp extends StatelessWidget {
7 | const MyApp({super.key});
8 |
9 | @override
10 | Widget build(BuildContext context) {
11 | return MaterialApp(
12 | theme: ThemeData(
13 | colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
14 | useMaterial3: true,
15 | ),
16 | home: const MyHomePage(),
17 | );
18 | }
19 | }
20 |
21 | class MyHomePage extends StatefulWidget {
22 | const MyHomePage({super.key});
23 |
24 | @override
25 | State createState() => _MyHomePageState();
26 | }
27 |
28 | class _MyHomePageState extends State {
29 | @override
30 | Widget build(BuildContext context) {
31 | return Material(
32 | child: Scaffold(
33 | backgroundColor: Color(0xFFFAFAFA),
34 | appBar: AppBar(
35 | title: const Text('example'),
36 | actions: [
37 | // example0 menu
38 | Padding(
39 | padding: const EdgeInsets.only(right: 30),
40 | child: CustomPopup(
41 | content: Column(
42 | mainAxisSize: MainAxisSize.min,
43 | children: List.generate(5, (index) => Text('menu$index')),
44 | ),
45 | child: const Icon(Icons.add_circle_outline),
46 | ),
47 | ),
48 | ],
49 | ),
50 | body: Column(
51 | children: [
52 | // example1 text
53 | CustomPopup(
54 | barrierColor: Colors.green.withOpacity(0.1),
55 | backgroundColor: Colors.white,
56 | content: Text('George says everything looks fine'),
57 | child: Icon(Icons.help, color: Colors.grey),
58 | ),
59 | SizedBox(height: 20),
60 |
61 | // example2 slider
62 | CustomPopup(
63 | arrowColor: Colors.orange,
64 | content: _Slider(),
65 | position: PopupPosition.top,
66 | child: Container(
67 | padding: const EdgeInsets.all(10),
68 | color: Colors.primaries[10],
69 | child: Text('slider'),
70 | ),
71 | ),
72 | SizedBox(height: 20),
73 |
74 | // example3 calendar
75 | CustomPopup(
76 | showArrow: false,
77 | position: PopupPosition.top,
78 | content: SizedBox(
79 | width: 300,
80 | child: CalendarDatePicker(
81 | initialDate: DateTime.now(),
82 | firstDate: DateTime.now(),
83 | lastDate: DateTime.now(),
84 | onDateChanged: (v) {},
85 | ),
86 | ),
87 | child: Container(
88 | padding: const EdgeInsets.all(10),
89 | color: Colors.primaries[10],
90 | child: Text('calendar'),
91 | ),
92 | ),
93 |
94 | SizedBox(height: 20),
95 |
96 | // example4 filter
97 | Container(
98 | decoration: BoxDecoration(color: Colors.white),
99 | padding: EdgeInsets.symmetric(vertical: 10),
100 | child: Row(
101 | mainAxisAlignment: MainAxisAlignment.spaceAround,
102 | children: [
103 | CustomPopup(
104 | showArrow: false,
105 | contentPadding:
106 | EdgeInsets.symmetric(horizontal: 30, vertical: 10),
107 | barrierColor: Colors.transparent,
108 | contentDecoration: BoxDecoration(
109 | color: Colors.white,
110 | ),
111 | content: SizedBox(
112 | width: double.infinity,
113 | child: Column(
114 | mainAxisSize: MainAxisSize.min,
115 | crossAxisAlignment: CrossAxisAlignment.start,
116 | children: List.generate(
117 | 4,
118 | (index) => Text('item$index'),
119 | ),
120 | ),
121 | ),
122 | child: Text('filter1'),
123 | ),
124 | Text('filter2'),
125 | Text('filter3'),
126 | ],
127 | ),
128 | ),
129 | SizedBox(height: 20),
130 | Text('data' * 100, maxLines: 20),
131 | TextField()
132 | ],
133 | ),
134 | ),
135 | );
136 | }
137 | }
138 |
139 | class _Slider extends StatefulWidget {
140 | const _Slider();
141 |
142 | @override
143 | State<_Slider> createState() => __SliderState();
144 | }
145 |
146 | class __SliderState extends State<_Slider> {
147 | double progress = 0.5;
148 |
149 | @override
150 | Widget build(BuildContext context) {
151 | return SizedBox(
152 | width: 300,
153 | height: 100,
154 | child: Slider(
155 | value: progress,
156 | onChanged: (value) {
157 | setState(() => progress = value);
158 | },
159 | ),
160 | );
161 | }
162 | }
163 |
--------------------------------------------------------------------------------
/example/pubspec.lock:
--------------------------------------------------------------------------------
1 | # Generated by pub
2 | # See https://dart.dev/tools/pub/glossary#lockfile
3 | packages:
4 | async:
5 | dependency: transitive
6 | description:
7 | name: async
8 | sha256: "947bfcf187f74dbc5e146c9eb9c0f10c9f8b30743e341481c1e2ed3ecc18c20c"
9 | url: "https://pub.dev"
10 | source: hosted
11 | version: "2.11.0"
12 | boolean_selector:
13 | dependency: transitive
14 | description:
15 | name: boolean_selector
16 | sha256: "6cfb5af12253eaf2b368f07bacc5a80d1301a071c73360d746b7f2e32d762c66"
17 | url: "https://pub.dev"
18 | source: hosted
19 | version: "2.1.1"
20 | characters:
21 | dependency: transitive
22 | description:
23 | name: characters
24 | sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605"
25 | url: "https://pub.dev"
26 | source: hosted
27 | version: "1.3.0"
28 | clock:
29 | dependency: transitive
30 | description:
31 | name: clock
32 | sha256: cb6d7f03e1de671e34607e909a7213e31d7752be4fb66a86d29fe1eb14bfb5cf
33 | url: "https://pub.dev"
34 | source: hosted
35 | version: "1.1.1"
36 | collection:
37 | dependency: transitive
38 | description:
39 | name: collection
40 | sha256: f092b211a4319e98e5ff58223576de6c2803db36221657b46c82574721240687
41 | url: "https://pub.dev"
42 | source: hosted
43 | version: "1.17.2"
44 | fake_async:
45 | dependency: transitive
46 | description:
47 | name: fake_async
48 | sha256: "511392330127add0b769b75a987850d136345d9227c6b94c96a04cf4a391bf78"
49 | url: "https://pub.dev"
50 | source: hosted
51 | version: "1.3.1"
52 | file:
53 | dependency: transitive
54 | description:
55 | name: file
56 | sha256: "1b92bec4fc2a72f59a8e15af5f52cd441e4a7860b49499d69dfa817af20e925d"
57 | url: "https://pub.dev"
58 | source: hosted
59 | version: "6.1.4"
60 | flutter:
61 | dependency: "direct main"
62 | description: flutter
63 | source: sdk
64 | version: "0.0.0"
65 | flutter_driver:
66 | dependency: transitive
67 | description: flutter
68 | source: sdk
69 | version: "0.0.0"
70 | flutter_popup:
71 | dependency: "direct main"
72 | description:
73 | path: ".."
74 | relative: true
75 | source: path
76 | version: "3.3.4"
77 | flutter_test:
78 | dependency: "direct dev"
79 | description: flutter
80 | source: sdk
81 | version: "0.0.0"
82 | fuchsia_remote_debug_protocol:
83 | dependency: transitive
84 | description: flutter
85 | source: sdk
86 | version: "0.0.0"
87 | integration_test:
88 | dependency: "direct dev"
89 | description: flutter
90 | source: sdk
91 | version: "0.0.0"
92 | matcher:
93 | dependency: transitive
94 | description:
95 | name: matcher
96 | sha256: "1803e76e6653768d64ed8ff2e1e67bea3ad4b923eb5c56a295c3e634bad5960e"
97 | url: "https://pub.dev"
98 | source: hosted
99 | version: "0.12.16"
100 | material_color_utilities:
101 | dependency: transitive
102 | description:
103 | name: material_color_utilities
104 | sha256: "9528f2f296073ff54cb9fee677df673ace1218163c3bc7628093e7eed5203d41"
105 | url: "https://pub.dev"
106 | source: hosted
107 | version: "0.5.0"
108 | meta:
109 | dependency: transitive
110 | description:
111 | name: meta
112 | sha256: "3c74dbf8763d36539f114c799d8a2d87343b5067e9d796ca22b5eb8437090ee3"
113 | url: "https://pub.dev"
114 | source: hosted
115 | version: "1.9.1"
116 | path:
117 | dependency: transitive
118 | description:
119 | name: path
120 | sha256: "8829d8a55c13fc0e37127c29fedf290c102f4e40ae94ada574091fe0ff96c917"
121 | url: "https://pub.dev"
122 | source: hosted
123 | version: "1.8.3"
124 | platform:
125 | dependency: transitive
126 | description:
127 | name: platform
128 | sha256: "4a451831508d7d6ca779f7ac6e212b4023dd5a7d08a27a63da33756410e32b76"
129 | url: "https://pub.dev"
130 | source: hosted
131 | version: "3.1.0"
132 | process:
133 | dependency: transitive
134 | description:
135 | name: process
136 | sha256: "53fd8db9cec1d37b0574e12f07520d582019cb6c44abf5479a01505099a34a09"
137 | url: "https://pub.dev"
138 | source: hosted
139 | version: "4.2.4"
140 | sky_engine:
141 | dependency: transitive
142 | description: flutter
143 | source: sdk
144 | version: "0.0.99"
145 | source_span:
146 | dependency: transitive
147 | description:
148 | name: source_span
149 | sha256: "53e943d4206a5e30df338fd4c6e7a077e02254531b138a15aec3bd143c1a8b3c"
150 | url: "https://pub.dev"
151 | source: hosted
152 | version: "1.10.0"
153 | stack_trace:
154 | dependency: transitive
155 | description:
156 | name: stack_trace
157 | sha256: c3c7d8edb15bee7f0f74debd4b9c5f3c2ea86766fe4178eb2a18eb30a0bdaed5
158 | url: "https://pub.dev"
159 | source: hosted
160 | version: "1.11.0"
161 | stream_channel:
162 | dependency: transitive
163 | description:
164 | name: stream_channel
165 | sha256: "83615bee9045c1d322bbbd1ba209b7a749c2cbcdcb3fdd1df8eb488b3279c1c8"
166 | url: "https://pub.dev"
167 | source: hosted
168 | version: "2.1.1"
169 | string_scanner:
170 | dependency: transitive
171 | description:
172 | name: string_scanner
173 | sha256: "556692adab6cfa87322a115640c11f13cb77b3f076ddcc5d6ae3c20242bedcde"
174 | url: "https://pub.dev"
175 | source: hosted
176 | version: "1.2.0"
177 | sync_http:
178 | dependency: transitive
179 | description:
180 | name: sync_http
181 | sha256: "7f0cd72eca000d2e026bcd6f990b81d0ca06022ef4e32fb257b30d3d1014a961"
182 | url: "https://pub.dev"
183 | source: hosted
184 | version: "0.3.1"
185 | term_glyph:
186 | dependency: transitive
187 | description:
188 | name: term_glyph
189 | sha256: a29248a84fbb7c79282b40b8c72a1209db169a2e0542bce341da992fe1bc7e84
190 | url: "https://pub.dev"
191 | source: hosted
192 | version: "1.2.1"
193 | test_api:
194 | dependency: transitive
195 | description:
196 | name: test_api
197 | sha256: "75760ffd7786fffdfb9597c35c5b27eaeec82be8edfb6d71d32651128ed7aab8"
198 | url: "https://pub.dev"
199 | source: hosted
200 | version: "0.6.0"
201 | vector_math:
202 | dependency: transitive
203 | description:
204 | name: vector_math
205 | sha256: "80b3257d1492ce4d091729e3a67a60407d227c27241d6927be0130c98e741803"
206 | url: "https://pub.dev"
207 | source: hosted
208 | version: "2.1.4"
209 | vm_service:
210 | dependency: transitive
211 | description:
212 | name: vm_service
213 | sha256: c620a6f783fa22436da68e42db7ebbf18b8c44b9a46ab911f666ff09ffd9153f
214 | url: "https://pub.dev"
215 | source: hosted
216 | version: "11.7.1"
217 | web:
218 | dependency: transitive
219 | description:
220 | name: web
221 | sha256: dc8ccd225a2005c1be616fe02951e2e342092edf968cf0844220383757ef8f10
222 | url: "https://pub.dev"
223 | source: hosted
224 | version: "0.1.4-beta"
225 | webdriver:
226 | dependency: transitive
227 | description:
228 | name: webdriver
229 | sha256: "3c923e918918feeb90c4c9fdf1fe39220fa4c0e8e2c0fffaded174498ef86c49"
230 | url: "https://pub.dev"
231 | source: hosted
232 | version: "3.0.2"
233 | sdks:
234 | dart: ">=3.1.0-185.0.dev <4.0.0"
235 |
--------------------------------------------------------------------------------
/example/pubspec.yaml:
--------------------------------------------------------------------------------
1 | name: example
2 | description: Demonstrates how to use the flutter_popup plugin.
3 | publish_to: 'none'
4 |
5 | environment:
6 | sdk: '>=2.17.0 <4.0.0'
7 |
8 | dependencies:
9 | flutter:
10 | sdk: flutter
11 | flutter_popup:
12 | path: ../
13 |
14 | dev_dependencies:
15 | integration_test:
16 | sdk: flutter
17 | flutter_test:
18 | sdk: flutter
19 |
20 | flutter:
21 | uses-material-design: true
22 |
--------------------------------------------------------------------------------
/ios/.gitignore:
--------------------------------------------------------------------------------
1 | .idea/
2 | .vagrant/
3 | .sconsign.dblite
4 | .svn/
5 |
6 | .DS_Store
7 | *.swp
8 | profile
9 |
10 | DerivedData/
11 | build/
12 | GeneratedPluginRegistrant.h
13 | GeneratedPluginRegistrant.m
14 |
15 | .generated/
16 |
17 | *.pbxuser
18 | *.mode1v3
19 | *.mode2v3
20 | *.perspectivev3
21 |
22 | !default.pbxuser
23 | !default.mode1v3
24 | !default.mode2v3
25 | !default.perspectivev3
26 |
27 | xcuserdata
28 |
29 | *.moved-aside
30 |
31 | *.pyc
32 | *sync/
33 | Icon?
34 | .tags*
35 |
36 | /Flutter/Generated.xcconfig
37 | /Flutter/ephemeral/
38 | /Flutter/flutter_export_environment.sh
--------------------------------------------------------------------------------
/ios/Assets/.gitkeep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/herowws/flutter_popup/b98eaf8fe7101d2ccf1d83ec3712c4ee4fc097ec/ios/Assets/.gitkeep
--------------------------------------------------------------------------------
/ios/Classes/FlutterPopupPlugin.swift:
--------------------------------------------------------------------------------
1 | import Flutter
2 | import UIKit
3 |
4 | public class FlutterPopupPlugin: NSObject, FlutterPlugin {
5 | public static func register(with registrar: FlutterPluginRegistrar) {
6 | let channel = FlutterMethodChannel(name: "flutter_popup", binaryMessenger: registrar.messenger())
7 | let instance = FlutterPopupPlugin()
8 | registrar.addMethodCallDelegate(instance, channel: channel)
9 | }
10 |
11 | public func handle(_ call: FlutterMethodCall, result: @escaping FlutterResult) {
12 | switch call.method {
13 | case "getPlatformVersion":
14 | result("iOS " + UIDevice.current.systemVersion)
15 | default:
16 | result(FlutterMethodNotImplemented)
17 | }
18 | }
19 | }
20 |
--------------------------------------------------------------------------------
/ios/flutter_popup.podspec:
--------------------------------------------------------------------------------
1 | #
2 | # To learn more about a Podspec see http://guides.cocoapods.org/syntax/podspec.html.
3 | # Run `pod lib lint flutter_popup.podspec` to validate before publishing.
4 | #
5 | Pod::Spec.new do |s|
6 | s.name = 'flutter_popup'
7 | s.version = '0.0.1'
8 | s.summary = 'A new Flutter project.'
9 | s.description = <<-DESC
10 | A new Flutter project.
11 | DESC
12 | s.homepage = 'http://example.com'
13 | s.license = { :file => '../LICENSE' }
14 | s.author = { 'Your Company' => 'email@example.com' }
15 | s.source = { :path => '.' }
16 | s.source_files = 'Classes/**/*'
17 | s.dependency 'Flutter'
18 | s.platform = :ios, '11.0'
19 |
20 | # Flutter.framework does not contain a i386 slice.
21 | s.pod_target_xcconfig = { 'DEFINES_MODULE' => 'YES', 'EXCLUDED_ARCHS[sdk=iphonesimulator*]' => 'i386' }
22 | s.swift_version = '5.0'
23 | end
24 |
--------------------------------------------------------------------------------
/lib/flutter_popup.dart:
--------------------------------------------------------------------------------
1 | library flutter_popup;
2 |
3 | import 'dart:math';
4 | import 'dart:ui';
5 |
6 | import 'package:flutter/material.dart';
7 | import 'package:flutter/scheduler.dart';
8 |
9 | part 'src/popup.dart';
10 | part 'src/screen.dart';
11 |
--------------------------------------------------------------------------------
/lib/src/popup.dart:
--------------------------------------------------------------------------------
1 | part of flutter_popup;
2 |
3 | enum _ArrowDirection { top, bottom }
4 |
5 | enum PopupPosition { auto, top, bottom }
6 |
7 | class CustomPopup extends StatelessWidget {
8 | final GlobalKey? anchorKey;
9 | final Widget content;
10 | final Widget child;
11 | final bool isLongPress;
12 | final Color? backgroundColor;
13 | final Color? arrowColor;
14 | final Color? barrierColor;
15 | final bool showArrow;
16 | final EdgeInsets contentPadding;
17 | final double? contentRadius;
18 | final BoxDecoration? contentDecoration;
19 | final VoidCallback? onBeforePopup;
20 | final VoidCallback? onAfterPopup;
21 | final bool rootNavigator;
22 | final PopupPosition position;
23 |
24 | const CustomPopup({
25 | super.key,
26 | required this.content,
27 | required this.child,
28 | this.anchorKey,
29 | this.isLongPress = false,
30 | this.backgroundColor,
31 | this.arrowColor,
32 | this.showArrow = true,
33 | this.barrierColor,
34 | this.contentPadding = const EdgeInsets.all(8),
35 | this.contentRadius,
36 | this.contentDecoration,
37 | this.onBeforePopup,
38 | this.onAfterPopup,
39 | this.rootNavigator = false,
40 | this.position = PopupPosition.auto,
41 | });
42 |
43 | void _show(BuildContext context) {
44 | final anchor = anchorKey?.currentContext ?? context;
45 | final renderBox = anchor.findRenderObject() as RenderBox?;
46 | if (renderBox == null) return;
47 | final offset = renderBox.localToGlobal(renderBox.paintBounds.topLeft);
48 |
49 | onBeforePopup?.call();
50 |
51 | Navigator.of(context, rootNavigator: rootNavigator)
52 | .push(
53 | _PopupRoute(
54 | targetRect: offset & renderBox.paintBounds.size,
55 | backgroundColor: backgroundColor,
56 | arrowColor: arrowColor,
57 | showArrow: showArrow,
58 | barriersColor: barrierColor,
59 | contentPadding: contentPadding,
60 | contentRadius: contentRadius,
61 | contentDecoration: contentDecoration,
62 | position: position,
63 | child: content,
64 | ),
65 | )
66 | .then((value) => onAfterPopup?.call());
67 | }
68 |
69 | @override
70 | Widget build(BuildContext context) {
71 | return GestureDetector(
72 | behavior: HitTestBehavior.translucent,
73 | onLongPress: isLongPress ? () => _show(context) : null,
74 | onTapUp: !isLongPress ? (_) => _show(context) : null,
75 | child: child,
76 | );
77 | }
78 | }
79 |
80 | class _PopupContent extends StatelessWidget {
81 | final Widget child;
82 | final GlobalKey childKey;
83 | final GlobalKey arrowKey;
84 | final _ArrowDirection arrowDirection;
85 | final double arrowHorizontal;
86 | final Color? backgroundColor;
87 | final Color? arrowColor;
88 | final bool showArrow;
89 | final EdgeInsets contentPadding;
90 | final double? contentRadius;
91 | final BoxDecoration? contentDecoration;
92 |
93 | const _PopupContent({
94 | Key? key,
95 | required this.child,
96 | required this.childKey,
97 | required this.arrowKey,
98 | required this.arrowHorizontal,
99 | required this.showArrow,
100 | this.arrowDirection = _ArrowDirection.top,
101 | this.backgroundColor,
102 | this.arrowColor,
103 | this.contentRadius,
104 | required this.contentPadding,
105 | this.contentDecoration,
106 | }) : super(key: key);
107 |
108 | @override
109 | Widget build(BuildContext context) {
110 | return Stack(
111 | children: [
112 | Container(
113 | key: childKey,
114 | padding: contentPadding,
115 | margin: const EdgeInsets.symmetric(vertical: 10).copyWith(
116 | top: arrowDirection == _ArrowDirection.bottom ? 0 : null,
117 | bottom: arrowDirection == _ArrowDirection.top ? 0 : null,
118 | ),
119 | constraints: const BoxConstraints(minWidth: 50),
120 | decoration: contentDecoration ??
121 | BoxDecoration(
122 | color: backgroundColor ?? Colors.white,
123 | borderRadius: BorderRadius.circular(contentRadius ?? 10),
124 | boxShadow: [
125 | BoxShadow(
126 | color: Colors.black.withOpacity(0.1),
127 | blurRadius: 10,
128 | ),
129 | ],
130 | ),
131 | child: child,
132 | ),
133 | Positioned(
134 | top: arrowDirection == _ArrowDirection.top ? 2 : null,
135 | bottom: arrowDirection == _ArrowDirection.bottom ? 2 : null,
136 | left: arrowHorizontal,
137 | child: RotatedBox(
138 | key: arrowKey,
139 | quarterTurns: arrowDirection == _ArrowDirection.top ? 2 : 4,
140 | child: CustomPaint(
141 | size: showArrow ? const Size(16, 8) : Size.zero,
142 | painter: _TrianglePainter(color: arrowColor ?? Colors.white),
143 | ),
144 | ),
145 | ),
146 | ],
147 | );
148 | }
149 | }
150 |
151 | class _TrianglePainter extends CustomPainter {
152 | final Color color;
153 |
154 | const _TrianglePainter({required this.color});
155 |
156 | @override
157 | void paint(Canvas canvas, Size size) {
158 | final paint = Paint();
159 | final path = Path();
160 | paint.isAntiAlias = true;
161 | paint.color = color;
162 |
163 | path.lineTo(size.width * 0.66, size.height * 0.86);
164 | path.cubicTo(size.width * 0.58, size.height * 1.05, size.width * 0.42,
165 | size.height * 1.05, size.width * 0.34, size.height * 0.86);
166 | path.cubicTo(size.width * 0.34, size.height * 0.86, 0, 0, 0, 0);
167 | path.cubicTo(0, 0, size.width, 0, size.width, 0);
168 | path.cubicTo(size.width, 0, size.width * 0.66, size.height * 0.86,
169 | size.width * 0.66, size.height * 0.86);
170 | path.cubicTo(size.width * 0.66, size.height * 0.86, size.width * 0.66,
171 | size.height * 0.86, size.width * 0.66, size.height * 0.86);
172 | canvas.drawPath(path, paint);
173 | }
174 |
175 | @override
176 | bool shouldRepaint(CustomPainter oldDelegate) {
177 | return true;
178 | }
179 | }
180 |
181 | class _PopupRoute extends PopupRoute {
182 | final Rect targetRect;
183 | final PopupPosition position;
184 | final Widget child;
185 |
186 | static const double _margin = 10;
187 | static final Rect _viewportRect = Rect.fromLTWH(
188 | _margin,
189 | Screen.statusBar + _margin,
190 | Screen.width - _margin * 2,
191 | Screen.height - Screen.statusBar - Screen.bottomBar - _margin * 2,
192 | );
193 |
194 | final GlobalKey _childKey = GlobalKey();
195 | final GlobalKey _arrowKey = GlobalKey();
196 | final Color? backgroundColor;
197 | final Color? arrowColor;
198 | final bool showArrow;
199 | final Color? barriersColor;
200 | final EdgeInsets contentPadding;
201 | final double? contentRadius;
202 | final BoxDecoration? contentDecoration;
203 |
204 | double _maxHeight = _viewportRect.height;
205 | _ArrowDirection _arrowDirection = _ArrowDirection.top;
206 | double _arrowHorizontal = 0;
207 | double _scaleAlignDx = 0.5;
208 | double _scaleAlignDy = 0.5;
209 | double? _bottom;
210 | double? _top;
211 | double? _left;
212 | double? _right;
213 |
214 | _PopupRoute({
215 | RouteSettings? settings,
216 | ImageFilter? filter,
217 | TraversalEdgeBehavior? traversalEdgeBehavior,
218 | required this.child,
219 | required this.targetRect,
220 | this.backgroundColor,
221 | this.arrowColor,
222 | required this.showArrow,
223 | this.barriersColor,
224 | required this.contentPadding,
225 | this.contentRadius,
226 | this.contentDecoration,
227 | this.position = PopupPosition.auto,
228 | }) : super(
229 | settings: settings,
230 | filter: filter,
231 | traversalEdgeBehavior: traversalEdgeBehavior,
232 | );
233 |
234 | @override
235 | Color? get barrierColor => barriersColor ?? Colors.black.withOpacity(0.1);
236 |
237 | @override
238 | bool get barrierDismissible => true;
239 |
240 | @override
241 | String? get barrierLabel => 'Popup';
242 |
243 | @override
244 | TickerFuture didPush() {
245 | super.offstage = true;
246 | SchedulerBinding.instance.addPostFrameCallback((_) {
247 | final childRect = _getRect(_childKey);
248 | final arrowRect = _getRect(_arrowKey);
249 | _calculateArrowOffset(arrowRect, childRect);
250 | _calculateChildOffset(childRect);
251 | super.offstage = false;
252 | });
253 | return super.didPush();
254 | }
255 |
256 | Rect? _getRect(GlobalKey key) {
257 | final currentContext = key.currentContext;
258 | final renderBox = currentContext?.findRenderObject() as RenderBox?;
259 | if (renderBox == null || currentContext == null) return null;
260 | final offset = renderBox.localToGlobal(renderBox.paintBounds.topLeft);
261 | var rect = offset & renderBox.paintBounds.size;
262 |
263 | if (Directionality.of(currentContext) == TextDirection.rtl) {
264 | rect = Rect.fromLTRB(0, rect.top, rect.right - rect.left, rect.bottom);
265 | }
266 |
267 | return rect;
268 | }
269 |
270 | // Calculate the horizontal position of the arrow
271 | void _calculateArrowOffset(Rect? arrowRect, Rect? childRect) {
272 | if (childRect == null || arrowRect == null) return;
273 | // Calculate the distance from the left side of the screen based on the middle position of the target and the popover layer
274 | var leftEdge = targetRect.center.dx - childRect.center.dx;
275 | final rightEdge = leftEdge + childRect.width;
276 | leftEdge = leftEdge < _viewportRect.left ? _viewportRect.left : leftEdge;
277 | // If it exceeds the screen, subtract the excess part
278 | if (rightEdge > _viewportRect.right) {
279 | leftEdge -= rightEdge - _viewportRect.right;
280 | }
281 | final center = targetRect.center.dx - leftEdge - arrowRect.center.dx;
282 | // Prevent the arrow from extending beyond the padding of the popover
283 | if (center + arrowRect.center.dx > childRect.width - 15) {
284 | _arrowHorizontal = center - 15;
285 | } else if (center < 15) {
286 | _arrowHorizontal = 15;
287 | } else {
288 | _arrowHorizontal = center;
289 | }
290 |
291 | _scaleAlignDx = (_arrowHorizontal + arrowRect.center.dx) / childRect.width;
292 | }
293 |
294 | // Calculate the position of the popover
295 | void _calculateChildOffset(Rect? childRect) {
296 | if (childRect == null) return;
297 |
298 | final topHeight = targetRect.top - _viewportRect.top;
299 | final bottomHeight = _viewportRect.bottom - targetRect.bottom;
300 | final maximum = max(topHeight, bottomHeight);
301 | _maxHeight = childRect.height > maximum ? maximum : childRect.height;
302 |
303 | if (position == PopupPosition.top ||
304 | (position == PopupPosition.auto && _maxHeight > bottomHeight)) {
305 | _bottom = Screen.height - targetRect.top;
306 | _arrowDirection = _ArrowDirection.bottom;
307 | _scaleAlignDy = 1;
308 | } else {
309 | _top = targetRect.bottom;
310 | _arrowDirection = _ArrowDirection.top;
311 | _scaleAlignDy = 0;
312 | }
313 |
314 | final left = targetRect.center.dx - childRect.center.dx;
315 | final right = left + childRect.width;
316 | if (right > _viewportRect.right) {
317 | _right = _margin;
318 | } else {
319 | _left = left < _margin ? _margin : left;
320 | }
321 | }
322 |
323 | @override
324 | Widget buildPage(
325 | BuildContext context,
326 | Animation animation,
327 | Animation secondaryAnimation,
328 | ) {
329 | return child;
330 | }
331 |
332 | @override
333 | Widget buildTransitions(
334 | BuildContext context,
335 | Animation animation,
336 | Animation secondaryAnimation,
337 | Widget child,
338 | ) {
339 | child = _PopupContent(
340 | childKey: _childKey,
341 | arrowKey: _arrowKey,
342 | arrowHorizontal: _arrowHorizontal,
343 | arrowDirection: _arrowDirection,
344 | backgroundColor: backgroundColor,
345 | arrowColor: arrowColor,
346 | showArrow: showArrow,
347 | contentPadding: contentPadding,
348 | contentRadius: contentRadius,
349 | contentDecoration: contentDecoration,
350 | child: child,
351 | );
352 | if (!animation.isCompleted) {
353 | child = FadeTransition(
354 | opacity: animation,
355 | child: ScaleTransition(
356 | alignment: FractionalOffset(_scaleAlignDx, _scaleAlignDy),
357 | scale: animation,
358 | child: child,
359 | ),
360 | );
361 | }
362 | return Stack(
363 | children: [
364 | Positioned(
365 | left: _left,
366 | right: _right,
367 | top: _top,
368 | bottom: _bottom,
369 | child: ConstrainedBox(
370 | constraints: BoxConstraints(
371 | maxWidth: _viewportRect.width,
372 | maxHeight: _maxHeight,
373 | ),
374 | child: Material(
375 | color: Colors.transparent,
376 | type: MaterialType.transparency,
377 | child: child,
378 | ),
379 | ),
380 | ),
381 | ],
382 | );
383 | }
384 |
385 | @override
386 | Duration get transitionDuration => const Duration(milliseconds: 150);
387 | }
388 |
--------------------------------------------------------------------------------
/lib/src/screen.dart:
--------------------------------------------------------------------------------
1 | part of flutter_popup;
2 |
3 | abstract class Screen {
4 | static MediaQueryData get mediaQuery => MediaQueryData.fromView(
5 | PlatformDispatcher.instance.views.first,
6 | );
7 |
8 | /// screen width
9 | static double get width => mediaQuery.size.width;
10 |
11 | // /screen height
12 | static double get height => mediaQuery.size.height;
13 |
14 | /// dp
15 | static double get scale => mediaQuery.devicePixelRatio;
16 |
17 | /// top
18 | static double get statusBar => mediaQuery.padding.top;
19 |
20 | /// bottom
21 | static double get bottomBar => mediaQuery.padding.bottom;
22 | }
23 |
--------------------------------------------------------------------------------
/pubspec.yaml:
--------------------------------------------------------------------------------
1 | name: flutter_popup
2 | description: The flutter_popup package is a versatile tool for creating customizable popups in Flutter apps. Its highlight feature effectively guides user attention to specific areas
3 | version: 3.3.7
4 | homepage: https://github.com/herowws/flutter_popup
5 |
6 | environment:
7 | sdk: '>=2.17.0 <4.0.0'
8 |
9 | dependencies:
10 | flutter:
11 | sdk: flutter
12 |
13 | dev_dependencies:
14 | example:
15 | path: example
16 | flutter_lints: ^1.0.0
17 | flutter_test:
18 | sdk: flutter
19 |
20 |
--------------------------------------------------------------------------------