# Frontend The frontend of this project is a Flutter application designed to run on both Android and iOS devices (and possibly as a PWA). The frontend is responsible for displaying the user interface and handling user input. It communicates with the backend via a REST-api to retrieve and send data. ## Getting Started The flutter application is divided into multiple chunks of code. - the `lib` directory contains the main code of the application. - the `android` and `ios` directories contain platform-specific code. - the root directory contains configuration files and metadata. To run the application, you need to have the Flutter SDK installed. You can find instructions on how to do this [here](https://flutter.dev/docs/get-started/install). Once you have the Flutter SDK installed, you can locally install the dependencies by running: ```bash flutter pub get ``` ## Development ### ... ### Icons and logos The application uses a custom launcher icon and splash screen. These are managed platform-independently using the `flutter_launcher_icons` package. To update the icons, change the `flutter_launcher_icons.yaml` configuration file. Especially the `image_path` is relevant. Then run ```bash dart run flutter_launcher_icons ``` ### Deploying a new version To truly deploy a new version of the application, i.e. to the official app stores, a special CI step is required. This listens for new tags. To create a new tag position yourself on the main branch and run ```bash git tag -a v -m "Release " git push origin v ``` We adhere to the [Semantic Versioning](https://semver.org/) standard, so the tag should be of the form `v0.1.8` for example. ## Fastlane - in depth The application is deployed to the Google Play Store and the Apple App Store using fastlane: [https://docs.fastlane.tools/](https://docs.fastlane.tools/) Fastlane is installed as a Ruby gem. Since the bundler-gemfile is scoped to a single directory, a `Gemfile` is included in both the `android` and `ios` directories. Once installed, the usage is ```bash cd frontend/android # or ios bundle install bundle exec fastlane ``` This is reused in the CI/CD pipeline to automate the deployment process. Secrets used by fastlane are stored on hashicorp vault and are fetched by the CI/CD pipeline. See below. ## Secrets These are mostly used by the CI/CD pipeline to deploy the application. The main usage for github actions is documented under [https://github.com/hashicorp/vault-action](https://github.com/hashicorp/vault-action). **Platform-specific secrets** are used by the CI/CD pipeline to deploy to the respective app stores. - `GOOGLE_MAPS_API_KEY` is used to authenticate with the Google Maps API and is scoped to the android platform - `ANDROID_KEYSTORE` is used to sign the android apk - `ANDROID_GOOGLE_KEY` is used to authenticate with the Google Play Store api - `IOS_GOOGLE_MAPS_API_KEY` is used to authenticate with the Google Maps API and is scoped to the ios platform - `IOS_GOOGLE_...` - `IOS_GOOGLE_...` - `IOS_GOOGLE_...`