[
  {
    "path": ".gitignore",
    "content": "# Miscellaneous\n*.class\n*.log\n*.pyc\n*.swp\n.DS_Store\n.atom/\n.buildlog/\n.history\n.svn/\n\n# IntelliJ related\n*.iml\n*.ipr\n*.iws\n.idea/\n\n# Visual Studio Code related\n.vscode/\n\n# Flutter/Dart/Pub related\n**/doc/api/\n.dart_tool/\n.flutter-plugins\n.packages\n.pub-cache/\n.pub/\n/build/\n\n# Android related\n**/android/**/gradle-wrapper.jar\n**/android/.gradle\n**/android/captures/\n**/android/gradlew\n**/android/gradlew.bat\n**/android/local.properties\n**/android/**/GeneratedPluginRegistrant.java\n\n# iOS/XCode related\n**/ios/**/*.mode1v3\n**/ios/**/*.mode2v3\n**/ios/**/*.moved-aside\n**/ios/**/*.pbxuser\n**/ios/**/*.perspectivev3\n**/ios/**/*sync/\n**/ios/**/.sconsign.dblite\n**/ios/**/.tags*\n**/ios/**/.vagrant/\n**/ios/**/DerivedData/\n**/ios/**/Icon?\n**/ios/**/Pods/\n**/ios/**/.symlinks/\n**/ios/**/profile\n**/ios/**/xcuserdata\n**/ios/.generated/\n**/ios/Flutter/App.framework\n**/ios/Flutter/Flutter.framework\n**/ios/Flutter/Generated.xcconfig\n**/ios/Flutter/app.flx\n**/ios/Flutter/app.zip\n**/ios/Flutter/flutter_assets/\n**/ios/ServiceDefinitions.json\n**/ios/Runner/GeneratedPluginRegistrant.*\n\n# Exceptions to above rules.\n!**/ios/**/default.mode1v3\n!**/ios/**/default.mode2v3\n!**/ios/**/default.pbxuser\n!**/ios/**/default.perspectivev3\n!/packages/flutter_tools/test/data/dart_dependencies_test/**/.packages\n"
  },
  {
    "path": "README.md",
    "content": "# \n\n# flutter_challenge_googlemaps\n\nUse Flutter💪  to implement the UI challenge of Google Maps on [uplabs](https://www.uplabs.com/posts/google-maps-redesign-919dd0d6-0883-4378-b5b2-f77e36adb6b5) .\n\n[中文版本](README_CN.md)\n\n> Designer : [Joydeep Sengupta](https://www.uplabs.com/joydeeproni)\n>\n> Uplabs : <https://www.uplabs.com/posts/google-maps-redesign-919dd0d6-0883-4378-b5b2-f77e36adb6b5>\n>\n> Developer : [ditclear](https://github.com/ditclear)\n\n#### DownLoad \n\n[demo.apk](apk/app.apk)\n\n#### Introduction\n\n| Branch                                                       | Description                                                  |\n| ------------------------------------------------------------ | ------------------------------------------------------------ |\n| [master](<https://github.com/flutter-ui-challenges/flutter_challenge_googlemaps>) | use `setState` to notify UI update                           |\n| [provide](https://github.com/flutter-ui-challenges/flutter_challenge_googlemaps/tree/provide) | use  [flutter-provide](https://github.com/google/flutter-provide) to notify UI update |\n| [desktop](https://github.com/flutter-ui-challenges/flutter_challenge_googlemaps/tree/desktop) | use [go-flutter](https://github.com/go-flutter-desktop/go-flutter) to implement UI on Desktop |\n\n### Challenge \n\n![](ui/all.png)\n\n\n\n![](ui/attachment.gif)\n\n\n\n![](ui/preview.gif)\n\n\n\n#### 不用客气，buy Me a Lunch ~\n\n[sponsor](https://github.com/flutter-ui-challenges/JoinUs/blob/master/sponsor.md)\n\n### License\n\n```\nCopyright 2019 ditclear\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n```\n\n\n\n\n\n\n\n\n\n\n\n"
  },
  {
    "path": "README_CN.md",
    "content": "# \n\n# flutter_challenge_googlemaps\n\n使用Flutter实现[uplabs](https://www.uplabs.com/posts/google-maps-redesign-919dd0d6-0883-4378-b5b2-f77e36adb6b5)上Google Maps的UI挑战\n\n> 设计师 : [Joydeep Sengupta](https://www.uplabs.com/joydeeproni)\n>\n> Uplabs : <https://www.uplabs.com/posts/google-maps-redesign-919dd0d6-0883-4378-b5b2-f77e36adb6b5>\n>\n> 开发者 : [ditclear](https://github.com/ditclear)\n\n#### 下载体验\n\n[demo.apk](apk/app.apk)\n\n#### 项目介绍 \n\n| 分支                                                         | 描述                                                         |\n| ------------------------------------------------------------ | ------------------------------------------------------------ |\n| [master](<https://github.com/flutter-ui-challenges/flutter_challenge_googlemaps>) | 使用 `setState` 来通知UI更新                                 |\n| [provide](https://github.com/flutter-ui-challenges/flutter_challenge_googlemaps/tree/provide) | 使用  [flutter-provide来通知UI更新                           |\n| [desktop](https://github.com/flutter-ui-challenges/flutter_challenge_googlemaps/tree/desktop) | 使用 [go-flutter](https://github.com/go-flutter-desktop/go-flutter) 来实现桌面端 |\n\n### 效果图\n\n![](ui/all.png)\n\n\n\n![](ui/attachment.gif)\n\n\n\n![](ui/preview.gif)\n\n\n\n#### 不用客气，buy Me a Lunch ~\n\n[赞助开发者](https://github.com/flutter-ui-challenges/JoinUs/blob/master/sponsor.md)\n\n### License\n\n```\nCopyright 2019 ditclear\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n```\n\n\n\n\n\n\n\n\n\n\n\n"
  },
  {
    "path": "android/app/build.gradle",
    "content": "def localProperties = new Properties()\ndef localPropertiesFile = rootProject.file('local.properties')\nif (localPropertiesFile.exists()) {\n    localPropertiesFile.withReader('UTF-8') { reader ->\n        localProperties.load(reader)\n    }\n}\n\ndef flutterRoot = localProperties.getProperty('flutter.sdk')\nif (flutterRoot == null) {\n    throw new GradleException(\"Flutter SDK not found. Define location with flutter.sdk in the local.properties file.\")\n}\n\ndef flutterVersionCode = localProperties.getProperty('flutter.versionCode')\nif (flutterVersionCode == null) {\n    flutterVersionCode = '1'\n}\n\ndef flutterVersionName = localProperties.getProperty('flutter.versionName')\nif (flutterVersionName == null) {\n    flutterVersionName = '1.0'\n}\n\napply plugin: 'com.android.application'\napply plugin: 'kotlin-android'\napply from: \"$flutterRoot/packages/flutter_tools/gradle/flutter.gradle\"\n\nandroid {\n    compileSdkVersion 28\n\n    sourceSets {\n        main.java.srcDirs += 'src/main/kotlin'\n    }\n\n    lintOptions {\n        disable 'InvalidPackage'\n    }\n\n    defaultConfig {\n        // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).\n        applicationId \"io.ditclear.flutter_challenge_googlemaps\"\n        minSdkVersion 16\n        targetSdkVersion 28\n        versionCode flutterVersionCode.toInteger()\n        versionName flutterVersionName\n        testInstrumentationRunner \"android.support.test.runner.AndroidJUnitRunner\"\n    }\n\n    buildTypes {\n        release {\n            // TODO: Add your own signing config for the release build.\n            // Signing with the debug keys for now, so `flutter run --release` works.\n            signingConfig signingConfigs.debug\n        }\n    }\n}\n\nflutter {\n    source '../..'\n}\n\ndependencies {\n    implementation \"org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version\"\n    testImplementation 'junit:junit:4.12'\n    androidTestImplementation 'com.android.support.test:runner:1.0.2'\n    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'\n}\n"
  },
  {
    "path": "android/app/src/debug/AndroidManifest.xml",
    "content": "<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    package=\"io.ditclear.flutter_challenge_googlemaps\">\n    <!-- Flutter needs it to communicate with the running application\n         to allow setting breakpoints, to provide hot reload, etc.\n    -->\n    <uses-permission android:name=\"android.permission.INTERNET\"/>\n</manifest>\n"
  },
  {
    "path": "android/app/src/main/AndroidManifest.xml",
    "content": "<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    package=\"io.ditclear.flutter_challenge_googlemaps\">\n\n    <!-- io.flutter.app.FlutterApplication is an android.app.Application that\n         calls FlutterMain.startInitialization(this); in its onCreate method.\n         In most cases you can leave this as-is, but you if you want to provide\n         additional functionality it is fine to subclass or reimplement\n         FlutterApplication and put your custom class here. -->\n    <application\n        android:name=\"io.flutter.app.FlutterApplication\"\n        android:label=\"flutter_challenge_googlemaps\"\n        android:icon=\"@mipmap/ic_launcher\">\n        <activity\n            android:name=\".MainActivity\"\n            android:launchMode=\"singleTop\"\n            android:theme=\"@style/LaunchTheme\"\n            android:configChanges=\"orientation|keyboardHidden|keyboard|screenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode\"\n            android:hardwareAccelerated=\"true\"\n            android:windowSoftInputMode=\"adjustResize\">\n            <!-- This keeps the window background of the activity showing\n                 until Flutter renders its first frame. It can be removed if\n                 there is no splash screen (such as the default splash screen\n                 defined in @style/LaunchTheme). -->\n            <meta-data\n                android:name=\"io.flutter.app.android.SplashScreenUntilFirstFrame\"\n                android:value=\"true\" />\n            <intent-filter>\n                <action android:name=\"android.intent.action.MAIN\"/>\n                <category android:name=\"android.intent.category.LAUNCHER\"/>\n            </intent-filter>\n        </activity>\n    </application>\n</manifest>\n"
  },
  {
    "path": "android/app/src/main/kotlin/io/ditclear/flutter_challenge_googlemaps/MainActivity.kt",
    "content": "package io.ditclear.flutter_challenge_googlemaps\n\nimport android.os.Bundle\n\nimport io.flutter.app.FlutterActivity\nimport io.flutter.plugins.GeneratedPluginRegistrant\n\nclass MainActivity: FlutterActivity() {\n  override fun onCreate(savedInstanceState: Bundle?) {\n    super.onCreate(savedInstanceState)\n    GeneratedPluginRegistrant.registerWith(this)\n  }\n}\n"
  },
  {
    "path": "android/app/src/main/res/drawable/launch_background.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<!-- Modify this file to customize your launch splash screen -->\n<layer-list xmlns:android=\"http://schemas.android.com/apk/res/android\">\n    <item android:drawable=\"@android:color/white\" />\n\n    <!-- You can insert your own image assets here -->\n    <!-- <item>\n        <bitmap\n            android:gravity=\"center\"\n            android:src=\"@mipmap/launch_image\" />\n    </item> -->\n</layer-list>\n"
  },
  {
    "path": "android/app/src/main/res/values/styles.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<resources>\n    <style name=\"LaunchTheme\" parent=\"@android:style/Theme.Black.NoTitleBar\">\n        <!-- Show a splash screen on the activity. Automatically removed when\n             Flutter draws its first frame -->\n        <item name=\"android:windowBackground\">@drawable/launch_background</item>\n    </style>\n</resources>\n"
  },
  {
    "path": "android/app/src/profile/AndroidManifest.xml",
    "content": "<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    package=\"io.ditclear.flutter_challenge_googlemaps\">\n    <!-- Flutter needs it to communicate with the running application\n         to allow setting breakpoints, to provide hot reload, etc.\n    -->\n    <uses-permission android:name=\"android.permission.INTERNET\"/>\n</manifest>\n"
  },
  {
    "path": "android/build.gradle",
    "content": "buildscript {\n    ext.kotlin_version = '1.2.71'\n    repositories {\n        google()\n        jcenter()\n    }\n\n    dependencies {\n        classpath 'com.android.tools.build:gradle:3.2.1'\n        classpath \"org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version\"\n    }\n}\n\nallprojects {\n    repositories {\n        google()\n        jcenter()\n    }\n}\n\nrootProject.buildDir = '../build'\nsubprojects {\n    project.buildDir = \"${rootProject.buildDir}/${project.name}\"\n}\nsubprojects {\n    project.evaluationDependsOn(':app')\n}\n\ntask clean(type: Delete) {\n    delete rootProject.buildDir\n}\n"
  },
  {
    "path": "android/gradle/wrapper/gradle-wrapper.properties",
    "content": "#Fri Jun 23 08:50:38 CEST 2017\ndistributionBase=GRADLE_USER_HOME\ndistributionPath=wrapper/dists\nzipStoreBase=GRADLE_USER_HOME\nzipStorePath=wrapper/dists\ndistributionUrl=https\\://services.gradle.org/distributions/gradle-4.10.2-all.zip\n"
  },
  {
    "path": "android/gradle.properties",
    "content": "org.gradle.jvmargs=-Xmx1536M\n"
  },
  {
    "path": "android/settings.gradle",
    "content": "include ':app'\n\ndef flutterProjectRoot = rootProject.projectDir.parentFile.toPath()\n\ndef plugins = new Properties()\ndef pluginsFile = new File(flutterProjectRoot.toFile(), '.flutter-plugins')\nif (pluginsFile.exists()) {\n    pluginsFile.withReader('UTF-8') { reader -> plugins.load(reader) }\n}\n\nplugins.each { name, path ->\n    def pluginDirectory = flutterProjectRoot.resolve(path).resolve('android').toFile()\n    include \":$name\"\n    project(\":$name\").projectDir = pluginDirectory\n}\n"
  },
  {
    "path": "ios/Flutter/AppFrameworkInfo.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n  <key>CFBundleDevelopmentRegion</key>\n  <string>en</string>\n  <key>CFBundleExecutable</key>\n  <string>App</string>\n  <key>CFBundleIdentifier</key>\n  <string>io.flutter.flutter.app</string>\n  <key>CFBundleInfoDictionaryVersion</key>\n  <string>6.0</string>\n  <key>CFBundleName</key>\n  <string>App</string>\n  <key>CFBundlePackageType</key>\n  <string>FMWK</string>\n  <key>CFBundleShortVersionString</key>\n  <string>1.0</string>\n  <key>CFBundleSignature</key>\n  <string>????</string>\n  <key>CFBundleVersion</key>\n  <string>1.0</string>\n  <key>MinimumOSVersion</key>\n  <string>8.0</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "ios/Flutter/Debug.xcconfig",
    "content": "#include \"Generated.xcconfig\"\n"
  },
  {
    "path": "ios/Flutter/Release.xcconfig",
    "content": "#include \"Generated.xcconfig\"\n"
  },
  {
    "path": "ios/Runner/AppDelegate.swift",
    "content": "import UIKit\nimport Flutter\n\n@UIApplicationMain\n@objc class AppDelegate: FlutterAppDelegate {\n  override func application(\n    _ application: UIApplication,\n    didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?\n  ) -> Bool {\n    GeneratedPluginRegistrant.register(with: self)\n    return super.application(application, didFinishLaunchingWithOptions: launchOptions)\n  }\n}\n"
  },
  {
    "path": "ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json",
    "content": "{\n  \"images\" : [\n    {\n      \"size\" : \"20x20\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-20x20@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"20x20\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-20x20@3x.png\",\n      \"scale\" : \"3x\"\n    },\n    {\n      \"size\" : \"29x29\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-29x29@1x.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      \"size\" : \"29x29\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-29x29@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"29x29\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-29x29@3x.png\",\n      \"scale\" : \"3x\"\n    },\n    {\n      \"size\" : \"40x40\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-40x40@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"40x40\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-40x40@3x.png\",\n      \"scale\" : \"3x\"\n    },\n    {\n      \"size\" : \"60x60\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-60x60@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"60x60\",\n      \"idiom\" : \"iphone\",\n      \"filename\" : \"Icon-App-60x60@3x.png\",\n      \"scale\" : \"3x\"\n    },\n    {\n      \"size\" : \"20x20\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-20x20@1x.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      \"size\" : \"20x20\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-20x20@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"29x29\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-29x29@1x.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      \"size\" : \"29x29\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-29x29@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"40x40\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-40x40@1x.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      \"size\" : \"40x40\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-40x40@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"76x76\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-76x76@1x.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      \"size\" : \"76x76\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-76x76@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"83.5x83.5\",\n      \"idiom\" : \"ipad\",\n      \"filename\" : \"Icon-App-83.5x83.5@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"size\" : \"1024x1024\",\n      \"idiom\" : \"ios-marketing\",\n      \"filename\" : \"Icon-App-1024x1024@1x.png\",\n      \"scale\" : \"1x\"\n    }\n  ],\n  \"info\" : {\n    \"version\" : 1,\n    \"author\" : \"xcode\"\n  }\n}\n"
  },
  {
    "path": "ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json",
    "content": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"LaunchImage.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"LaunchImage@2x.png\",\n      \"scale\" : \"2x\"\n    },\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"LaunchImage@3x.png\",\n      \"scale\" : \"3x\"\n    }\n  ],\n  \"info\" : {\n    \"version\" : 1,\n    \"author\" : \"xcode\"\n  }\n}\n"
  },
  {
    "path": "ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md",
    "content": "# Launch Screen Assets\n\nYou can customize the launch screen with your own desired assets by replacing the image files in this directory.\n\nYou 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."
  },
  {
    "path": "ios/Runner/Base.lproj/LaunchScreen.storyboard",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<document type=\"com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB\" version=\"3.0\" toolsVersion=\"12121\" systemVersion=\"16G29\" targetRuntime=\"iOS.CocoaTouch\" propertyAccessControl=\"none\" useAutolayout=\"YES\" launchScreen=\"YES\" colorMatched=\"YES\" initialViewController=\"01J-lp-oVM\">\n    <dependencies>\n        <deployment identifier=\"iOS\"/>\n        <plugIn identifier=\"com.apple.InterfaceBuilder.IBCocoaTouchPlugin\" version=\"12089\"/>\n    </dependencies>\n    <scenes>\n        <!--View Controller-->\n        <scene sceneID=\"EHf-IW-A2E\">\n            <objects>\n                <viewController id=\"01J-lp-oVM\" sceneMemberID=\"viewController\">\n                    <layoutGuides>\n                        <viewControllerLayoutGuide type=\"top\" id=\"Ydg-fD-yQy\"/>\n                        <viewControllerLayoutGuide type=\"bottom\" id=\"xbc-2k-c8Z\"/>\n                    </layoutGuides>\n                    <view key=\"view\" contentMode=\"scaleToFill\" id=\"Ze5-6b-2t3\">\n                        <autoresizingMask key=\"autoresizingMask\" widthSizable=\"YES\" heightSizable=\"YES\"/>\n                        <subviews>\n                            <imageView opaque=\"NO\" clipsSubviews=\"YES\" multipleTouchEnabled=\"YES\" contentMode=\"center\" image=\"LaunchImage\" translatesAutoresizingMaskIntoConstraints=\"NO\" id=\"YRO-k0-Ey4\">\n                            </imageView>\n                        </subviews>\n                        <color key=\"backgroundColor\" red=\"1\" green=\"1\" blue=\"1\" alpha=\"1\" colorSpace=\"custom\" customColorSpace=\"sRGB\"/>\n                        <constraints>\n                            <constraint firstItem=\"YRO-k0-Ey4\" firstAttribute=\"centerX\" secondItem=\"Ze5-6b-2t3\" secondAttribute=\"centerX\" id=\"1a2-6s-vTC\"/>\n                            <constraint firstItem=\"YRO-k0-Ey4\" firstAttribute=\"centerY\" secondItem=\"Ze5-6b-2t3\" secondAttribute=\"centerY\" id=\"4X2-HB-R7a\"/>\n                        </constraints>\n                    </view>\n                </viewController>\n                <placeholder placeholderIdentifier=\"IBFirstResponder\" id=\"iYj-Kq-Ea1\" userLabel=\"First Responder\" sceneMemberID=\"firstResponder\"/>\n            </objects>\n            <point key=\"canvasLocation\" x=\"53\" y=\"375\"/>\n        </scene>\n    </scenes>\n    <resources>\n        <image name=\"LaunchImage\" width=\"168\" height=\"185\"/>\n    </resources>\n</document>\n"
  },
  {
    "path": "ios/Runner/Base.lproj/Main.storyboard",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<document type=\"com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB\" version=\"3.0\" toolsVersion=\"10117\" systemVersion=\"15F34\" targetRuntime=\"iOS.CocoaTouch\" propertyAccessControl=\"none\" useAutolayout=\"YES\" useTraitCollections=\"YES\" initialViewController=\"BYZ-38-t0r\">\n    <dependencies>\n        <deployment identifier=\"iOS\"/>\n        <plugIn identifier=\"com.apple.InterfaceBuilder.IBCocoaTouchPlugin\" version=\"10085\"/>\n    </dependencies>\n    <scenes>\n        <!--Flutter View Controller-->\n        <scene sceneID=\"tne-QT-ifu\">\n            <objects>\n                <viewController id=\"BYZ-38-t0r\" customClass=\"FlutterViewController\" sceneMemberID=\"viewController\">\n                    <layoutGuides>\n                        <viewControllerLayoutGuide type=\"top\" id=\"y3c-jy-aDJ\"/>\n                        <viewControllerLayoutGuide type=\"bottom\" id=\"wfy-db-euE\"/>\n                    </layoutGuides>\n                    <view key=\"view\" contentMode=\"scaleToFill\" id=\"8bC-Xf-vdC\">\n                        <rect key=\"frame\" x=\"0.0\" y=\"0.0\" width=\"600\" height=\"600\"/>\n                        <autoresizingMask key=\"autoresizingMask\" widthSizable=\"YES\" heightSizable=\"YES\"/>\n                        <color key=\"backgroundColor\" white=\"1\" alpha=\"1\" colorSpace=\"custom\" customColorSpace=\"calibratedWhite\"/>\n                    </view>\n                </viewController>\n                <placeholder placeholderIdentifier=\"IBFirstResponder\" id=\"dkx-z0-nzr\" sceneMemberID=\"firstResponder\"/>\n            </objects>\n        </scene>\n    </scenes>\n</document>\n"
  },
  {
    "path": "ios/Runner/Info.plist",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>CFBundleDevelopmentRegion</key>\n\t<string>en</string>\n\t<key>CFBundleExecutable</key>\n\t<string>$(EXECUTABLE_NAME)</string>\n\t<key>CFBundleIdentifier</key>\n\t<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>\n\t<key>CFBundleInfoDictionaryVersion</key>\n\t<string>6.0</string>\n\t<key>CFBundleName</key>\n\t<string>flutter_challenge_googlemaps</string>\n\t<key>CFBundlePackageType</key>\n\t<string>APPL</string>\n\t<key>CFBundleShortVersionString</key>\n\t<string>$(FLUTTER_BUILD_NAME)</string>\n\t<key>CFBundleSignature</key>\n\t<string>????</string>\n\t<key>CFBundleVersion</key>\n\t<string>$(FLUTTER_BUILD_NUMBER)</string>\n\t<key>LSRequiresIPhoneOS</key>\n\t<true/>\n\t<key>UILaunchStoryboardName</key>\n\t<string>LaunchScreen</string>\n\t<key>UIMainStoryboardFile</key>\n\t<string>Main</string>\n\t<key>UISupportedInterfaceOrientations</key>\n\t<array>\n\t\t<string>UIInterfaceOrientationPortrait</string>\n\t\t<string>UIInterfaceOrientationLandscapeLeft</string>\n\t\t<string>UIInterfaceOrientationLandscapeRight</string>\n\t</array>\n\t<key>UISupportedInterfaceOrientations~ipad</key>\n\t<array>\n\t\t<string>UIInterfaceOrientationPortrait</string>\n\t\t<string>UIInterfaceOrientationPortraitUpsideDown</string>\n\t\t<string>UIInterfaceOrientationLandscapeLeft</string>\n\t\t<string>UIInterfaceOrientationLandscapeRight</string>\n\t</array>\n\t<key>UIViewControllerBasedStatusBarAppearance</key>\n\t<false/>\n</dict>\n</plist>\n"
  },
  {
    "path": "ios/Runner/Runner-Bridging-Header.h",
    "content": "#import \"GeneratedPluginRegistrant.h\""
  },
  {
    "path": "ios/Runner.xcodeproj/project.pbxproj",
    "content": "// !$*UTF8*$!\n{\n\tarchiveVersion = 1;\n\tclasses = {\n\t};\n\tobjectVersion = 46;\n\tobjects = {\n\n/* Begin PBXBuildFile section */\n\t\t1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };\n\t\t3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };\n\t\t3B80C3941E831B6300D905FE /* App.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3B80C3931E831B6300D905FE /* App.framework */; };\n\t\t3B80C3951E831B6300D905FE /* App.framework in Embed Frameworks */ = {isa = PBXBuildFile; fileRef = 3B80C3931E831B6300D905FE /* App.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; };\n\t\t74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; };\n\t\t9705A1C61CF904A100538489 /* Flutter.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9740EEBA1CF902C7004384FC /* Flutter.framework */; };\n\t\t9705A1C71CF904A300538489 /* Flutter.framework in Embed Frameworks */ = {isa = PBXBuildFile; fileRef = 9740EEBA1CF902C7004384FC /* Flutter.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; };\n\t\t9740EEB41CF90195004384FC /* Debug.xcconfig in Resources */ = {isa = PBXBuildFile; fileRef = 9740EEB21CF90195004384FC /* Debug.xcconfig */; };\n\t\t97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; };\n\t\t97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; };\n\t\t97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; };\n/* End PBXBuildFile section */\n\n/* Begin PBXCopyFilesBuildPhase section */\n\t\t9705A1C41CF9048500538489 /* Embed Frameworks */ = {\n\t\t\tisa = PBXCopyFilesBuildPhase;\n\t\t\tbuildActionMask = 2147483647;\n\t\t\tdstPath = \"\";\n\t\t\tdstSubfolderSpec = 10;\n\t\t\tfiles = (\n\t\t\t\t3B80C3951E831B6300D905FE /* App.framework in Embed Frameworks */,\n\t\t\t\t9705A1C71CF904A300538489 /* Flutter.framework in Embed Frameworks */,\n\t\t\t);\n\t\t\tname = \"Embed Frameworks\";\n\t\t\trunOnlyForDeploymentPostprocessing = 0;\n\t\t};\n/* End PBXCopyFilesBuildPhase section */\n\n/* Begin PBXFileReference section */\n\t\t1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = \"<group>\"; };\n\t\t1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = \"<group>\"; };\n\t\t3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = \"<group>\"; };\n\t\t3B80C3931E831B6300D905FE /* App.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = App.framework; path = Flutter/App.framework; sourceTree = \"<group>\"; };\n\t\t74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = \"Runner-Bridging-Header.h\"; sourceTree = \"<group>\"; };\n\t\t74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = \"<group>\"; };\n\t\t7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = \"<group>\"; };\n\t\t9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = \"<group>\"; };\n\t\t9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = \"<group>\"; };\n\t\t9740EEBA1CF902C7004384FC /* Flutter.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Flutter.framework; path = Flutter/Flutter.framework; sourceTree = \"<group>\"; };\n\t\t97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };\n\t\t97C146FB1CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = \"<group>\"; };\n\t\t97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = \"<group>\"; };\n\t\t97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = \"<group>\"; };\n\t\t97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = \"<group>\"; };\n/* End PBXFileReference section */\n\n/* Begin PBXFrameworksBuildPhase section */\n\t\t97C146EB1CF9000F007C117D /* Frameworks */ = {\n\t\t\tisa = PBXFrameworksBuildPhase;\n\t\t\tbuildActionMask = 2147483647;\n\t\t\tfiles = (\n\t\t\t\t9705A1C61CF904A100538489 /* Flutter.framework in Frameworks */,\n\t\t\t\t3B80C3941E831B6300D905FE /* App.framework in Frameworks */,\n\t\t\t);\n\t\t\trunOnlyForDeploymentPostprocessing = 0;\n\t\t};\n/* End PBXFrameworksBuildPhase section */\n\n/* Begin PBXGroup section */\n\t\t9740EEB11CF90186004384FC /* Flutter */ = {\n\t\t\tisa = PBXGroup;\n\t\t\tchildren = (\n\t\t\t\t3B80C3931E831B6300D905FE /* App.framework */,\n\t\t\t\t3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */,\n\t\t\t\t9740EEBA1CF902C7004384FC /* Flutter.framework */,\n\t\t\t\t9740EEB21CF90195004384FC /* Debug.xcconfig */,\n\t\t\t\t7AFA3C8E1D35360C0083082E /* Release.xcconfig */,\n\t\t\t\t9740EEB31CF90195004384FC /* Generated.xcconfig */,\n\t\t\t);\n\t\t\tname = Flutter;\n\t\t\tsourceTree = \"<group>\";\n\t\t};\n\t\t97C146E51CF9000F007C117D = {\n\t\t\tisa = PBXGroup;\n\t\t\tchildren = (\n\t\t\t\t9740EEB11CF90186004384FC /* Flutter */,\n\t\t\t\t97C146F01CF9000F007C117D /* Runner */,\n\t\t\t\t97C146EF1CF9000F007C117D /* Products */,\n\t\t\t);\n\t\t\tsourceTree = \"<group>\";\n\t\t};\n\t\t97C146EF1CF9000F007C117D /* Products */ = {\n\t\t\tisa = PBXGroup;\n\t\t\tchildren = (\n\t\t\t\t97C146EE1CF9000F007C117D /* Runner.app */,\n\t\t\t);\n\t\t\tname = Products;\n\t\t\tsourceTree = \"<group>\";\n\t\t};\n\t\t97C146F01CF9000F007C117D /* Runner */ = {\n\t\t\tisa = PBXGroup;\n\t\t\tchildren = (\n\t\t\t\t97C146FA1CF9000F007C117D /* Main.storyboard */,\n\t\t\t\t97C146FD1CF9000F007C117D /* Assets.xcassets */,\n\t\t\t\t97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */,\n\t\t\t\t97C147021CF9000F007C117D /* Info.plist */,\n\t\t\t\t97C146F11CF9000F007C117D /* Supporting Files */,\n\t\t\t\t1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */,\n\t\t\t\t1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */,\n\t\t\t\t74858FAE1ED2DC5600515810 /* AppDelegate.swift */,\n\t\t\t\t74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */,\n\t\t\t);\n\t\t\tpath = Runner;\n\t\t\tsourceTree = \"<group>\";\n\t\t};\n\t\t97C146F11CF9000F007C117D /* Supporting Files */ = {\n\t\t\tisa = PBXGroup;\n\t\t\tchildren = (\n\t\t\t);\n\t\t\tname = \"Supporting Files\";\n\t\t\tsourceTree = \"<group>\";\n\t\t};\n/* End PBXGroup section */\n\n/* Begin PBXNativeTarget section */\n\t\t97C146ED1CF9000F007C117D /* Runner */ = {\n\t\t\tisa = PBXNativeTarget;\n\t\t\tbuildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget \"Runner\" */;\n\t\t\tbuildPhases = (\n\t\t\t\t9740EEB61CF901F6004384FC /* Run Script */,\n\t\t\t\t97C146EA1CF9000F007C117D /* Sources */,\n\t\t\t\t97C146EB1CF9000F007C117D /* Frameworks */,\n\t\t\t\t97C146EC1CF9000F007C117D /* Resources */,\n\t\t\t\t9705A1C41CF9048500538489 /* Embed Frameworks */,\n\t\t\t\t3B06AD1E1E4923F5004D2608 /* Thin Binary */,\n\t\t\t);\n\t\t\tbuildRules = (\n\t\t\t);\n\t\t\tdependencies = (\n\t\t\t);\n\t\t\tname = Runner;\n\t\t\tproductName = Runner;\n\t\t\tproductReference = 97C146EE1CF9000F007C117D /* Runner.app */;\n\t\t\tproductType = \"com.apple.product-type.application\";\n\t\t};\n/* End PBXNativeTarget section */\n\n/* Begin PBXProject section */\n\t\t97C146E61CF9000F007C117D /* Project object */ = {\n\t\t\tisa = PBXProject;\n\t\t\tattributes = {\n\t\t\t\tLastUpgradeCheck = 0910;\n\t\t\t\tORGANIZATIONNAME = \"The Chromium Authors\";\n\t\t\t\tTargetAttributes = {\n\t\t\t\t\t97C146ED1CF9000F007C117D = {\n\t\t\t\t\t\tCreatedOnToolsVersion = 7.3.1;\n\t\t\t\t\t\tLastSwiftMigration = 0910;\n\t\t\t\t\t};\n\t\t\t\t};\n\t\t\t};\n\t\t\tbuildConfigurationList = 97C146E91CF9000F007C117D /* Build configuration list for PBXProject \"Runner\" */;\n\t\t\tcompatibilityVersion = \"Xcode 3.2\";\n\t\t\tdevelopmentRegion = English;\n\t\t\thasScannedForEncodings = 0;\n\t\t\tknownRegions = (\n\t\t\t\ten,\n\t\t\t\tBase,\n\t\t\t);\n\t\t\tmainGroup = 97C146E51CF9000F007C117D;\n\t\t\tproductRefGroup = 97C146EF1CF9000F007C117D /* Products */;\n\t\t\tprojectDirPath = \"\";\n\t\t\tprojectRoot = \"\";\n\t\t\ttargets = (\n\t\t\t\t97C146ED1CF9000F007C117D /* Runner */,\n\t\t\t);\n\t\t};\n/* End PBXProject section */\n\n/* Begin PBXResourcesBuildPhase section */\n\t\t97C146EC1CF9000F007C117D /* Resources */ = {\n\t\t\tisa = PBXResourcesBuildPhase;\n\t\t\tbuildActionMask = 2147483647;\n\t\t\tfiles = (\n\t\t\t\t97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */,\n\t\t\t\t3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */,\n\t\t\t\t9740EEB41CF90195004384FC /* Debug.xcconfig in Resources */,\n\t\t\t\t97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */,\n\t\t\t\t97C146FC1CF9000F007C117D /* Main.storyboard in Resources */,\n\t\t\t);\n\t\t\trunOnlyForDeploymentPostprocessing = 0;\n\t\t};\n/* End PBXResourcesBuildPhase section */\n\n/* Begin PBXShellScriptBuildPhase section */\n\t\t3B06AD1E1E4923F5004D2608 /* Thin Binary */ = {\n\t\t\tisa = PBXShellScriptBuildPhase;\n\t\t\tbuildActionMask = 2147483647;\n\t\t\tfiles = (\n\t\t\t);\n\t\t\tinputPaths = (\n\t\t\t);\n\t\t\tname = \"Thin Binary\";\n\t\t\toutputPaths = (\n\t\t\t);\n\t\t\trunOnlyForDeploymentPostprocessing = 0;\n\t\t\tshellPath = /bin/sh;\n\t\t\tshellScript = \"/bin/sh \\\"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\\\" thin\";\n\t\t};\n\t\t9740EEB61CF901F6004384FC /* Run Script */ = {\n\t\t\tisa = PBXShellScriptBuildPhase;\n\t\t\tbuildActionMask = 2147483647;\n\t\t\tfiles = (\n\t\t\t);\n\t\t\tinputPaths = (\n\t\t\t);\n\t\t\tname = \"Run Script\";\n\t\t\toutputPaths = (\n\t\t\t);\n\t\t\trunOnlyForDeploymentPostprocessing = 0;\n\t\t\tshellPath = /bin/sh;\n\t\t\tshellScript = \"/bin/sh \\\"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\\\" build\";\n\t\t};\n/* End PBXShellScriptBuildPhase section */\n\n/* Begin PBXSourcesBuildPhase section */\n\t\t97C146EA1CF9000F007C117D /* Sources */ = {\n\t\t\tisa = PBXSourcesBuildPhase;\n\t\t\tbuildActionMask = 2147483647;\n\t\t\tfiles = (\n\t\t\t\t74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */,\n\t\t\t\t1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */,\n\t\t\t);\n\t\t\trunOnlyForDeploymentPostprocessing = 0;\n\t\t};\n/* End PBXSourcesBuildPhase section */\n\n/* Begin PBXVariantGroup section */\n\t\t97C146FA1CF9000F007C117D /* Main.storyboard */ = {\n\t\t\tisa = PBXVariantGroup;\n\t\t\tchildren = (\n\t\t\t\t97C146FB1CF9000F007C117D /* Base */,\n\t\t\t);\n\t\t\tname = Main.storyboard;\n\t\t\tsourceTree = \"<group>\";\n\t\t};\n\t\t97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */ = {\n\t\t\tisa = PBXVariantGroup;\n\t\t\tchildren = (\n\t\t\t\t97C147001CF9000F007C117D /* Base */,\n\t\t\t);\n\t\t\tname = LaunchScreen.storyboard;\n\t\t\tsourceTree = \"<group>\";\n\t\t};\n/* End PBXVariantGroup section */\n\n/* Begin XCBuildConfiguration section */\n\t\t249021D3217E4FDB00AE95B9 /* Profile */ = {\n\t\t\tisa = XCBuildConfiguration;\n\t\t\tbaseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;\n\t\t\tbuildSettings = {\n\t\t\t\tALWAYS_SEARCH_USER_PATHS = NO;\n\t\t\t\tCLANG_ANALYZER_NONNULL = YES;\n\t\t\t\tCLANG_CXX_LANGUAGE_STANDARD = \"gnu++0x\";\n\t\t\t\tCLANG_CXX_LIBRARY = \"libc++\";\n\t\t\t\tCLANG_ENABLE_MODULES = YES;\n\t\t\t\tCLANG_ENABLE_OBJC_ARC = YES;\n\t\t\t\tCLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;\n\t\t\t\tCLANG_WARN_BOOL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_COMMA = YES;\n\t\t\t\tCLANG_WARN_CONSTANT_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;\n\t\t\t\tCLANG_WARN_EMPTY_BODY = YES;\n\t\t\t\tCLANG_WARN_ENUM_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_INFINITE_RECURSION = YES;\n\t\t\t\tCLANG_WARN_INT_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_OBJC_LITERAL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;\n\t\t\t\tCLANG_WARN_RANGE_LOOP_ANALYSIS = YES;\n\t\t\t\tCLANG_WARN_STRICT_PROTOTYPES = YES;\n\t\t\t\tCLANG_WARN_SUSPICIOUS_MOVE = YES;\n\t\t\t\tCLANG_WARN_UNREACHABLE_CODE = YES;\n\t\t\t\tCLANG_WARN__DUPLICATE_METHOD_MATCH = YES;\n\t\t\t\t\"CODE_SIGN_IDENTITY[sdk=iphoneos*]\" = \"iPhone Developer\";\n\t\t\t\tCOPY_PHASE_STRIP = NO;\n\t\t\t\tDEBUG_INFORMATION_FORMAT = \"dwarf-with-dsym\";\n\t\t\t\tENABLE_NS_ASSERTIONS = NO;\n\t\t\t\tENABLE_STRICT_OBJC_MSGSEND = YES;\n\t\t\t\tGCC_C_LANGUAGE_STANDARD = gnu99;\n\t\t\t\tGCC_NO_COMMON_BLOCKS = YES;\n\t\t\t\tGCC_WARN_64_TO_32_BIT_CONVERSION = YES;\n\t\t\t\tGCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;\n\t\t\t\tGCC_WARN_UNDECLARED_SELECTOR = YES;\n\t\t\t\tGCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;\n\t\t\t\tGCC_WARN_UNUSED_FUNCTION = YES;\n\t\t\t\tGCC_WARN_UNUSED_VARIABLE = YES;\n\t\t\t\tIPHONEOS_DEPLOYMENT_TARGET = 8.0;\n\t\t\t\tMTL_ENABLE_DEBUG_INFO = NO;\n\t\t\t\tSDKROOT = iphoneos;\n\t\t\t\tTARGETED_DEVICE_FAMILY = \"1,2\";\n\t\t\t\tVALIDATE_PRODUCT = YES;\n\t\t\t};\n\t\t\tname = Profile;\n\t\t};\n\t\t249021D4217E4FDB00AE95B9 /* Profile */ = {\n\t\t\tisa = XCBuildConfiguration;\n\t\t\tbaseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;\n\t\t\tbuildSettings = {\n\t\t\t\tASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;\n\t\t\t\tCURRENT_PROJECT_VERSION = \"$(FLUTTER_BUILD_NUMBER)\";\n\t\t\t\tDEVELOPMENT_TEAM = S8QB4VV633;\n\t\t\t\tENABLE_BITCODE = NO;\n\t\t\t\tFRAMEWORK_SEARCH_PATHS = (\n\t\t\t\t\t\"$(inherited)\",\n\t\t\t\t\t\"$(PROJECT_DIR)/Flutter\",\n\t\t\t\t);\n\t\t\t\tINFOPLIST_FILE = Runner/Info.plist;\n\t\t\t\tLD_RUNPATH_SEARCH_PATHS = \"$(inherited) @executable_path/Frameworks\";\n\t\t\t\tLIBRARY_SEARCH_PATHS = (\n\t\t\t\t\t\"$(inherited)\",\n\t\t\t\t\t\"$(PROJECT_DIR)/Flutter\",\n\t\t\t\t);\n\t\t\t\tPRODUCT_BUNDLE_IDENTIFIER = io.ditclear.flutterChallengeGooglemaps;\n\t\t\t\tPRODUCT_NAME = \"$(TARGET_NAME)\";\n\t\t\t\tSWIFT_VERSION = 4.0;\n\t\t\t\tVERSIONING_SYSTEM = \"apple-generic\";\n\t\t\t};\n\t\t\tname = Profile;\n\t\t};\n\t\t97C147031CF9000F007C117D /* Debug */ = {\n\t\t\tisa = XCBuildConfiguration;\n\t\t\tbaseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */;\n\t\t\tbuildSettings = {\n\t\t\t\tALWAYS_SEARCH_USER_PATHS = NO;\n\t\t\t\tCLANG_ANALYZER_NONNULL = YES;\n\t\t\t\tCLANG_CXX_LANGUAGE_STANDARD = \"gnu++0x\";\n\t\t\t\tCLANG_CXX_LIBRARY = \"libc++\";\n\t\t\t\tCLANG_ENABLE_MODULES = YES;\n\t\t\t\tCLANG_ENABLE_OBJC_ARC = YES;\n\t\t\t\tCLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;\n\t\t\t\tCLANG_WARN_BOOL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_COMMA = YES;\n\t\t\t\tCLANG_WARN_CONSTANT_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;\n\t\t\t\tCLANG_WARN_EMPTY_BODY = YES;\n\t\t\t\tCLANG_WARN_ENUM_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_INFINITE_RECURSION = YES;\n\t\t\t\tCLANG_WARN_INT_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_OBJC_LITERAL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;\n\t\t\t\tCLANG_WARN_RANGE_LOOP_ANALYSIS = YES;\n\t\t\t\tCLANG_WARN_STRICT_PROTOTYPES = YES;\n\t\t\t\tCLANG_WARN_SUSPICIOUS_MOVE = YES;\n\t\t\t\tCLANG_WARN_UNREACHABLE_CODE = YES;\n\t\t\t\tCLANG_WARN__DUPLICATE_METHOD_MATCH = YES;\n\t\t\t\t\"CODE_SIGN_IDENTITY[sdk=iphoneos*]\" = \"iPhone Developer\";\n\t\t\t\tCOPY_PHASE_STRIP = NO;\n\t\t\t\tDEBUG_INFORMATION_FORMAT = dwarf;\n\t\t\t\tENABLE_STRICT_OBJC_MSGSEND = YES;\n\t\t\t\tENABLE_TESTABILITY = YES;\n\t\t\t\tGCC_C_LANGUAGE_STANDARD = gnu99;\n\t\t\t\tGCC_DYNAMIC_NO_PIC = NO;\n\t\t\t\tGCC_NO_COMMON_BLOCKS = YES;\n\t\t\t\tGCC_OPTIMIZATION_LEVEL = 0;\n\t\t\t\tGCC_PREPROCESSOR_DEFINITIONS = (\n\t\t\t\t\t\"DEBUG=1\",\n\t\t\t\t\t\"$(inherited)\",\n\t\t\t\t);\n\t\t\t\tGCC_WARN_64_TO_32_BIT_CONVERSION = YES;\n\t\t\t\tGCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;\n\t\t\t\tGCC_WARN_UNDECLARED_SELECTOR = YES;\n\t\t\t\tGCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;\n\t\t\t\tGCC_WARN_UNUSED_FUNCTION = YES;\n\t\t\t\tGCC_WARN_UNUSED_VARIABLE = YES;\n\t\t\t\tIPHONEOS_DEPLOYMENT_TARGET = 8.0;\n\t\t\t\tMTL_ENABLE_DEBUG_INFO = YES;\n\t\t\t\tONLY_ACTIVE_ARCH = YES;\n\t\t\t\tSDKROOT = iphoneos;\n\t\t\t\tTARGETED_DEVICE_FAMILY = \"1,2\";\n\t\t\t};\n\t\t\tname = Debug;\n\t\t};\n\t\t97C147041CF9000F007C117D /* Release */ = {\n\t\t\tisa = XCBuildConfiguration;\n\t\t\tbaseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;\n\t\t\tbuildSettings = {\n\t\t\t\tALWAYS_SEARCH_USER_PATHS = NO;\n\t\t\t\tCLANG_ANALYZER_NONNULL = YES;\n\t\t\t\tCLANG_CXX_LANGUAGE_STANDARD = \"gnu++0x\";\n\t\t\t\tCLANG_CXX_LIBRARY = \"libc++\";\n\t\t\t\tCLANG_ENABLE_MODULES = YES;\n\t\t\t\tCLANG_ENABLE_OBJC_ARC = YES;\n\t\t\t\tCLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;\n\t\t\t\tCLANG_WARN_BOOL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_COMMA = YES;\n\t\t\t\tCLANG_WARN_CONSTANT_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;\n\t\t\t\tCLANG_WARN_EMPTY_BODY = YES;\n\t\t\t\tCLANG_WARN_ENUM_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_INFINITE_RECURSION = YES;\n\t\t\t\tCLANG_WARN_INT_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_OBJC_LITERAL_CONVERSION = YES;\n\t\t\t\tCLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;\n\t\t\t\tCLANG_WARN_RANGE_LOOP_ANALYSIS = YES;\n\t\t\t\tCLANG_WARN_STRICT_PROTOTYPES = YES;\n\t\t\t\tCLANG_WARN_SUSPICIOUS_MOVE = YES;\n\t\t\t\tCLANG_WARN_UNREACHABLE_CODE = YES;\n\t\t\t\tCLANG_WARN__DUPLICATE_METHOD_MATCH = YES;\n\t\t\t\t\"CODE_SIGN_IDENTITY[sdk=iphoneos*]\" = \"iPhone Developer\";\n\t\t\t\tCOPY_PHASE_STRIP = NO;\n\t\t\t\tDEBUG_INFORMATION_FORMAT = \"dwarf-with-dsym\";\n\t\t\t\tENABLE_NS_ASSERTIONS = NO;\n\t\t\t\tENABLE_STRICT_OBJC_MSGSEND = YES;\n\t\t\t\tGCC_C_LANGUAGE_STANDARD = gnu99;\n\t\t\t\tGCC_NO_COMMON_BLOCKS = YES;\n\t\t\t\tGCC_WARN_64_TO_32_BIT_CONVERSION = YES;\n\t\t\t\tGCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;\n\t\t\t\tGCC_WARN_UNDECLARED_SELECTOR = YES;\n\t\t\t\tGCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;\n\t\t\t\tGCC_WARN_UNUSED_FUNCTION = YES;\n\t\t\t\tGCC_WARN_UNUSED_VARIABLE = YES;\n\t\t\t\tIPHONEOS_DEPLOYMENT_TARGET = 8.0;\n\t\t\t\tMTL_ENABLE_DEBUG_INFO = NO;\n\t\t\t\tSDKROOT = iphoneos;\n\t\t\t\tSWIFT_OPTIMIZATION_LEVEL = \"-Owholemodule\";\n\t\t\t\tTARGETED_DEVICE_FAMILY = \"1,2\";\n\t\t\t\tVALIDATE_PRODUCT = YES;\n\t\t\t};\n\t\t\tname = Release;\n\t\t};\n\t\t97C147061CF9000F007C117D /* Debug */ = {\n\t\t\tisa = XCBuildConfiguration;\n\t\t\tbaseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */;\n\t\t\tbuildSettings = {\n\t\t\t\tASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;\n\t\t\t\tCLANG_ENABLE_MODULES = YES;\n\t\t\t\tCURRENT_PROJECT_VERSION = \"$(FLUTTER_BUILD_NUMBER)\";\n\t\t\t\tENABLE_BITCODE = NO;\n\t\t\t\tFRAMEWORK_SEARCH_PATHS = (\n\t\t\t\t\t\"$(inherited)\",\n\t\t\t\t\t\"$(PROJECT_DIR)/Flutter\",\n\t\t\t\t);\n\t\t\t\tINFOPLIST_FILE = Runner/Info.plist;\n\t\t\t\tLD_RUNPATH_SEARCH_PATHS = \"$(inherited) @executable_path/Frameworks\";\n\t\t\t\tLIBRARY_SEARCH_PATHS = (\n\t\t\t\t\t\"$(inherited)\",\n\t\t\t\t\t\"$(PROJECT_DIR)/Flutter\",\n\t\t\t\t);\n\t\t\t\tPRODUCT_BUNDLE_IDENTIFIER = io.ditclear.flutterChallengeGooglemaps;\n\t\t\t\tPRODUCT_NAME = \"$(TARGET_NAME)\";\n\t\t\t\tSWIFT_OBJC_BRIDGING_HEADER = \"Runner/Runner-Bridging-Header.h\";\n\t\t\t\tSWIFT_OPTIMIZATION_LEVEL = \"-Onone\";\n\t\t\t\tSWIFT_SWIFT3_OBJC_INFERENCE = On;\n\t\t\t\tSWIFT_VERSION = 4.0;\n\t\t\t\tVERSIONING_SYSTEM = \"apple-generic\";\n\t\t\t};\n\t\t\tname = Debug;\n\t\t};\n\t\t97C147071CF9000F007C117D /* Release */ = {\n\t\t\tisa = XCBuildConfiguration;\n\t\t\tbaseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;\n\t\t\tbuildSettings = {\n\t\t\t\tASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;\n\t\t\t\tCLANG_ENABLE_MODULES = YES;\n\t\t\t\tCURRENT_PROJECT_VERSION = \"$(FLUTTER_BUILD_NUMBER)\";\n\t\t\t\tENABLE_BITCODE = NO;\n\t\t\t\tFRAMEWORK_SEARCH_PATHS = (\n\t\t\t\t\t\"$(inherited)\",\n\t\t\t\t\t\"$(PROJECT_DIR)/Flutter\",\n\t\t\t\t);\n\t\t\t\tINFOPLIST_FILE = Runner/Info.plist;\n\t\t\t\tLD_RUNPATH_SEARCH_PATHS = \"$(inherited) @executable_path/Frameworks\";\n\t\t\t\tLIBRARY_SEARCH_PATHS = (\n\t\t\t\t\t\"$(inherited)\",\n\t\t\t\t\t\"$(PROJECT_DIR)/Flutter\",\n\t\t\t\t);\n\t\t\t\tPRODUCT_BUNDLE_IDENTIFIER = io.ditclear.flutterChallengeGooglemaps;\n\t\t\t\tPRODUCT_NAME = \"$(TARGET_NAME)\";\n\t\t\t\tSWIFT_OBJC_BRIDGING_HEADER = \"Runner/Runner-Bridging-Header.h\";\n\t\t\t\tSWIFT_SWIFT3_OBJC_INFERENCE = On;\n\t\t\t\tSWIFT_VERSION = 4.0;\n\t\t\t\tVERSIONING_SYSTEM = \"apple-generic\";\n\t\t\t};\n\t\t\tname = Release;\n\t\t};\n/* End XCBuildConfiguration section */\n\n/* Begin XCConfigurationList section */\n\t\t97C146E91CF9000F007C117D /* Build configuration list for PBXProject \"Runner\" */ = {\n\t\t\tisa = XCConfigurationList;\n\t\t\tbuildConfigurations = (\n\t\t\t\t97C147031CF9000F007C117D /* Debug */,\n\t\t\t\t97C147041CF9000F007C117D /* Release */,\n\t\t\t\t249021D3217E4FDB00AE95B9 /* Profile */,\n\t\t\t);\n\t\t\tdefaultConfigurationIsVisible = 0;\n\t\t\tdefaultConfigurationName = Release;\n\t\t};\n\t\t97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget \"Runner\" */ = {\n\t\t\tisa = XCConfigurationList;\n\t\t\tbuildConfigurations = (\n\t\t\t\t97C147061CF9000F007C117D /* Debug */,\n\t\t\t\t97C147071CF9000F007C117D /* Release */,\n\t\t\t\t249021D4217E4FDB00AE95B9 /* Profile */,\n\t\t\t);\n\t\t\tdefaultConfigurationIsVisible = 0;\n\t\t\tdefaultConfigurationName = Release;\n\t\t};\n/* End XCConfigurationList section */\n\n\t};\n\trootObject = 97C146E61CF9000F007C117D /* Project object */;\n}\n"
  },
  {
    "path": "ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Workspace\n   version = \"1.0\">\n   <FileRef\n      location = \"group:Runner.xcodeproj\">\n   </FileRef>\n</Workspace>\n"
  },
  {
    "path": "ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Scheme\n   LastUpgradeVersion = \"0910\"\n   version = \"1.3\">\n   <BuildAction\n      parallelizeBuildables = \"YES\"\n      buildImplicitDependencies = \"YES\">\n      <BuildActionEntries>\n         <BuildActionEntry\n            buildForTesting = \"YES\"\n            buildForRunning = \"YES\"\n            buildForProfiling = \"YES\"\n            buildForArchiving = \"YES\"\n            buildForAnalyzing = \"YES\">\n            <BuildableReference\n               BuildableIdentifier = \"primary\"\n               BlueprintIdentifier = \"97C146ED1CF9000F007C117D\"\n               BuildableName = \"Runner.app\"\n               BlueprintName = \"Runner\"\n               ReferencedContainer = \"container:Runner.xcodeproj\">\n            </BuildableReference>\n         </BuildActionEntry>\n      </BuildActionEntries>\n   </BuildAction>\n   <TestAction\n      buildConfiguration = \"Debug\"\n      selectedDebuggerIdentifier = \"Xcode.DebuggerFoundation.Debugger.LLDB\"\n      selectedLauncherIdentifier = \"Xcode.DebuggerFoundation.Launcher.LLDB\"\n      language = \"\"\n      shouldUseLaunchSchemeArgsEnv = \"YES\">\n      <Testables>\n      </Testables>\n      <MacroExpansion>\n         <BuildableReference\n            BuildableIdentifier = \"primary\"\n            BlueprintIdentifier = \"97C146ED1CF9000F007C117D\"\n            BuildableName = \"Runner.app\"\n            BlueprintName = \"Runner\"\n            ReferencedContainer = \"container:Runner.xcodeproj\">\n         </BuildableReference>\n      </MacroExpansion>\n      <AdditionalOptions>\n      </AdditionalOptions>\n   </TestAction>\n   <LaunchAction\n      buildConfiguration = \"Debug\"\n      selectedDebuggerIdentifier = \"Xcode.DebuggerFoundation.Debugger.LLDB\"\n      selectedLauncherIdentifier = \"Xcode.DebuggerFoundation.Launcher.LLDB\"\n      language = \"\"\n      launchStyle = \"0\"\n      useCustomWorkingDirectory = \"NO\"\n      ignoresPersistentStateOnLaunch = \"NO\"\n      debugDocumentVersioning = \"YES\"\n      debugServiceExtension = \"internal\"\n      allowLocationSimulation = \"YES\">\n      <BuildableProductRunnable\n         runnableDebuggingMode = \"0\">\n         <BuildableReference\n            BuildableIdentifier = \"primary\"\n            BlueprintIdentifier = \"97C146ED1CF9000F007C117D\"\n            BuildableName = \"Runner.app\"\n            BlueprintName = \"Runner\"\n            ReferencedContainer = \"container:Runner.xcodeproj\">\n         </BuildableReference>\n      </BuildableProductRunnable>\n      <AdditionalOptions>\n      </AdditionalOptions>\n   </LaunchAction>\n   <ProfileAction\n      buildConfiguration = \"Profile\"\n      shouldUseLaunchSchemeArgsEnv = \"YES\"\n      savedToolIdentifier = \"\"\n      useCustomWorkingDirectory = \"NO\"\n      debugDocumentVersioning = \"YES\">\n      <BuildableProductRunnable\n         runnableDebuggingMode = \"0\">\n         <BuildableReference\n            BuildableIdentifier = \"primary\"\n            BlueprintIdentifier = \"97C146ED1CF9000F007C117D\"\n            BuildableName = \"Runner.app\"\n            BlueprintName = \"Runner\"\n            ReferencedContainer = \"container:Runner.xcodeproj\">\n         </BuildableReference>\n      </BuildableProductRunnable>\n   </ProfileAction>\n   <AnalyzeAction\n      buildConfiguration = \"Debug\">\n   </AnalyzeAction>\n   <ArchiveAction\n      buildConfiguration = \"Release\"\n      revealArchiveInOrganizer = \"YES\">\n   </ArchiveAction>\n</Scheme>\n"
  },
  {
    "path": "ios/Runner.xcworkspace/contents.xcworkspacedata",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Workspace\n   version = \"1.0\">\n   <FileRef\n      location = \"group:Runner.xcodeproj\">\n   </FileRef>\n</Workspace>\n"
  },
  {
    "path": "ios/Runner.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n\t<key>BuildSystemType</key>\n\t<string>Original</string>\n</dict>\n</plist>\n"
  },
  {
    "path": "lib/components/components.dart",
    "content": "export 'explore_content_widget.dart';\nexport 'explore_widget.dart';\nexport 'map_button.dart';\nexport 'menu_widget.dart';\nexport 'recent_search_widget.dart';\nexport 'search_back_widget.dart';\nexport 'search_menu_widget.dart';\nexport 'search_widget.dart';\n"
  },
  {
    "path": "lib/components/explore_content_widget.dart",
    "content": "import 'package:flutter/material.dart';\nimport 'package:flutter_challenge_googlemaps/helper/ui_helper.dart';\n\nclass ExploreContentWidget extends StatelessWidget {\n  final double currentExplorePercent;\n  final placeName = const [\"Authentic\\nrestaurant\", \"Famous\\nmonuments\", \"Weekend\\ngetaways\"];\n  const ExploreContentWidget({Key key, this.currentExplorePercent}) : super(key: key);\n\n  @override\n  Widget build(BuildContext context) {\n    if (currentExplorePercent != 0) {\n      return Positioned(\n        top: realH(standardHeight + (162 - standardHeight) * currentExplorePercent),\n        width: screenWidth,\n        child: Container(\n          height: screenHeight,\n          child: ListView(\n            physics: const BouncingScrollPhysics(),\n            shrinkWrap: true,\n            children: <Widget>[\n              Opacity(\n                opacity: currentExplorePercent,\n                child: Row(\n                  mainAxisSize: MainAxisSize.max,\n                  children: <Widget>[\n                    Expanded(\n                      child: Transform.translate(\n                        offset: Offset(screenWidth / 3 * (1 - currentExplorePercent),\n                            screenWidth / 3 / 2 * (1 - currentExplorePercent)),\n                        child: Image.asset(\n                          \"assets/icon_1.png\",\n                          width: realH(133),\n                          height: realH(133),\n                        ),\n                      ),\n                    ),\n                    Expanded(\n                      child: Image.asset(\n                        \"assets/icon_2.png\",\n                        width: realH(133),\n                        height: realH(133),\n                      ),\n                    ),\n                    Expanded(\n                      child: Transform.translate(\n                        offset: Offset(-screenWidth / 3 * (1 - currentExplorePercent),\n                            screenWidth / 3 / 2 * (1 - currentExplorePercent)),\n                        child: Image.asset(\n                          \"assets/icon_3.png\",\n                          width: realH(133),\n                          height: realH(133),\n                        ),\n                      ),\n                    )\n                  ],\n                ),\n              ),\n              Transform.translate(\n                  offset: Offset(0, realH(23 + 380 * (1 - currentExplorePercent))),\n                  child: Opacity(\n                      opacity: currentExplorePercent,\n                      child: Container(\n                        width: screenWidth,\n                        height: realH(172 + (172 * 4 * (1 - currentExplorePercent))),\n                        child: ListView(\n                          physics: const BouncingScrollPhysics(),\n                          scrollDirection: Axis.horizontal,\n                          children: <Widget>[\n                            Padding(\n                              padding: EdgeInsets.only(left: realW(22)),\n                            ),\n                            buildListItem(0, \"Authentic\\nrestaurant\"),\n                            buildListItem(1, \"Famous\\nmonuments\"),\n                            buildListItem(2, \"Weekend\\ngetaways\"),\n                            buildListItem(3, \"Authentic\\nrestaurant\"),\n                            buildListItem(4, \"Famous\\nmonuments\"),\n                            buildListItem(5, \"Weekend\\ngetaways\"),\n                          ],\n                        ),\n                      ))),\n              Transform.translate(\n                  offset: Offset(0, realH(58 + 570 * (1 - currentExplorePercent))),\n                  child: Opacity(\n                    opacity: currentExplorePercent,\n                    child: Padding(\n                      padding: EdgeInsets.symmetric(horizontal: realW(22)),\n                      child: Column(\n                        crossAxisAlignment: CrossAxisAlignment.start,\n                        mainAxisSize: MainAxisSize.max,\n                        children: <Widget>[\n                          Padding(\n                            padding: EdgeInsets.only(left: realW(22)),\n                            child: Text(\"EVENTS\",\n                                style:\n                                    const TextStyle(color: Colors.white54, fontSize: 13, fontWeight: FontWeight.bold)),\n                          ),\n                          Stack(\n                            children: <Widget>[\n                              Image.asset(\n                                \"assets/dj.png\",\n                              ),\n                              Positioned(\n                                  bottom: realH(26),\n                                  left: realW(24),\n                                  child: Text(\n                                    \"Marshmello Live in Concert\",\n                                    style: TextStyle(color: Colors.white, fontSize: realW(16)),\n                                  ))\n                            ],\n                          ),\n                          Transform.translate(\n                            offset: Offset(0, realH(30 - 30 * (currentExplorePercent - 0.75) * 4)),\n                            child: Row(\n                              children: <Widget>[\n                                Expanded(\n                                  child: Image.asset(\"assets/banner_4.png\"),\n                                ),\n                                Expanded(\n                                  child: Image.asset(\"assets/banner_5.png\"),\n                                ),\n                              ],\n                            ),\n                          )\n                        ],\n                      ),\n                    ),\n                  )),\n              Padding(\n                padding: EdgeInsets.only(bottom: realH(262)),\n              )\n            ],\n          ),\n        ),\n      );\n    } else {\n      return const Padding(\n        padding: const EdgeInsets.all(0),\n      );\n    }\n  }\n\n  buildListItem(int index, String name) {\n    return Transform.translate(\n      offset: Offset(0, index * realH(127) * (1 - currentExplorePercent)),\n      child: Column(\n        mainAxisSize: MainAxisSize.min,\n        children: <Widget>[\n          Image.asset(\n            \"assets/banner_${index % 3 + 1}.png\",\n            width: realH(127),\n            height: realH(127),\n          ),\n          Text(\n            placeName[index % 3],\n            style: TextStyle(color: Colors.white, fontSize: realH(16)),\n            textAlign: TextAlign.center,\n          )\n        ],\n      ),\n    );\n  }\n}\n"
  },
  {
    "path": "lib/components/explore_widget.dart",
    "content": "import 'package:flutter/material.dart';\nimport 'package:flutter_challenge_googlemaps/helper/ui_helper.dart';\n\nclass ExploreWidget extends StatelessWidget {\n  final double currentSearchPercent;\n\n  final double currentExplorePercent;\n\n  final Function(bool) animateExplore;\n\n  final Function(DragUpdateDetails) onVerticalDragUpdate;\n  final Function() onPanDown;\n\n  final bool isExploreOpen;\n\n  const ExploreWidget(\n      {Key key,\n      this.currentSearchPercent,\n      this.currentExplorePercent,\n      this.animateExplore,\n      this.isExploreOpen,\n      this.onVerticalDragUpdate,\n      this.onPanDown})\n      : super(key: key);\n\n  @override\n  Widget build(BuildContext context) {\n    return Positioned(\n        bottom: realH(-122 * currentSearchPercent),\n        left: (screenWidth - realW(159 + (standardWidth - 159) * currentExplorePercent)) / 2,\n        child: GestureDetector(\n          onTap: () {\n            animateExplore(!isExploreOpen);\n          },\n          onVerticalDragUpdate: onVerticalDragUpdate,\n          onVerticalDragEnd: (_) {\n            _dispatchExploreOffset();\n          },\n          onPanDown: (_) => onPanDown(),\n          child: Opacity(\n            opacity: 1 - currentSearchPercent,\n            child: Container(\n              alignment: Alignment.bottomCenter,\n              width: realW(159 + (standardWidth - 159) * currentExplorePercent),\n              height: realH(122 + (766 - 122) * currentExplorePercent),\n              decoration: BoxDecoration(\n                  gradient: LinearGradient(begin: Alignment.topCenter, colors: [\n                    Color(0xFF5496FF),\n                    Color(0xFF8739E5),\n                  ]),\n                  borderRadius: BorderRadius.only(\n                      topLeft: Radius.circular(realW(80 + (50 - 80) * currentExplorePercent)),\n                      topRight: Radius.circular(realW(80 + (50 - 80) * currentExplorePercent)))),\n              child: Stack(\n                children: [\n                  Positioned(\n                      top: realH(65 + (-5 * currentExplorePercent)),\n                      left: realW(49 + (91 - 49) * currentExplorePercent),\n                      child: Text(\n                        \"Explore\",\n                        style: TextStyle(color: Colors.white, fontSize: realW(18 + (32 - 18) * currentExplorePercent)),\n                      )),\n                  Positioned(\n                      top: realH(20 + (60 - 20) * currentExplorePercent),\n                      left: realW(63 + (44 - 63) * currentExplorePercent),\n                      child: Icon(\n                        Icons.location_on,\n                        size: realW(34),\n                        color: Colors.white,\n                      )),\n                  Positioned(\n                      top: realH(currentExplorePercent < 0.9\n                          ? realH(-35)\n                          : realH(-35 + (6 + 35) * (currentExplorePercent - 0.9) * 8)),\n                      left: realW(63 + (170 - 63) * currentExplorePercent),\n                      child: GestureDetector(\n                        onTap: () {\n                          animateExplore(false);\n                        },\n                        child: Image.asset(\n                          \"assets/arrow.png\",\n                          width: realH(35),\n                          height: realH(35),\n                        ),\n                      )),\n                ],\n              ),\n            ),\n          ),\n        ));\n  }\n\n  /// dispatch Explore state\n  ///\n  /// handle it by [isExploreOpen] and [currentExplorePercent]\n  void _dispatchExploreOffset() {\n    if (!isExploreOpen) {\n      if (currentExplorePercent < 0.3) {\n        animateExplore(false);\n      } else {\n        animateExplore(true);\n      }\n    } else {\n      if (currentExplorePercent > 0.6) {\n        animateExplore(true);\n      } else {\n        animateExplore(false);\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "lib/components/map_button.dart",
    "content": "import 'package:flutter/material.dart';\nimport 'package:flutter_challenge_googlemaps/helper/ui_helper.dart';\n\nclass MapButton extends StatelessWidget {\n  final double currentSearchPercent;\n  final double currentExplorePercent;\n\n  final double bottom;\n  final double offsetX;\n  final double width;\n  final double height;\n\n  final IconData icon;\n  final Color iconColor;\n  final bool isRight;\n  final Gradient gradient;\n\n  const MapButton(\n      {Key key,\n      this.currentSearchPercent,\n      this.currentExplorePercent,\n      this.bottom,\n      this.offsetX,\n      this.width,\n      this.height,\n      this.icon,\n      this.iconColor,\n      this.isRight = true,\n      this.gradient})\n      : assert(currentExplorePercent != null),\n        assert(currentExplorePercent != null),\n        assert(bottom != null),\n        assert(offsetX != null),\n        assert(width != null),\n        assert(height != null),\n        assert(icon != null),\n        super(key: key);\n\n  @override\n  Widget build(BuildContext context) {\n    return Positioned(\n      bottom: realH(bottom),\n      left: !isRight ? realW(offsetX * (currentExplorePercent + currentSearchPercent)) : null,\n      right: isRight ? realW(offsetX * (currentExplorePercent + currentSearchPercent)) : null,\n      child: Opacity(\n        opacity: 1 - (currentSearchPercent + currentExplorePercent),\n        child: Container(\n          width: realW(width),\n          height: realH(height),\n          alignment: Alignment.centerLeft,\n          padding: EdgeInsets.only(left: realW(17)),\n          child: Icon(\n            icon,\n            size: realW(34),\n            color: iconColor ?? Colors.black,\n          ),\n          decoration: BoxDecoration(\n              color: gradient == null ? Colors.white : null,\n              gradient: gradient,\n              borderRadius: isRight\n                  ? BorderRadius.only(bottomLeft: Radius.circular(realW(36)), topLeft: Radius.circular(realW(36)))\n                  : BorderRadius.only(bottomRight: Radius.circular(realW(36)), topRight: Radius.circular(realW(36))),\n              boxShadow: [\n                BoxShadow(color: Color.fromRGBO(0, 0, 0, 0.3), blurRadius: realW(36)),\n              ]),\n        ),\n      ),\n    );\n  }\n}\n"
  },
  {
    "path": "lib/components/menu_widget.dart",
    "content": "import 'package:flutter/material.dart';\nimport 'package:flutter_challenge_googlemaps/helper/ui_helper.dart';\n\n/// Drawer Menu\nclass MenuWidget extends StatelessWidget {\n  final menuItems = ['Home', 'Saved', 'Timeline', 'Contributions', 'Messages', 'Sharing', 'Drive Mode'];\n\n  final num currentMenuPercent;\n  final Function(bool) animateMenu;\n\n  MenuWidget({Key key, this.currentMenuPercent, this.animateMenu}) : super(key: key);\n\n  @override\n  Widget build(BuildContext context) {\n    return currentMenuPercent != 0\n        ? Positioned(\n            left: realW(-358 + 358 * currentMenuPercent),\n            width: realW(358),\n            height: screenHeight,\n            child: Opacity(\n              opacity: currentMenuPercent,\n              child: Container(\n                decoration: BoxDecoration(\n                  color: Colors.white,\n                  borderRadius: BorderRadius.only(topRight: Radius.circular(realW(50))),\n                  boxShadow: [\n                    BoxShadow(color: Color.fromRGBO(0, 0, 0, 0.16), blurRadius: realW(20)),\n                  ],\n                ),\n                child: Stack(\n                  children: <Widget>[\n                    NotificationListener<OverscrollIndicatorNotification>(\n                      onNotification: (notification) {\n                        notification.disallowGlow();\n                      },\n                      child: CustomScrollView(\n                        physics: NeverScrollableScrollPhysics(),\n                        slivers: <Widget>[\n                          SliverToBoxAdapter(\n                            child: Container(\n                              height: realH(236),\n                              decoration: BoxDecoration(\n                                  borderRadius: BorderRadius.only(topRight: Radius.circular(realW(50))),\n                                  gradient: const LinearGradient(begin: Alignment.topLeft, colors: [\n                                    Color(0xFF59C2FF),\n                                    Color(0xFF1270E3),\n                                  ])),\n                              child: Stack(\n                                children: <Widget>[\n                                  Positioned(\n                                    left: realW(10),\n                                    bottom: realH(27),\n                                    child: Image.asset(\n                                      \"assets/avatar.png\",\n                                      width: realH(120),\n                                      height: realH(120),\n                                    ),\n                                  ),\n                                  Positioned(\n                                    left: realW(60),\n                                    bottom: realH(18),\n                                    child: Image.asset(\n                                      \"assets/lable.png\",\n                                      width: realH(72),\n                                      height: realH(72),\n                                    ),\n                                  ),\n                                  Positioned(\n                                    left: realW(135),\n                                    top: realH(110),\n                                    child: DefaultTextStyle(\n                                      style: TextStyle(color: Colors.white),\n                                      child: Column(\n                                        mainAxisSize: MainAxisSize.min,\n                                        crossAxisAlignment: CrossAxisAlignment.start,\n                                        children: <Widget>[\n                                          Text(\n                                            \"implemented by ditclear\",\n                                            style: TextStyle(fontWeight: FontWeight.bold, fontSize: realW(18)),\n                                          ),\n                                          Padding(\n                                            padding: EdgeInsets.symmetric(vertical: realH(11.0)),\n                                            child: FittedBox(\n                                              fit: BoxFit.scaleDown,\n                                              child: Text.rich(\n                                                TextSpan(\n                                                  text: \"https://github.com/ditclear\",\n                                                  style: TextStyle(\n                                                      fontSize: realW(16), decoration: TextDecoration.underline),\n                                                ),\n                                              ),\n                                            ),\n                                          ),\n                                          Row(\n                                            children: <Widget>[\n                                              Text(\n                                                \"公众号：ditclear\",\n                                                style: TextStyle(fontSize: realW(14)),\n                                              ),\n                                              Icon(\n                                                Icons.arrow_right,\n                                                color: Colors.white,\n                                                size: realH(30),\n                                              )\n                                            ],\n                                          ),\n                                        ],\n                                      ),\n                                    ),\n                                  ),\n                                ],\n                              ),\n                            ),\n                          ),\n                          SliverPadding(\n                            padding: EdgeInsets.only(top: realH(34), bottom: realH(50), right: realW(37)),\n                            sliver: SliverFixedExtentList(\n                              itemExtent: realH(56),\n                              delegate: new SliverChildBuilderDelegate((BuildContext context, int index) {\n                                //创建列表项\n                                return Container(\n                                  width: realW(321),\n                                  alignment: Alignment.centerLeft,\n                                  padding: EdgeInsets.only(left: realW(20)),\n                                  decoration: index == 0\n                                      ? BoxDecoration(\n                                          color: Color(0xFF379BF2).withOpacity(0.2),\n                                          borderRadius: BorderRadius.only(\n                                              topRight: Radius.circular(realW(50)),\n                                              bottomRight: Radius.circular(realW(50))))\n                                      : null,\n                                  child: Text(\n                                    menuItems[index],\n                                    style:\n                                        TextStyle(color: index == 0 ? Colors.blue : Colors.black, fontSize: realW(20)),\n                                  ),\n                                );\n                              }, childCount: menuItems.length),\n                            ),\n                          ),\n                          SliverPadding(\n                            padding: EdgeInsets.only(left: realW(20)),\n                            sliver: SliverToBoxAdapter(\n                              child: Text(\n                                'Settings',\n                                style: TextStyle(color: Colors.black, fontSize: realW(20)),\n                              ),\n                            ),\n                          )\n                        ],\n                      ),\n                    ),\n                    // close button\n                    Positioned(\n                      bottom: realH(53),\n                      right: 0,\n                      child: GestureDetector(\n                        onTap: () {\n                          animateMenu(false);\n                        },\n                        child: Container(\n                          width: realW(71),\n                          height: realH(71),\n                          alignment: Alignment.centerLeft,\n                          padding: EdgeInsets.only(left: realW(17)),\n                          child: Icon(\n                            Icons.close,\n                            color: Color(0xFFE96977),\n                            size: realW(34),\n                          ),\n                          decoration: BoxDecoration(\n                            color: Color(0xFFFB5E74).withOpacity(0.2),\n                            borderRadius: BorderRadius.only(\n                                bottomLeft: Radius.circular(realW(36)), topLeft: Radius.circular(realW(36))),\n                          ),\n                        ),\n                      ),\n                    )\n                  ],\n                ),\n              ),\n            ),\n          )\n        : const Padding(padding: EdgeInsets.all(0));\n  }\n}\n"
  },
  {
    "path": "lib/components/recent_search_widget.dart",
    "content": "import 'package:flutter/material.dart';\nimport 'package:flutter_challenge_googlemaps/helper/ui_helper.dart';\n\nclass RecentSearchWidget extends StatelessWidget {\n  final double currentSearchPercent;\n\n  const RecentSearchWidget({Key key, this.currentSearchPercent}) : super(key: key);\n\n  @override\n  Widget build(BuildContext context) {\n    return currentSearchPercent != 0\n        ? Positioned(\n            top: realH(-(75.0 + 494.0) + (75 + 75.0 + 494.0) * currentSearchPercent),\n            left: realW((standardWidth - 320) / 2),\n            width: realW(320),\n            height: realH(494),\n            child: Opacity(\n              opacity: currentSearchPercent,\n              child: Align(\n                alignment: Alignment.topCenter,\n                child: Image.asset(\n                  \"assets/recent.png\",\n                  fit: BoxFit.contain,\n                ),\n              ),\n            ),\n          )\n        : const Padding(\n            padding: const EdgeInsets.all(0),\n          );\n  }\n}\n"
  },
  {
    "path": "lib/components/search_back_widget.dart",
    "content": "import 'package:flutter/material.dart';\nimport 'package:flutter_challenge_googlemaps/helper/ui_helper.dart';\n\nclass SearchBackWidget extends StatelessWidget {\n  final double currentSearchPercent;\n\n  final Function(bool) animateSearch;\n\n  const SearchBackWidget({Key key, this.currentSearchPercent, this.animateSearch}) : super(key: key);\n\n  @override\n  Widget build(BuildContext context) {\n    return Positioned(\n      bottom: realH(53),\n      right: realW(27),\n      child: Opacity(\n        opacity: currentSearchPercent,\n        child: Container(\n          width: realW(320),\n          height: realH(71),\n          alignment: Alignment.centerLeft,\n          padding: EdgeInsets.only(left: realW(17)),\n          child: Row(\n            children: <Widget>[\n              InkWell(\n                onTap: () {\n                  animateSearch(false);\n                },\n                child: Transform.scale(\n                  scale: currentSearchPercent,\n                  child: Icon(\n                    Icons.arrow_back,\n                    size: realW(34),\n                  ),\n                ),\n              ),\n              Expanded(\n                child: Padding(\n                  padding: EdgeInsets.symmetric(horizontal: realW(30.0)),\n                  child: TextField(\n                    enabled: currentSearchPercent == 1.0,\n                    cursorColor: Color(0xFF707070),\n                    decoration: InputDecoration(\n                      hintText: \"Search here\",\n                      alignLabelWithHint: true,\n                      border: InputBorder.none,\n                    ),\n                    style: TextStyle(fontSize: realW(22)),\n                  ),\n                ),\n              )\n            ],\n          ),\n        ),\n      ),\n    );\n  }\n}\n"
  },
  {
    "path": "lib/components/search_menu_widget.dart",
    "content": "import 'package:flutter/material.dart';\nimport 'package:flutter_challenge_googlemaps/helper/ui_helper.dart';\n\nclass SearchMenuWidget extends StatelessWidget {\n  final double currentSearchPercent;\n\n  const SearchMenuWidget({Key key, this.currentSearchPercent}) : super(key: key);\n\n  @override\n  Widget build(BuildContext context) {\n    return currentSearchPercent != 0\n        ? Positioned(\n            bottom: realH(58 + (144 - 58) * currentSearchPercent),\n            left: realW((standardWidth - 320) / 2),\n            width: realW(320),\n            height: realH(60),\n            child: Opacity(\n                opacity: currentSearchPercent,\n                child: Padding(\n                  padding: EdgeInsets.symmetric(horizontal: realW(20.0)),\n                  child: Row(\n                    children: <Widget>[\n                      _buildSearchMenuItem(Icons.home, \"Home\"),\n                      Padding(\n                        padding: EdgeInsets.only(left: realW(16)),\n                      ),\n                      _buildSearchMenuItem(Icons.work, \"Work\")\n                    ],\n                  ),\n                )),\n          )\n        : const Padding(\n            padding: const EdgeInsets.all(0),\n          );\n  }\n\n  _buildSearchMenuItem(IconData icon, String text) {\n    return Expanded(\n        child: Container(\n      width: realW(130),\n      height: realH(60),\n      padding: EdgeInsets.only(left: realW(17)),\n      child: Row(\n        children: <Widget>[\n          Icon(\n            icon,\n            size: realW(30),\n            color: Colors.blue,\n          ),\n          Padding(\n            padding: EdgeInsets.only(left: realW(12)),\n          ),\n          Text(\n            text,\n            style: TextStyle(color: Colors.blue, fontSize: realW(18)),\n          )\n        ],\n      ),\n      decoration: BoxDecoration(\n        color: const Color(0xFF379BF2).withOpacity(0.2),\n        borderRadius: BorderRadius.all(Radius.circular(realW(30))),\n      ),\n    ));\n  }\n}\n"
  },
  {
    "path": "lib/components/search_widget.dart",
    "content": "import 'package:flutter/material.dart';\nimport 'package:flutter_challenge_googlemaps/helper/ui_helper.dart';\n\nclass SearchWidget extends StatelessWidget {\n  final double currentExplorePercent;\n\n  final double currentSearchPercent;\n\n  final Function(bool) animateSearch;\n\n  final bool isSearchOpen;\n\n  final Function(DragUpdateDetails) onHorizontalDragUpdate;\n\n  final Function() onPanDown;\n\n  const SearchWidget(\n      {Key key,\n      this.currentExplorePercent,\n      this.currentSearchPercent,\n      this.animateSearch,\n      this.isSearchOpen,\n      this.onHorizontalDragUpdate,\n      this.onPanDown})\n      : super(key: key);\n\n  @override\n  Widget build(BuildContext context) {\n    return Positioned(\n      bottom: realH(53),\n      right: realW((68.0 - 320) - (68.0 * currentExplorePercent) + (347 - 68.0) * currentSearchPercent),\n      child: GestureDetector(\n        onTap: () {\n          animateSearch(!isSearchOpen);\n        },\n        onPanDown: (_) => onPanDown,\n        onHorizontalDragUpdate: onHorizontalDragUpdate,\n        onHorizontalDragEnd: (_) {\n          _dispatchSearchOffset();\n        },\n        child: Container(\n          width: realW(320),\n          height: realH(71),\n          alignment: Alignment.centerLeft,\n          padding: EdgeInsets.only(left: realW(17)),\n          child: Opacity(\n            opacity: 1.0 - currentSearchPercent,\n            child: Icon(\n              Icons.search,\n              size: realW(34),\n            ),\n          ),\n          decoration: BoxDecoration(\n              color: Colors.white,\n              borderRadius: BorderRadius.all(Radius.circular(realW(36))),\n              boxShadow: [\n                BoxShadow(color: Color.fromRGBO(0, 0, 0, 0.3), blurRadius: realW(36)),\n              ]),\n        ),\n      ),\n    );\n  }\n\n  /// dispatch Search state\n  ///\n  /// handle it by [isSearchOpen] and [currentSearchPercent]\n  void _dispatchSearchOffset() {\n    if (!isSearchOpen) {\n      if (currentSearchPercent < 0.3) {\n        animateSearch(false);\n      } else {\n        animateSearch(true);\n      }\n    } else {\n      if (currentSearchPercent > 0.6) {\n        animateSearch(true);\n      } else {\n        animateSearch(false);\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "lib/helper/ui_helper.dart",
    "content": "import 'dart:core';\n\n/// ui standard\nfinal standardWidth = 375.0;\nfinal standardHeight = 815.0;\n\n/// late init\ndouble screenWidth;\ndouble screenHeight;\n\n/// scale [height] by [standardHeight]\ndouble realH(double height) {\n  assert(screenHeight != 0.0);\n  return height / standardHeight * screenHeight;\n}\n\n// scale [width] by [ standardWidth ]\ndouble realW(double width) {\n  assert(screenWidth != 0.0);\n  return width / standardWidth * screenWidth;\n}\n"
  },
  {
    "path": "lib/home_page.dart",
    "content": "import 'dart:math';\nimport 'dart:ui';\n\nimport 'package:flutter/cupertino.dart';\nimport 'package:flutter/material.dart';\nimport 'package:flutter/services.dart';\n\nimport 'components/components.dart';\nimport 'helper/ui_helper.dart';\n\nclass GoogleMapPage extends StatefulWidget {\n  GoogleMapPage();\n\n  @override\n  State<StatefulWidget> createState() {\n    return _GoogleMapState();\n  }\n}\n\nclass _GoogleMapState extends State<GoogleMapPage> with TickerProviderStateMixin {\n  AnimationController animationControllerExplore;\n  AnimationController animationControllerSearch;\n  AnimationController animationControllerMenu;\n  CurvedAnimation curve;\n  Animation<double> animation;\n  Animation<double> animationW;\n  Animation<double> animationR;\n\n  /// get currentOffset percent\n  get currentExplorePercent => max(0.0, min(1.0, offsetExplore / (760.0 - 122.0)));\n  get currentSearchPercent => max(0.0, min(1.0, offsetSearch / (347 - 68.0)));\n  get currentMenuPercent => max(0.0, min(1.0, offsetMenu / 358));\n\n  var offsetExplore = 0.0;\n  var offsetSearch = 0.0;\n  var offsetMenu = 0.0;\n\n  bool isExploreOpen = false;\n  bool isSearchOpen = false;\n  bool isMenuOpen = false;\n\n  /// search drag callback\n  void onSearchHorizontalDragUpdate(details) {\n    offsetSearch -= details.delta.dx;\n    if (offsetSearch < 0) {\n      offsetSearch = 0;\n    } else if (offsetSearch > (347 - 68.0)) {\n      offsetSearch = 347 - 68.0;\n    }\n    setState(() {});\n  }\n\n  /// explore drag callback\n  void onExploreVerticalUpdate(details) {\n    offsetExplore -= details.delta.dy;\n    if (offsetExplore > 644) {\n      offsetExplore = 644;\n    } else if (offsetExplore < 0) {\n      offsetExplore = 0;\n    }\n    setState(() {});\n  }\n\n  /// animate Explore\n  ///\n  /// if [open] is true , make Explore open\n  /// else make Explore close\n  void animateExplore(bool open) {\n    animationControllerExplore = AnimationController(\n        duration: Duration(\n            milliseconds: 1 + (800 * (isExploreOpen ? currentExplorePercent : (1 - currentExplorePercent))).toInt()),\n        vsync: this);\n    curve = CurvedAnimation(parent: animationControllerExplore, curve: Curves.ease);\n    animation = Tween(begin: offsetExplore, end: open ? 760.0 - 122 : 0.0).animate(curve)\n      ..addListener(() {\n        setState(() {\n          offsetExplore = animation.value;\n        });\n      })\n      ..addStatusListener((status) {\n        if (status == AnimationStatus.completed) {\n          isExploreOpen = open;\n        }\n      });\n    animationControllerExplore.forward();\n  }\n\n  void animateSearch(bool open) {\n    animationControllerSearch = AnimationController(\n        duration: Duration(\n            milliseconds: 1 + (800 * (isSearchOpen ? currentSearchPercent : (1 - currentSearchPercent))).toInt()),\n        vsync: this);\n    curve = CurvedAnimation(parent: animationControllerSearch, curve: Curves.ease);\n    animation = Tween(begin: offsetSearch, end: open ? 347.0 - 68.0 : 0.0).animate(curve)\n      ..addListener(() {\n        setState(() {\n          offsetSearch = animation.value;\n        });\n      })\n      ..addStatusListener((status) {\n        if (status == AnimationStatus.completed) {\n          isSearchOpen = open;\n        }\n      });\n    animationControllerSearch.forward();\n  }\n\n  void animateMenu(bool open) {\n    animationControllerMenu = AnimationController(duration: Duration(milliseconds: 500), vsync: this);\n    curve = CurvedAnimation(parent: animationControllerMenu, curve: Curves.ease);\n    animation = Tween(begin: open ? 0.0 : 358.0, end: open ? 358.0 : 0.0).animate(curve)\n      ..addListener(() {\n        setState(() {\n          offsetMenu = animation.value;\n        });\n      })\n      ..addStatusListener((status) {\n        if (status == AnimationStatus.completed) {\n          isMenuOpen = open;\n        }\n      });\n    animationControllerMenu.forward();\n  }\n\n  @override\n  Widget build(BuildContext context) {\n    screenWidth = MediaQuery.of(context).size.width;\n    screenHeight = MediaQuery.of(context).size.height;\n    return Scaffold(\n      body: SizedBox(\n        width: screenWidth,\n        height: screenHeight,\n        child: Stack(\n          children: <Widget>[\n            Image.asset(\n              \"assets/map.png\",\n              width: screenWidth,\n              height: screenHeight,\n              fit: BoxFit.cover,\n            ),\n            //explore\n            ExploreWidget(\n              currentExplorePercent: currentExplorePercent,\n              currentSearchPercent: currentSearchPercent,\n              animateExplore: animateExplore,\n              isExploreOpen: isExploreOpen,\n              onVerticalDragUpdate: onExploreVerticalUpdate,\n              onPanDown: () => animationControllerExplore?.stop(),\n            ),\n            //blur\n            offsetSearch != 0\n                ? BackdropFilter(\n                    filter: ImageFilter.blur(sigmaX: 10 * currentSearchPercent, sigmaY: 10 * currentSearchPercent),\n                    child: Container(\n                      color: Colors.white.withOpacity(0.1 * currentSearchPercent),\n                      width: screenWidth,\n                      height: screenHeight,\n                    ),\n                  )\n                : const Padding(\n                    padding: const EdgeInsets.all(0),\n                  ),\n            //explore content\n            ExploreContentWidget(\n              currentExplorePercent: currentExplorePercent,\n            ),\n            //recent search\n            RecentSearchWidget(\n              currentSearchPercent: currentSearchPercent,\n            ),\n            //search menu background\n            offsetSearch != 0\n                ? Positioned(\n                    bottom: realH(88),\n                    left: realW((standardWidth - 320) / 2),\n                    width: realW(320),\n                    height: realH(135 * currentSearchPercent),\n                    child: Opacity(\n                      opacity: currentSearchPercent,\n                      child: DecoratedBox(\n                        decoration: BoxDecoration(\n                            color: Colors.white,\n                            borderRadius: BorderRadius.only(\n                                topLeft: Radius.circular(realW(33)), topRight: Radius.circular(realW(33)))),\n                      ),\n                    ),\n                  )\n                : const Padding(\n                    padding: const EdgeInsets.all(0),\n                  ),\n            //search menu\n            SearchMenuWidget(\n              currentSearchPercent: currentSearchPercent,\n            ),\n            //search\n            SearchWidget(\n              currentSearchPercent: currentSearchPercent,\n              currentExplorePercent: currentExplorePercent,\n              isSearchOpen: isSearchOpen,\n              animateSearch: animateSearch,\n              onHorizontalDragUpdate: onSearchHorizontalDragUpdate,\n              onPanDown: () => animationControllerSearch?.stop(),\n            ),\n            //search back\n            SearchBackWidget(\n              currentSearchPercent: currentSearchPercent,\n              animateSearch: animateSearch,\n            ),\n            //layer button\n            MapButton(\n              currentExplorePercent: currentExplorePercent,\n              currentSearchPercent: currentSearchPercent,\n              bottom: 243,\n              offsetX: -71,\n              width: 71,\n              height: 71,\n              isRight: false,\n              icon: Icons.layers,\n            ),\n            //directions button\n            MapButton(\n              currentSearchPercent: currentSearchPercent,\n              currentExplorePercent: currentExplorePercent,\n              bottom: 243,\n              offsetX: -68,\n              width: 68,\n              height: 71,\n              icon: Icons.directions,\n              iconColor: Colors.white,\n              gradient: const LinearGradient(colors: [\n                Color(0xFF59C2FF),\n                Color(0xFF1270E3),\n              ]),\n            ),\n            //my_location button\n            MapButton(\n              currentSearchPercent: currentSearchPercent,\n              currentExplorePercent: currentExplorePercent,\n              bottom: 148,\n              offsetX: -68,\n              width: 68,\n              height: 71,\n              icon: Icons.my_location,\n              iconColor: Colors.blue,\n            ),\n            //menu button\n            Positioned(\n              bottom: realH(53),\n              left: realW(-71 * (currentExplorePercent + currentSearchPercent)),\n              child: GestureDetector(\n                onTap: () {\n                  animateMenu(true);\n                },\n                child: Opacity(\n                  opacity: 1 - (currentSearchPercent + currentExplorePercent),\n                  child: Container(\n                    width: realW(71),\n                    height: realH(71),\n                    alignment: Alignment.centerLeft,\n                    padding: EdgeInsets.only(left: realW(17)),\n                    child: Icon(\n                      Icons.menu,\n                      size: realW(34),\n                    ),\n                    decoration: BoxDecoration(\n                        color: Colors.white,\n                        borderRadius: BorderRadius.only(\n                            bottomRight: Radius.circular(realW(36)), topRight: Radius.circular(realW(36))),\n                        boxShadow: [\n                          BoxShadow(color: Color.fromRGBO(0, 0, 0, 0.3), blurRadius: realW(36)),\n                        ]),\n                  ),\n                ),\n              ),\n            ),\n            //menu\n            MenuWidget(currentMenuPercent: currentMenuPercent, animateMenu: animateMenu),\n          ],\n        ),\n      ),\n    );\n  }\n\n  @override\n  void initState() {\n    super.initState();\n    SystemChrome.setEnabledSystemUIOverlays([]);\n  }\n\n  @override\n  void dispose() {\n    super.dispose();\n    animationControllerExplore?.dispose();\n    animationControllerSearch?.dispose();\n    animationControllerMenu?.dispose();\n  }\n}\n"
  },
  {
    "path": "lib/main.dart",
    "content": "import 'package:flutter/material.dart';\n\nimport 'home_page.dart';\n\nvoid main() => runApp(MyApp());\n\nclass MyApp extends StatelessWidget {\n  // This widget is the root of your application.\n  @override\n  Widget build(BuildContext context) {\n    return MaterialApp(\n      title: 'Flutter Demo',\n      theme: ThemeData(\n        // This is the theme of your application.\n        //\n        // Try running your application with \"flutter run\". You'll see the\n        // application has a blue toolbar. Then, without quitting the app, try\n        // changing the primarySwatch below to Colors.green and then invoke\n        // \"hot reload\" (press \"r\" in the console where you ran \"flutter run\",\n        // or simply save your changes to \"hot reload\" in a Flutter IDE).\n        // Notice that the counter didn't reset back to zero; the application\n        // is not restarted.\n        primaryColor: Color(0xFF707070),\n      ),\n      home: GoogleMapPage(),\n    );\n  }\n}\n"
  },
  {
    "path": "pubspec.yaml",
    "content": "name: flutter_challenge_googlemaps\ndescription: rework the UI of the Google Maps in uplabs by Flutter.\n\n# The following defines the version and build number for your application.\n# A version number is three numbers separated by dots, like 1.2.43\n# followed by an optional build number separated by a +.\n# Both the version and the builder number may be overridden in flutter\n# build by specifying --build-name and --build-number, respectively.\n# In Android, build-name is used as versionName while build-number used as versionCode.\n# Read more about Android versioning at https://developer.android.com/studio/publish/versioning\n# In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion.\n# Read more about iOS versioning at\n# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html\nversion: 1.0.0+1\n\nenvironment:\n  sdk: \">=2.1.0 <3.0.0\"\n\ndependencies:\n  flutter:\n    sdk: flutter\n\n  # The following adds the Cupertino Icons font to your application.\n  # Use with the CupertinoIcons class for iOS style icons.\n  cupertino_icons: ^0.1.2\n\ndev_dependencies:\n  flutter_test:\n    sdk: flutter\n\n\n# For information on the generic Dart part of this file, see the\n# following page: https://www.dartlang.org/tools/pub/pubspec\n\n# The following section is specific to Flutter.\nflutter:\n\n  # The following line ensures that the Material Icons font is\n  # included with your application, so that you can use the icons in\n  # the material Icons class.\n  uses-material-design: true\n\n  # To add assets to your application, add an assets section, like this:\n  assets:\n     - arrow.png\n     - banner_1.png\n     - banner_2.png\n     - banner_3.png\n     - banner_4.png\n     - banner_5.png\n     - dj.png\n     - icon_1.png\n     - icon_2.png\n     - icon_3.png\n     - map.png\n     - recent.png\n     - search.png\n     - avatar.png\n     - lable.png\n\n  # An image asset can refer to one or more resolution-specific \"variants\", see\n  # https://flutter.dev/assets-and-images/#resolution-aware.\n\n  # For details regarding adding assets from package dependencies, see\n  # https://flutter.dev/assets-and-images/#from-packages\n\n  # To add custom fonts to your application, add a fonts section here,\n  # in this \"flutter\" section. Each entry in this list should have a\n  # \"family\" key with the font family name, and a \"fonts\" key with a\n  # list giving the asset and other descriptors for the font. For\n  # example:\n  # fonts:\n  #   - family: Schyler\n  #     fonts:\n  #       - asset: fonts/Schyler-Regular.ttf\n  #       - asset: fonts/Schyler-Italic.ttf\n  #         style: italic\n  #   - family: Trajan Pro\n  #     fonts:\n  #       - asset: fonts/TrajanPro.ttf\n  #       - asset: fonts/TrajanPro_Bold.ttf\n  #         weight: 700\n  #\n  # For details regarding fonts from package dependencies,\n  # see https://flutter.dev/custom-fonts/#from-packages\n"
  },
  {
    "path": "test/widget_test.dart",
    "content": "// This is a basic Flutter widget test.\n//\n// To perform an interaction with a widget in your test, use the WidgetTester\n// utility that Flutter provides. For example, you can send tap and scroll\n// gestures. You can also use WidgetTester to find child widgets in the widget\n// tree, read text, and verify that the values of widget properties are correct.\n\nimport 'package:flutter/material.dart';\nimport 'package:flutter_test/flutter_test.dart';\n\nimport 'package:flutter_challenge_googlemaps/main.dart';\n\nvoid main() {\n  testWidgets('Counter increments smoke test', (WidgetTester tester) async {\n    // Build our app and trigger a frame.\n    await tester.pumpWidget(MyApp());\n\n    // Verify that our counter starts at 0.\n    expect(find.text('0'), findsOneWidget);\n    expect(find.text('1'), findsNothing);\n\n    // Tap the '+' icon and trigger a frame.\n    await tester.tap(find.byIcon(Icons.add));\n    await tester.pump();\n\n    // Verify that our counter has incremented.\n    expect(find.text('0'), findsNothing);\n    expect(find.text('1'), findsOneWidget);\n  });\n}\n"
  }
]