Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marcossevilla/pass_app
A full-stack application to show Apple PassKit functionality.
https://github.com/marcossevilla/pass_app
dart dartfrog flutter full-stack passkit
Last synced: 1 day ago
JSON representation
A full-stack application to show Apple PassKit functionality.
- Host: GitHub
- URL: https://github.com/marcossevilla/pass_app
- Owner: marcossevilla
- Created: 2024-11-14T11:50:30.000Z (2 months ago)
- Default Branch: main
- Last Pushed: 2024-12-19T11:55:39.000Z (about 1 month ago)
- Last Synced: 2024-12-31T20:07:50.632Z (25 days ago)
- Topics: dart, dartfrog, flutter, full-stack, passkit
- Language: Dart
- Homepage:
- Size: 1.69 MB
- Stars: 5
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Pass App
![coverage][coverage_badge]
[![style: very good analysis][very_good_analysis_badge]][very_good_analysis_link]
[![License: MIT][license_badge]][license_link]Generated by the [Very Good CLI][very_good_cli_link] π€
A full-stack application to show Apple PassKit functionality.
---
## Getting Started π
### Configuration Files π
This project has a VSCode configuration under `.vscode/launch.json` that expects an env.json file at the root of the project.
```json
{
"TEAM_IDENTIFIER": "MY_TEAM_IDENTIFIER",
"PASS_TYPE_IDENTIFIER": "com.my_company.my_pass_app"
}
```And requires the `certificate.pem` and `private_key.pem` files to be present in this directory `api/data/`. You can check the PassKit Signing documentation [here](https://github.com/ueman/passkit/blob/master/passkit/SIGNING.md) to learn more about how to generate these files.
### Flavors π¦
This project contains 3 flavors:
- development
- staging
- productionTo run the desired flavor either use the launch configuration in VSCode or use the following commands:
```sh
# Development
$ flutter run --flavor development --target lib/main_development.dart# Staging
$ flutter run --flavor staging --target lib/main_staging.dart# Production
$ flutter run --flavor production --target lib/main_production.dart
```_\*Pass App works on iOS only, due to Apple Wallet integrations._
---
## Running Tests π§ͺ
To run all unit and widget tests use the following command:
```sh
$ flutter test --coverage --test-randomize-ordering-seed random
```To view the generated coverage report you can use [lcov](https://github.com/linux-test-project/lcov).
```sh
# Generate Coverage Report
$ genhtml coverage/lcov.info -o coverage/# Open Coverage Report
$ open coverage/index.html
```---
## Working with Translations π
This project relies on [flutter_localizations][flutter_localizations_link] and follows the [official internationalization guide for Flutter][internationalization_link].
### Adding Strings
1. To add a new localizable string, open the `app_en.arb` file at `lib/l10n/arb/app_en.arb`.
```arb
{
"@@locale": "en",
"counterAppBarTitle": "Counter",
"@counterAppBarTitle": {
"description": "Text shown in the AppBar of the Counter Page"
}
}
```2. Then add a new key/value and description
```arb
{
"@@locale": "en",
"counterAppBarTitle": "Counter",
"@counterAppBarTitle": {
"description": "Text shown in the AppBar of the Counter Page"
},
"helloWorld": "Hello World",
"@helloWorld": {
"description": "Hello World Text"
}
}
```3. Use the new string
```dart
import 'package:pass_app/l10n/l10n.dart';@override
Widget build(BuildContext context) {
final l10n = context.l10n;
return Text(l10n.helloWorld);
}
```### Adding Supported Locales
Update the `CFBundleLocalizations` array in the `Info.plist` at `ios/Runner/Info.plist` to include the new locale.
```xml
...CFBundleLocalizations
en
es
...
```### Adding Translations
1. For each supported locale, add a new ARB file in `lib/l10n/arb`.
```
βββ l10n
β βββ arb
β β βββ app_en.arb
β β βββ app_es.arb
```2. Add the translated strings to each `.arb` file:
`app_en.arb`
```arb
{
"@@locale": "en",
"counterAppBarTitle": "Counter",
"@counterAppBarTitle": {
"description": "Text shown in the AppBar of the Counter Page"
}
}
````app_es.arb`
```arb
{
"@@locale": "es",
"counterAppBarTitle": "Contador",
"@counterAppBarTitle": {
"description": "Texto mostrado en la AppBar de la pΓ‘gina del contador"
}
}
```### Generating Translations
To use the latest translations changes, you will need to generate them:
1. Generate localizations for the current project:
```sh
flutter gen-l10n --arb-dir="lib/l10n/arb"
```Alternatively, run `flutter run` and code generation will take place automatically.
[coverage_badge]: coverage_badge.svg
[flutter_localizations_link]: https://api.flutter.dev/flutter/flutter_localizations/flutter_localizations-library.html
[internationalization_link]: https://flutter.dev/docs/development/accessibility-and-localization/internationalization
[license_badge]: https://img.shields.io/badge/license-MIT-blue.svg
[license_link]: https://opensource.org/licenses/MIT
[very_good_analysis_badge]: https://img.shields.io/badge/style-very_good_analysis-B22C89.svg
[very_good_analysis_link]: https://pub.dev/packages/very_good_analysis
[very_good_cli_link]: https://github.com/VeryGoodOpenSource/very_good_cli