Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/hossamsadekk/finaxis

🤑 Compose Multiplatform App built with Jetpack Compose , SOLID , Koin , Ktor , DataStore , Napier , Kottie , Coroutines , Kotlinx Serialization
https://github.com/hossamsadekk/finaxis

android clean-architecture compose-multiplatform compose-ui coroutines datastore datastore-android datastore-preferences koin-android koin-injection koin-kotlin kotlinx-serialization ktor mvvm-architecture soild version-catalog

Last synced: 2 months ago
JSON representation

🤑 Compose Multiplatform App built with Jetpack Compose , SOLID , Koin , Ktor , DataStore , Napier , Kottie , Coroutines , Kotlinx Serialization

Awesome Lists containing this project

README

        



API










Hits


GitHub code size in bytes


# Finaxis - Secure Banking App for Android and iOS

Finaxis is a cutting-edge banking application designed for both Android and iOS platforms, offering a seamless and secure way to manage your finances. Whether you're transferring funds, managing accounts, or tracking your transaction history, Finaxis provides an intuitive and efficient banking experience tailored to meet the needs of modern users.

## Goal 👀
The primary goal of the Finaxis project is to enhance my skills by practicing and exploring new technologies. Specifically:

- Compose Multiplatform: To gain hands-on experience with Jetpack Compose Multiplatform, enabling the creation of a unified user interface across Android and iOS platforms.
- Backend Development with Spring Boot: To practice building a custom backend using Spring Boot, providing a robust and scalable server-side solution rather than relying on external APIs.
This project serves as a learning opportunity to deepen my understanding of cross-platform development and backend engineering.

## Project Structure and Design Principles 🛠
**Finaxis** is built following the principles of Clean Architecture, which provides a clear separation of concerns and organizes the code into layers. The architecture is designed to make the app easy to extend and maintain.

**Finaxis** is structured into three main layers:

- **Presentation Layer:** Handles the UI using Jetpack Compose Multiplatform. Dependency injection (DI) is set up to manage UI components and state.

- **Domain Layer:** Contains the core business logic, including entities and use cases. It is independent of other layers, ensuring easy testability and adherence to **SOLID principles**.

- **Data Layer:** Manages data sources, including API services and local storage. DI is used to provide repository implementations that interact with the domain layer.

This architecture ensures a clean separation of concerns, making the project maintainable, scalable, and testable.

## 📸 Screenshots For IOS

| | | |
|---|---|---|
| ![1](./screenshots/iphone_screenshots/1.png) | ![2](./screenshots/iphone_screenshots/2.png) | ![3](./screenshots/iphone_screenshots/3.png) |
| ![4](./screenshots/iphone_screenshots/4.png) | ![5](./screenshots/iphone_screenshots/5.png) | ![6](./screenshots/iphone_screenshots/6.png) |
| ![7](./screenshots/iphone_screenshots/7.png) | ![8](./screenshots/iphone_screenshots/8.png) | ![9](./screenshots/iphone_screenshots/9.png) |
| ![10](./screenshots/iphone_screenshots/10.png) | ![11](./screenshots/iphone_screenshots/11.png) | ![12](./screenshots/iphone_screenshots/12.png) |
| ![13](./screenshots/iphone_screenshots/13.png) | ![14](./screenshots/iphone_screenshots/14.png) | ![15](./screenshots/iphone_screenshots/15.png) |
| ![16](./screenshots/iphone_screenshots/16.png) | ![17](./screenshots/iphone_screenshots/17.png) | ![18](./screenshots/iphone_screenshots/18.png) |
| ![19](./screenshots/iphone_screenshots/19.png) |

## 📸 Screenshots For Android

| | | |
|---|---|---|
| ![1](./screenshots/android_screenshots/1.png) | ![2](./screenshots/android_screenshots/2.png) | ![3](./screenshots/android_screenshots/3.png) |
| ![4](./screenshots/android_screenshots/4.png) | ![5](./screenshots/android_screenshots/5.png) | ![6](./screenshots/android_screenshots/6.png) |
| ![7](./screenshots/android_screenshots/7.png) | ![8](./screenshots/android_screenshots/8.png) | ![9](./screenshots/android_screenshots/9.png) |
| ![10](./screenshots/android_screenshots/10.png) | ![11](./screenshots/android_screenshots/11.png) | ![12](./screenshots/android_screenshots/12.png) |
| ![13](./screenshots/android_screenshots/13.png) | ![14](./screenshots/android_screenshots/14.png) | ![15](./screenshots/android_screenshots/15.png) |
| ![16](./screenshots/android_screenshots/16.png) | ![17](./screenshots/android_screenshots/17.png) | ![18](./screenshots/android_screenshots/18.png) |
| ![19](./screenshots/android_screenshots/19.png) | ![20](./screenshots/android_screenshots/20.png) | ![21](./screenshots/android_screenshots/21.png) |

## 🚀 Future Plans

In the coming updates, we plan to enhance the project with the following features:

1.**Enhanced User Experience:** Improving the overall user interface and experience based on feedback to make the app more intuitive and user-friendly.

2.**New Features:** Adding new functionalities such as Donating Service, paying bills to increase the app's capabilities.

3.**Setting Screen:** Implementing settings screen flow.

4.**Security Enhancements:** Strengthening security measures to ensure user data is protected and to comply with the latest security standards.

5.**Bug Fixes and Updates:** Continuously addressing reported issues and releasing updates to fix bugs and introduce improvements.

# Built with 🛠
- [Kotlin](https://kotlinlang.org/) - First class and official programming language for Android development.
- [Compose](https://www.google.com/search?client=safari&rls=en&q=jetback+compose&ie=UTF-8&oe=UTF-8) - Modern UI toolkit for building native Android interfaces, offering a declarative approach to creating UIs with Kotlin.
- [Koin](https://insert-koin.io/docs/reference/koin-compose/multiplatform/) - Lightweight dependency injection framework for Kotlin, designed to simplify the setup and management of dependencies in applications with minimal boilerplate.
- [Ktor](https://ktor.io) - Asynchronous framework for building web applications and microservices in Kotlin, providing a flexible and scalable solution for server-side development, HTTP client functionality, and networking tasks.
- [Data Store](https://developer.android.com/topic/libraries/architecture/datastore) - A modern data storage solution for Android that provides a simple and efficient way to handle key-value pairs and typed objects, replacing SharedPreferences with improved performance and ease of use.
- [compose-imageloader](https://github.com/qdsfdhvh/compose-imageloader) - A lightweight and efficient image loading library for Android that simplifies the process of loading and displaying images, with support for caching, transformations, and image resource management.
- [Pull To Refresh](https://github.com/MateriiApps/pullrefresh) - A library for implementing pull-to-refresh functionality in Android applications, allowing users to refresh content by pulling down on a list or scrollable view.
- [Naiper](https://github.com/AAkira/Napier) - A lightweight logging library for Kotlin Multiplatform projects, designed to provide a flexible and easy-to-use logging mechanism with support for different logging levels and customizable log formatting.
- [Kotlin](https://kotlinlang.org/) - First class and official programming language for Android development.

# Project Setup 📝
1. **Clone the Repository**

Clone this repository to your local machine using the following command:
```bash
git clone https://github.com/HossamSadekk/Finaxis

2. **Spring Boot**
Setup the backend for spring boot side

3. **Required prerequisites**
- Android Studio or Compatible IDE
- Kotlin
- Java IDE for spring
- Xcode (For iOS Development)
- Java Development Kit (JDK)
- Additional Tools like