Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/SinaSys/flutter_office_furniture_store_app
🎲 Flutter Office furniture store app using GetX | bloc | cubit | Provider | riverpod
https://github.com/SinaSys/flutter_office_furniture_store_app
android bloc cubit dart flutter flutter-apps flutter-bloc flutter-cubit flutter-demo flutter-hooks flutter-material flutter-provider flutter-template flutter-ui-challenges flutter-widgets getx provider-state-management reactive riverpod state-management
Last synced: 3 months ago
JSON representation
🎲 Flutter Office furniture store app using GetX | bloc | cubit | Provider | riverpod
- Host: GitHub
- URL: https://github.com/SinaSys/flutter_office_furniture_store_app
- Owner: SinaSys
- License: bsd-2-clause
- Created: 2022-06-05T15:08:33.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-11-23T10:26:33.000Z (about 1 year ago)
- Last Synced: 2024-08-01T12:19:34.051Z (6 months ago)
- Topics: android, bloc, cubit, dart, flutter, flutter-apps, flutter-bloc, flutter-cubit, flutter-demo, flutter-hooks, flutter-material, flutter-provider, flutter-template, flutter-ui-challenges, flutter-widgets, getx, provider-state-management, reactive, riverpod, state-management
- Language: Dart
- Homepage:
- Size: 25.2 MB
- Stars: 186
- Watchers: 2
- Forks: 45
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## office_furniture_store_app
Office Furniture Store app is a design implementation
of [Office Furniture Store app](https://dribbble.com/shots/16394699-E-commerce-design-concept)
designed by [Jonatan](https://dribbble.com/Jhonatan_artist23)![](https://github.com/SinaSys/flutter_office_furniture_store_app/blob/master/screenshots/office_furniture_store_app.jpg?raw=true)
## GetX | Cubit | Bloc | Provider | Riverpod
#### • Access to different versions
| Version | Bloc | Cubit | Getx | Provider | Riverpod |
|:-----------------------------------:|:------------------------------------------------------------------------------------------------------:|:---------------------------------------------------------------------------------------------------------:|:-------------------------------------------------------------------------------------------------------------:|:-----------------------------------------------------------------------------------------------------------------:|:----------------------------------------------------------------------------------------------------------------:|
| Branch | [Source](https://github.com/SinaSys/flutter_office_furniture_store_app/tree/bloc)
(bloc branch)️ | [Source](https://github.com/SinaSys/flutter_office_furniture_store_app/tree/cubit)
(cubit branch) | [Source](https://github.com/SinaSys/flutter_office_furniture_store_app/tree/master)
(master branch) | [Source](https://github.com/SinaSys/flutter_office_furniture_store_app/tree/provider)
(provider branch) | [Source](https://github.com/SinaSys/flutter_office_furniture_store_app/tree/riverpod)
(riverpod branch) |
## Screenshots
Preview | List screen | Detail Screen | Cart Screen
:-------------------------:|:-------------------------:|:-------------------------:|:-------------------------:
![](https://github.com/SinaSys/flutter_office_furniture_store_app/blob/master/screenshots/preview.gif?raw=true)|![](https://github.com/SinaSys/flutter_office_furniture_store_app/blob/master/screenshots/office_furniture_list_screen.png?raw=true)|![](https://github.com/SinaSys/flutter_office_furniture_store_app/blob/master/screenshots/office_furniture_detail_screen.png?raw=true)|![](https://github.com/SinaSys/flutter_office_furniture_store_app/blob/master/screenshots/cart_screen.png?raw=true)
## 🚀 Features :
```
• Five different implementations
• Display items on list item screen
• Display detail of each item on detail screen
• Hero animation for images when navigate fron list screen to detail screen
• Fade animation for list views
• Select quantity and color for each item
• Display item images using carousel slider
• Add desired item to favorite screen
• Add or delete item to cart
• Clear all itms from cart screen
• Automatically delete single item from cart by set its value to zero
• Real-time calculation of total price in the cart screen
• State management with GetX | cubit | bloc | Provider | Riverpod
```
## Dependencies
| Name | Cubit
version | Bloc
version | GetX
version | provider
version | riverpod
version |
| :-------------: | :--------------------------: | :----------------------------: | :------------------------: | :------------------------: |:----------------------:|
| [flutter_bloc](https://pub.dev/packages/flutter_bloc) | ✔️ | ✔️ | ✖️ | ✖️ | ✖️ |
| [GetX](https://pub.dev/packages/get) | ✖️ | ✖️ | ✔️ | ✖️ | ✖️ |
| [provider](https://pub.dev/packages/provider) | ✖️ | ✖️ | ✖️ | ✔️ | ✖️ |
| [flutter_hooks](https://pub.dev/packages/flutter_hooks) | ✔️ | ✔️ | ✖️ | ✔️ | ✖️ |
| [hooks_riverpod](https://pub.dev/packages/hooks_riverpod) | ✖️ | ✖️ | ✖️ | ✖️ |✔️ |
| [equatable](https://pub.dev/packages/equatable) | ✔️ | ✔️ | ✖️ | ✔️| ✔️ |
| [smooth_page_indicator](https://pub.dev/packages/smooth_page_indicator) | ✔️ | ✔️ | ✔️ |✔️| ✔️ |
| [flutter_rating_bar](https://pub.dev/packages/flutter_rating_bar) | ✔️ | ✔️ |✔️ |✔️| ✔️ |
| [simple_animations](https://pub.dev/packages/simple_animations) | ✔️ | ✔️ |✔️ |✔️| ✔️ |
## Directory Structure (GetX version)
```
đź“‚lib
│───main.dart
│───📂core
| │──app_asset.dart
| │──app_color.dart
| │──app_data.dart
| │──app_extension.dart
| │──app_style.dart
| └──app_theme.dart
└───📂src
│────📂model
│ │──bottom_navigation_item.dart
| │──furniture.dart
| └──furniture_color.dart
└────📂view
| │───📂screen
| | |──cart_screen.dart
| | |──favorite_screen.dart
| | |──home_screen.dart
| | |──intro_screen.dart
| | |──office_furniture_detail_screen.dart
| | |──office_furniture_list_screen.dart
| | └──profile_screen.dart
| │───📂widget
| | |──bottom_bar.dart
│ | |──cart_list_view.dart
│ | |──color_picker.dart
│ | |──counter_button.dart
│ | |──empty_widget.dart
│ | |──furniture_list_view.dart
│ | |──fade_in_animation.dart
| | └──rating_bar.dart
└────📂controller
└──office_furniture_controller.dart
```## Directory Structure (Cubit version)
```
đź“‚lib
│───main.dart
│───📂core
│ │──app_asset.dart
│ │──app_color.dart
│ │──app_data.dart
│ │──app_extension.dart
│ │──app_style.dart
│ └──app_extension.dart
└───📂src
│────📂data
│ │───📂model
│ │ |──bottom_navigation_item.dart
│ │ |──furniture.dart
│ │ └──furniture_color.dart
│ │───📂repository
│ │ └──repository.dart
└────📂presentation
│ │───📂screen
│ │ |──cart_screen.dart
│ │ |──favorite_screen.dart
│ │ |──home_screen.dart
│ │ |──intro_screen.dart
│ │ |──office_furniture_detail_screen.dart
│ │ |──office_furniture_list_screen.dart
│ │ └──profile_screen.dart
│ │───📂widget
│ │ |──bottom_bar.dart
│ │ |──cart_list_view.dart
│ │ |──color_picker.dart
│ │ |──counter_button.dart
│ │ |──empty_widget.dart
│ │ |──furniture_list_view.dart
│ │ └──rating_bar.dart
│ │───📂animation
│ │ └──fade_in_animation.dart
└────📂business_logic
└───📂cubit
└──📂furniture
|──furniture_cubit.dart
└──furniture_state.dart
```## Directory Structure (Bloc version)
```
đź“‚lib
│───main.dart
│───📂core
│ │──app_asset.dart
│ │──app_color.dart
│ │──app_data.dart
│ │──app_extension.dart
│ │──app_style.dart
│ └──app_extension.dart
└───📂src
│────📂data
│ │───📂model
│ │ |──bottom_navigation_item.dart
│ │ |──furniture.dart
│ │ └──furniture_color.dart
│ │───📂repository
│ │ └──repository.dart
└────📂presentation
│ │───📂screen
│ │ |──cart_screen.dart
│ │ |──favorite_screen.dart
│ │ |──home_screen.dart
│ │ |──intro_screen.dart
│ │ |──office_furniture_detail_screen.dart
│ │ |──office_furniture_list_screen.dart
│ │ └──profile_screen.dart
│ │───📂widget
│ │ |──bottom_bar.dart
│ │ |──cart_list_view.dart
│ │ |──color_picker.dart
│ │ |──counter_button.dart
│ │ |──empty_widget.dart
│ │ |──furniture_list_view.dart
│ │ └──rating_bar.dart
│ │───📂animation
│ │ └──fade_in_animation.dart
└────📂business_logic
└───📂bloc
└──📂furniture
|──furniture_bloc.dart
|──furniture_state.dart
└──furniture_event.dart
```## Directory Structure (Riverpod version)
```
đź“‚lib
│───main.dart
│───📂core
│ │──app_asset.dart
│ │──app_color.dart
│ │──app_data.dart
│ │──app_extension.dart
│ │──app_style.dart
│ └──app_extension.dart
└───📂src
│────📂data
│ │───📂model
│ │ |──bottom_navigation_item.dart
│ │ |──furniture.dart
│ │ └──furniture_color.dart
│ │───📂repository
│ │ └──repository.dart
└────📂presentation
│ │───📂screen
│ │ |──cart_screen.dart
│ │ |──favorite_screen.dart
│ │ |──home_screen.dart
│ │ |──intro_screen.dart
│ │ |──office_furniture_detail_screen.dart
│ │ |──office_furniture_list_screen.dart
│ │ └──profile_screen.dart
│ │───📂widget
│ │ |──bottom_bar.dart
│ │ |──cart_list_view.dart
│ │ |──color_picker.dart
│ │ |──counter_button.dart
│ │ |──empty_widget.dart
│ │ |──furniture_list_view.dart
│ │ └──rating_bar.dart
│ │───📂animation
│ │ └──fade_in_animation.dart
└────📂business_logic
└───📂provider
|──furniture_provider.dart
└──furniture_state.dart
```## Directory Structure (Provider version)
```
đź“‚lib
│───main.dart
│───📂core
│ │──app_asset.dart
│ │──app_color.dart
│ │──app_data.dart
│ │──app_extension.dart
│ │──app_style.dart
│ └──app_extension.dart
└───📂src
│────📂data
│ │───📂model
│ │ |──bottom_navigation_item.dart
│ │ |──furniture.dart
│ │ └──furniture_color.dart
│ │───📂repository
│ │ └──repository.dart
└────📂presentation
│ │───📂screen
│ │ |──cart_screen.dart
│ │ |──favorite_screen.dart
│ │ |──home_screen.dart
│ │ |──intro_screen.dart
│ │ |──office_furniture_detail_screen.dart
│ │ |──office_furniture_list_screen.dart
│ │ └──profile_screen.dart
│ │───📂widget
│ │ |──bottom_bar.dart
│ │ |──cart_list_view.dart
│ │ |──color_picker.dart
│ │ |──counter_button.dart
│ │ |──empty_widget.dart
│ │ |──furniture_list_view.dart
│ │ └──rating_bar.dart
│ │───📂animation
│ │ └──fade_in_animation.dart
└────📂business_logic
└───📂provider
└──📂furniture
|──furniture_provider.dart
└──furniture_state.dart
```## Created & Maintained By
[SinaSys](https://github.com/SinaSys)
## Other flutter projects
Project Name |Stars
:-------------------------|-------------------------
[Go rest app](https://github.com/SinaSys/flutter_go_rest_app)|![GitHub stars](https://img.shields.io/github/stars/SinaSys/flutter_go_rest_app?style=social)
[Japanese restaurant app](https://github.com/SinaSys/flutter_japanese_restaurant_app)| ![GitHub stars](https://img.shields.io/github/stars/SinaSys/flutter_japanese_restaurant_app?style=social)
|[Ecommerce app](https://github.com/SinaSys/flutter_ecommerce_app) |![GitHub stars](https://img.shields.io/github/stars/SinaSys/flutter_ecommerce_app?style=social)