Skip to content

An open-source Android app employing MVVM architecture and Jetpack Compose. Enhance family safety with real-time location sharing.

Notifications You must be signed in to change notification settings

canopas/group-track-android

Repository files navigation

GroupTrack - Stay connected, Anywhere!

Enhancing family safety and communication with real-time location sharing and modern UIs.

cover

Overview

Welcome to GroupTrack, an open-source Android application designed to enhance family safety through real-time location sharing and communication features. GroupTrack aims to provide peace of mind by ensuring the safety of your loved ones and facilitating seamless communication regardless of their location.

GroupTrack adopts the MVVM architecture pattern and leverages Jetpack Compose for building modern UIs declaratively. This architecture ensures a clear separation of concerns, making the codebase more maintainable and testable. Jetpack Compose simplifies UI development by allowing developers to define UI elements and their behavior in a more intuitive way, resulting in a seamless user experience.

Download App

Features

GroupTrack is currently in active development 🚧, with plans to incorporate additional features shortly.

GroupTrack ensures your loved ones' well-being with:

  • Real-time Location Sharing
  • Secure Communication
  • Location History with Routes
  • Geo-fencing
  • SOS Help Alert

Screenshots

Create/Join Space Share Location Location History
Family Safety At Your Fingertips Say Goodbye to 'Where are You?' Texts Always Track Your Loved Ones
Geofencing Communication
Customize Your Places According to Your Needs Chat with Your Loved Ones Anytime, Anywhere

Requirements

Make sure you have the latest stable version of Android Studio installed. You can then proceed by either cloning this repository or importing the project directly into Android Studio, following the steps provided in the documentation.

Click to expand

Google Maps SDK

To enable the MapView functionality, obtaining an API key as instructed in the documentation is required. This key should then be included in the local.properties file as follows:

MAPS_API_KEY=your_map_api_key

Firebase Setup

To enable Firebase services, you will need to create a new project in the Firebase Console. Use the applicationId value specified in the app/build.gradle file of the app as the Android package name. Once the project is created, you will need to add the google-services.json file to the app module. For more information, refer to the Firebase documentation.

GroupTrack uses the following Firebase services, Make sure you enable them in your Firebase project:

  • Authentication (Phone, Google)
  • Firestore (To store user data)

Tech stack

GroupTrack utilizes the latest Android technologies and adheres to industry best practices. Below is the current tech stack used in the development process:

  • MVVM Architecture
  • Jetpack Compose
  • Kotlin
  • Coroutines + Flow
  • Jetpack Navigation
  • Retrofit
  • Fusion Location Provider
  • Google Maps SDK
  • DataStore
  • Room Database
  • Firebase Authentication
  • Firebase Firestore
  • Cloud Functions
  • Google Maps SDK
  • Hilt

Contribution

Currently, we are not accepting any contributions.

Credits

GroupTrack is owned and maintained by the Canopas team. You can follow them on Twitter at @canopas_eng for project updates and releases. If you are interested in building apps or designing products, please let us know. We'd love to hear from you!

License

GroupTrack is licensed under the Apache License, Version 2.0.

Copyright 2024 Canopas Software LLP

Licensed under the Apache License, Version 2.0 (the "License");
You won't be using this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.