Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/KingWu/flutter_starter_kit
A starter kit for beginner learns with Bloc pattern, RxDart, sqflite, Fluro and Dio to architect a flutter project. This starter kit build an App Store app as a example
https://github.com/KingWu/flutter_starter_kit
android flutter flutter-bloc flutter-demo flutter-examples ios mobile mobile-app mobile-development rxdart starter-kit
Last synced: 3 months ago
JSON representation
A starter kit for beginner learns with Bloc pattern, RxDart, sqflite, Fluro and Dio to architect a flutter project. This starter kit build an App Store app as a example
- Host: GitHub
- URL: https://github.com/KingWu/flutter_starter_kit
- Owner: KingWu
- License: apache-2.0
- Created: 2019-01-11T10:19:21.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2022-05-18T06:13:38.000Z (over 2 years ago)
- Last Synced: 2024-08-01T19:38:23.477Z (6 months ago)
- Topics: android, flutter, flutter-bloc, flutter-demo, flutter-examples, ios, mobile, mobile-app, mobile-development, rxdart, starter-kit
- Language: Dart
- Size: 128 KB
- Stars: 791
- Watchers: 27
- Forks: 126
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- my-awesome-list - flutter_starter_kit
README
# Flutter Starter Kit - App Store Example
A starter kit for beginner learns with Bloc pattern, RxDart, sqflite, Fluro and Dio to architect a flutter project. This starter kit build an App Store app as a example
![App Store Flutter Demo](https://i.ibb.co/FsyWhpY/ezgif-3-5dbb34baf658.gif)
## Feature
- Bloc Pattern
- Navigate pages by [Fluro](https://github.com/theyakka/fluro)
- Local cache by using [sqflite](https://github.com/tekartik/sqflite)
- Restful api call by using [Dio](https://github.com/flutterchina/dio)
- Database debugging (Android Only) by using [flutter_stetho](https://github.com/brianegan/flutter_stetho)
- Loading Network Image
- Localization by using [gen_lang](https://github.com/KingWu/gen_lang)
and [lang_table](https://github.com/KingWu/lang_table)
- Environment Variable & Project Config (Like App Name, Bundle Id) based on different project flavour (Development, Staging & Production)
- Build pojo by using json_serializable
- Update each list item instead of re-rendering whole list view when data set has changed on a list item
- Hero animation
- Show empty View when the list view is empty## Install
1. Follow flutter [official setup guide](https://flutter.io/docs/get-started/install) to set up flutter environment
2. Download [flutter version 1.17.3](https://flutter.dev/docs/development/tools/sdk/releases)Remark: This starter kit support Flutter version - 1.17.3. It is because Flutter may have breaking change on latest version.
## Run Config
1. Click 'Edit Configuration'
2. Create different run configs for flavours![Edit Config](https://i.ibb.co/sbkgnmN/Screen-Shot-2019-01-13-at-7-28-44-PM.png)
![Config](https://i.ibb.co/tqPgMVz/Screen-Shot-2019-01-13-at-7-52-38-PM.png)
![Flavour](https://i.ibb.co/hCP2QJ1/Screen-Shot-2019-01-13-at-7-40-16-PM.png)
## Useful Command
### Run flutter_starter_kit
For development,
```
flutter run --flavor development -t lib/config/main_development.dart
```For staging,
```
flutter run --flavor staging -t lib/config/main_staging.dart
```For production,
```
flutter run --flavor production -t lib/config/main_production.dart
```### Generate json serialize and deserialize functions
```
flutter packages pub run build_runner build --delete-conflicting-outputs
```### lang_table
```
flutter packages pub run lang_table:generate --platform=airTable --input=https://api.airtable.com/v0/appZmh0WMg3y6APAg/example --api-key={YOUR API KEY} --target=Flutter
```### gen_lang
```
flutter packages pub run gen_lang:generate
```## Known Issues
- [Unable to launch app on ios simulator with different flavours](https://github.com/flutter/flutter/issues/21335)## Migration Guide
- If you wanna to use this project as your project's base, please read
[migration guide](https://github.com/KingWu/flutter_starter_kit/wiki/Migration-Guide)## Reference
- [My Flutter Learning Path](https://medium.com/@kingwu/flutter-learning-path-d6b3b0235799)
#### From other platform?
- [Flutter for Android developers](https://flutter.io/docs/get-started/flutter-for/android-devs)
- [Flutter for iOS developers](https://flutter.io/docs/get-started/flutter-for/ios-devs)
- [Flutter for React Native developers](https://flutter.io/docs/get-started/flutter-for/react-native-devs)
- [Flutter for web developers](https://flutter.io/docs/get-started/flutter-for/web-devs)
- [Flutter for Xamarin.Forms developers](https://flutter.io/docs/get-started/flutter-for/xamarin-forms-devs)#### Learn Widget & Layout
- [Building Layouts](https://flutter.io/docs/development/ui/layout)
- [Widget catalog](https://flutter.io/docs/development/ui/widgets)
- [Series of flutter widget of the week](https://www.youtube.com/playlist?list=PLOU2XLYxmsIL0pH0zWe_ZOHgGhZ7UasUE)
- [Series of Flutter Widgets 101](https://www.youtube.com/playlist?list=PLOU2XLYxmsIJyiwUPCou_OVTpRIn_8UMd)#### Bloc Pattern
- [Architect your Flutter project using BLOC pattern](https://medium.com/flutterpub/architecting-your-flutter-project-bd04e144a8f1)#### Json Serialization
- [JSON and serialization](https://flutter.io/docs/development/data-and-backend/json)#### Localization
- [A new approach of localization in Flutter](https://medium.com/@kingwu/a-new-approach-of-localization-in-flutter-e18bfb2b14ab)
- [Flutter: internationalization tutorials: Part 3— Android Studio plugin](https://medium.com/@datvt9312/flutter-internationalization-tutorials-part-3-android-studio-plugin-8604e2dc90f0)
- [讓 Flutter App 支援多國語系的開發流程](https://medium.com/@zonble/%E8%AE%93-flutter-app-%E6%94%AF%E6%8F%B4%E5%A4%9A%E5%9C%8B%E8%AA%9E%E7%B3%BB%E7%9A%84%E9%96%8B%E7%99%BC%E6%B5%81%E7%A8%8B-ceb31532e2e1)#### Flavouring
- [Flavoring Flutter](https://medium.com/@salvatoregiordanoo/flavoring-flutter-392aaa875f36)
- [Creating flavors of a Flutter app (Flutter & Android setup)](http://cogitas.net/creating-flavors-of-a-flutter-app/)#### Advance Topic
- [The Mahogany Staircase - Flutter's Layered Design](https://www.youtube.com/watch?time_continue=1&v=dkyY9WCGMi0)
- [Flutter's Rendering Pipeline](https://www.youtube.com/watch?v=UUfXWzp0-DU)### Powered By
- [Plaker Lab 創玩坊](https://www.plakerlab.com/)
- [Wenjetso 搵著數](https://www.wenjetso.com/zh_HK/)