GroFresh

Mandatory setup

Info

Same documentation for all related projects like Delivery man

Run an existing flutter project on IDE #

You can generate an app icon from this website https://app icon.co.

  • Go to <project>/assets/image/ and replace logo.png with your own logo.
  • Then go to /android/app/src/main/res and replace all Mipmap folders with your <generated icon>/android folder.
  • Again go to /ios/Runner and replace Assets.xcassets with your generated Assets.xcassets folder.

TIP

Recommended tutorial is below 👇

Change App Name #

  • You need to set your app name in three different places. Open <project>/lib/util/app_constrants.dart and set the value of APP_NAME

/lib/util/app_constrants.dart

static const String APP_NAME =My App;
  • Change the value of the label from <project>/android/app/src/main/AndroidManifest.xml

/android/app/src/main/AndroidManifest.xml

android:label="My App"
  • Change the value of CFBundleName from <project>/iOS/Runner/info.plist

/iOS/Runner/info.plist

<key>CFBundleName</key>
<string>My App</string>

TIP

Recommended tutorial is below 👇

Change Base URL #

Must remember that don’t put slash(/) at the end of your base URL. Use your admin URL as base URL. First, you have to install your admin panel. For example: If your admin url is https://your_domain.com/admin then the base URL will be https://your_domain.com. Open /lib/util/app_constrants.dart and replace BASE_URL variable value with your own URL.

/lib/util/app_constrants.dart

static const String BASE_URL = 'https://your_domain.com';

TIP

Recommended tutorial is below 👇

Change App Package #

First you have to find out the existing package name. You can find it out from top of /app/src/main/AndroidManifest.xml file. Now right click on project folder from android studio and click on replace in path. You will get a popup window with two input box. In first box you have to put existing package name that you saw in AndroidManifest.xml file previously and write down your preferred package name in second box and then click on Replace All button.

TIP

Recommended tutorial is below 👇

Setup Firebase for Push Notification #

First, you have to change your package name. If you didn’t then follow this.

WARNING

Do not create multiple projects if you have multiple apps like User App and Delivery App. Create only one project and add multiple apps under the project.

  • Click register app and download google-services.json file from there.
  • Copy that file and paste it under <project>/android/app/ folder.
  • Create a totally white png logo for notification icon. Paste it on <project>/android/app/src/main/res/drawable/ and replace notification_icon.png with your whiter version logo.
  • For IOS again create an app under the same project and download GoogleService-Info.plist and paste it under <project>/iOS/ folder. Also follow this documentation for full setup for IOS: https://firebase.flutter.dev/docs/messaging/apple-integration
  • Paste the Firebase server key in the admin panel Notification Settings section. You can get the server key from Firebase project settings->Cloud Messaging->Server Key.

After your setup please restart your IDE and uninstall your previously installed app then run it. Also, don’t try to test it on an emulator or simulator. Emulators and simulators are unable to get push. Use a real device in this case.

TIP

Recommended tutorial is below 👇

Add Google Map API Key #

For Android, open <project>/android/app/src/main/AndroidManifest.xml and place the value of com.google.android.geo.API_KEY

/android/app/src/main/AndroidManifest.xml

<meta-data android:name="com.google.android.geo.API_KEY" android:value=“YOUR_MAP_API_KEY_HERE”/>

For iOS: open <project>/iOS/Runner/AppDelegate.swift and place the value of GMSServices.provideAPIKey

/iOS/Runner/AppDelegate.swift

GMSServices.provideAPIKey(“YOUR_MAP_API_KEY_HERE")

For web: open <project>/web/index.html and place the value of https://maps.googleapis.com/maps/api/js?key

/web/index.html

<script src="https://maps.googleapis.com/maps/api/js?key=YOUR_MAP_API_KEY_HERE"></script>

TIP

Recommended tutorial is below 👇