Added script to setup the repo & updated README.md (#223)

* added script to setup the repo

* moved scripts to scripts folder

* Update README.md

* added macOS disclaimer
This commit is contained in:
Vadim 2025-03-17 21:35:33 +01:00 committed by GitHub
parent 2dee63e78e
commit d95b811d6c
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 24 additions and 35 deletions

View file

@ -38,41 +38,18 @@ To build this app you need to install Flutter 3.24.5 stable. [How to install](ht
### 2. Project setup
#### Restore _constants.dart_ file
#### Restore git-ignored files:
Create a file _lib/constants.dart_ and paste the following content:
```dart
const String contactEmail = '';
const String iapServerUrl = '';
const String issuesReportUrl = '';
const String sourceCodeUrl = '';
```
#### Stub IAP package
As part of the app's functionallity is in the private repo, you have to replace these lines in _pubspec.yaml_:
```yaml
m3_lightmeter_iap:
git:
url: "https://github.com/vodemn/m3_lightmeter_iap"
ref: main
```
with these:
```yaml
m3_lightmeter_iap:
path: iap
```
You can do it simply by running the script:
For macOS you can just run the following script:
```console
sh .github/scripts/stub_iap.sh
sh scripts/setup_fork.sh
```
Or create the files manually using the contents from the script.
#### Get dependencies
> If you are using VSCode, you can open the workspace like so: _File -> Open Workspace from File -> m3_lightmeter.code-workspace_. Otherwise you have to run `flutter pub get` command from the iap folder.
Then you can fetch all the neccessary dependencies and generate translation files by running the following commands:
@ -82,11 +59,7 @@ flutter pub get
flutter pub run intl_utils:generate
```
### 3. (Optional) Install Firebase
Out of the box Firebase Crashlytics won't work. If you want to add Crashlytics to your local build please follow [this guide](https://firebase.google.com/docs/flutter/setup).
### 4. Build
### 3. Build
- Checkout [Build .apk](.github/workflows/build_apk.yml) workflow for Android
- Checkout [Build .ipa](.github/workflows/build_ipa.yml) workflow for iOS

16
scripts/setup_fork.sh Normal file
View file

@ -0,0 +1,16 @@
constants="const String contactEmail = '';
const String iapServerUrl = '';
const String issuesReportUrl = 'https://github.com/vodemn/m3_lightmeter/issues/new/choose';
const String sourceCodeUrl = 'https://github.com/vodemn/m3_lightmeter/';"
firebase_options="// ignore_for_file: type=lint
import 'package:firebase_core/firebase_core.dart' show FirebaseOptions;
class DefaultFirebaseOptions {
static FirebaseOptions get currentPlatform =>
FirebaseOptions(apiKey: '', appId: '', messagingSenderId: '', projectId: '');
}"
echo "$constants" > "lib/constants.dart"
echo "$firebase_options" > "lib/firebase_options.dart"
sh .github/scripts/stub_iap.sh