Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/felipecastrosales/barbershop

💈 Barbershop App developed with Flutter
https://github.com/felipecastrosales/barbershop

app barber barber-shop barbershop dart flutter flutter-app flutter-apps flutter-examples riverpod schedule

Last synced: about 1 month ago
JSON representation

💈 Barbershop App developed with Flutter

Awesome Lists containing this project

README

        


Logo Barbershop App

Barbershop App

---

Topics 📋

- [📖 Sobre](#-about)
- [📱 Preview](#-preview)
- [📦 Assets](#-assets)
- [🛠️ Features and Technologies Studied](#-features-and-technologies-studied)
- [🤯 Challenges and Learning along the way](#-challenges-and-learning-along-the-way)
- [🤔 How to use](#-how-to-use)
- [💪 How to contribute](#-how-to-contribute)
- [📝 License](#-license)

---

📖 About

An app for barber shop professionals, where it is possible to manage your own barber shop and even yourself. In addition to having the flow of scheduling appointments and controlling services.

---

📱 Preview

https://github.com/felipecastrosales/barbershop/assets/59374587/ff81c19d-851f-4148-9612-bb08fe8a7fb8

---

📦 Assets

- **`Postman Collections`**.
- **`Figma`**;

---

🛠️ Features and Technologies Studied

- Using Dart 3 powers:
- Functional Programming (Either) with Pure Dart (using Dart 3 power);
- Using a lot `switch` ways;
- Using `pattern matching` etc.
- Postman Collections;
- Themes, help extensions, constants helpers, custom exceptions and more;
- Rest Client with Dio and Interceptors;
- Login, Register and Logout flow;
- Screens
- Splash;
- Register (account, establishment and professional);
- Login;
- Home (customized for each user);
- Schedule;
- Employee flow;
- Calendar flow;
- Packages:
- [asyncstate](https://pub.dev/packages/asyncstate)
- [dio](https://pub.dev/packages/dio)
- [intl](https://pub.dev/packages/intl)
- [loading_animation_widget](https://pub.dev/packages/loading_animation_widget)
- [pretty_dio_logger](https://pub.dev/packages/pretty_dio_logger)
- [shared_preferences](https://pub.dev/packages/shared_preferences)
- [syncfusion_flutter_calendar](https://pub.dev/packages/syncfusion_flutter_calendar)
- [table_calendar](https://pub.dev/packages/table_calendar)
- [top_snackbar_flutter](https://pub.dev/packages/top_snackbar_flutter)
- [validatorless](https://pub.dev/packages/validatorless)
- [build_runner](https://pub.dev/packages/build_runner)
- [custom_lint](https://pub.dev/packages/custom_lint)
- [flutter_lints](https://pub.dev/packages/flutter_lints)
- [riverpod_annotation](https://pub.dev/packages/riverpod_annotation), [riverpod_generator](https://pub.dev/packages/riverpod_generator), [riverpod_lint](https://pub.dev/packages/riverpod_lint)
- Dentre outras coisas. 🔥

---

🤯 Challenges and Learning along the way

Without a doubt, the biggest learning experience was Riverpod; I realized that it is very interesting for managing the state of an application, going further in points that can be crucial (such as being able to have multiple providers of the same type, performing dispose when it is no longer used, among other things).

Furthermore, it was really cool to learn more about the powers and uses of Dart 3 in practice, such as the new `switch` and the use of `pattern matching`; which fit very well and make the code more objective. Another point that was very interesting was the `Either` used, similar to what is [in this article](https://codewithandrea.com/articles/flutter-exception-handling-try-catch-result-type/); without any external dependency. You can use functional programming with `pattern matching` to handle error and success cases.

Various other learnings were acquired and also reinforced; in addition to refactorings and code improvements made along the way. There is always something to be improved and learned. 🚀

---

🤔 How to use

```
Configure the Flutter environment on your machine:
https://flutter.dev/docs/get-started/install

- Clone the repository:
$ git clone https://github.com/felipecastrosales/barbershop

- Enter the directory:
$ cd barbershop

- Open the project:
$ code .

- Install the json_rest_server:
$ dart pub global activate json_rest_server

- Enter the api directory:
$ cd api

- Run the server:
$ json_rest_server run

- Enter the project directory:
$ flutter pub get

- Get your IP and put on `rest_client.dart`;

- Execute the application:
$ flutter run
```

---

💪 How to contribute

There are several ways to contribute to this project, such as:

```
- Fork this repository;

- Create a branch with your feature:
$ git checkout -b my-feature

- Commit your changes:
$ git commit -m "feature: My new feature"

- Push your branch:
$ git push origin my-feature

- Open a pull request on this repository and/or create an issue explaining your problem.
```

---

📝 License

This repository is under the MIT License, and you can see it in the LICENSE file for more details.

---

> This project was developed with ❤️ by **[@Felipe Sales](https://www.linkedin.com/in/felipecastrosales/)**, with the instructor **[@Rodrigo Rahman](https://linkedin.com/in/rodrigo-rahman)**.
If this helped you, give it a ⭐, and contribute, it will help me too. 😉

---

[![Linkedin Badge](https://img.shields.io/badge/-Felipe%20Sales-292929?style=flat-square&logo=Linkedin&logoColor=white&link=https://www.linkedin.com/in/felipecastrosales/)](https://www.linkedin.com/in/felipecastrosales/)