Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/razaghimahdi/shopping-by-kmp

This is a cross-platform application that is built using Jetpack Compose Multiplatform, a declarative framework for sharing UIs across multiple platforms with Kotlin.
https://github.com/razaghimahdi/shopping-by-kmp

android clean-architecture compose compose-android compose-ios compose-multiplatform ios kmm kmp kotlin kotlin-multiplatform kotlin-multiplatform-sample ktor ktor-client mvi swift

Last synced: about 13 hours ago
JSON representation

This is a cross-platform application that is built using Jetpack Compose Multiplatform, a declarative framework for sharing UIs across multiple platforms with Kotlin.

Awesome Lists containing this project

README

        

# Shopping-By-KMP (Compose Multiplatform application)

Welcome to the documentation for the Jetpack Compose Multiplatform Shopping Application!
This is a cross-platform application that is built using Jetpack Compose Multiplatform, a declarative framework for sharing UIs across multiple platforms with Kotlin.
The application allows users to browse, search, and purchase products from a shopping catalog on Android, iOS.

![Wallpaper](screenshots/banner.png)
![Wallpaper](screenshots/banner2.png)

https://github.com/razaghimahdi/Shopping-By-KMP/assets/61207818/a4702cbf-1449-48b0-88f1-bcb9c42d273e

## Give a Star! ⭐
If you like or are using this project to learn or start your solution, please give it a star. Thanks!

## Related ArticlesπŸ“„
[How to set up Convention Gradle Plugin in CMP](https://medium.com/@razaghimahdi78/creating-convention-gradle-plugin-for-compose-multiplatform-1b4051e98f61)

[How to create custom Number Formatting in CMP](https://medium.com/@razaghimahdi78/number-formatting-in-jetpack-compose-multiplatform-b3fd01308f6c)

## Features ✨
| Feature | Status |
|-----------------------------|------------------|
| Login, Sign Up | βœ”οΈ Implemented |
| Home | βœ”οΈ Implemented |
| Product Detail and Comments | βœ”οΈ Implemented |
| Wishlist | βœ”οΈ Implemented |
| Cart | βœ”οΈ Implemented |
| Profile | βœ”οΈ Implemented |
| Search | βœ”οΈ Implemented |
| Category | βœ”οΈ Implemented |
| Edit Profile | βœ”οΈ Implemented |
| Manage Address | βœ”οΈ Implemented |
| Payment Method | βœ”οΈ Implemented |
| My Orders | βœ”οΈ Implemented |
| My Coupons | βœ”οΈ Implemented |
| Notifications | βœ”οΈ Implemented |
| Setting | βœ”οΈ Implemented |

## **Next Features πŸ„β€β™‚οΈ**
Obviously it would be more updates, What we are working on these days?
- **Product Comparison:** Easily compare features, prices, and reviews of two products side by side for a smarter shopping choice.

#### **Future Plans:**
- **Web platfrom:** Soon we gonna have release for web

## Tech Stack πŸ“š
- Kotlin Multiplatform
- Kotlin Coroutines
- Compose Multiplatform
- Material3
- Ktor
- Datastore
- Compose Navigation and Type safety
- Koin
- Coil3
- Kotest
- Fake Data

## Development πŸ’»

Firs, let me say the backend is also in progress. You can find the backend source code [here](https://github.com/aydenGill/shop-admin-panel).

We appreciate any feedback or suggestions that you may have to help us improve the project.

We plan to add more features, improve the code quality, and make the application more user-friendly.

Our goal is to create a high-quality, multiplatform shopping application that demonstrates the power and flexibility of Jetpack Compose.

Please stay tuned for updates and feel free to contribute to the project by submitting pull requests or opening issues.
Together, we can create a great shopping application that meets the needs of users across multiple platforms.

## Challenges Faced πŸ‘¨β€πŸ’»
During the development of this project,
i encountered several challenges that required creative solutions.
Some of the key challenges I addressed include:

- **Native Functionality Challenges:** Implementing native functionalities posed challenges in image selection, camera access permissions, status bar customization, and image upload via Ktor.
- **UI Testing:** Developing comprehensive UI tests across multiple platforms presented challenges in ensuring consistent behavior and visual presentation.
- **Unit Testing:** Writing unit tests for shared code and platform-specific implementations required careful consideration of differences in testing frameworks and environments.
- **User Session Management:** Securely managing user sessions across platforms involved implementing robust authentication mechanisms while prioritizing privacy and security.
- **UI/UX Design:** Crafting an intuitive and visually appealing UI/UX for diverse devices presented creative challenges, driving iterative design processes.

These challenges underscored the complexity of developing a cross-platform shopping application and pushed us to innovate and refine our solutions continually.

## Architecture 🏒
The Jetpack Compose Multiplatform Shopping Application is built using the Clean Architecture and the MVI (Model-View-Intent) pattern.

## Testing πŸ§ͺ
Testing is a crucial aspect of software development to ensure the reliability and functionality of the application.
In the Shopping-By-KMP project, we utilize various testing frameworks and tools to maintain the quality of our codebase.

## Backend 🌐
[This project](https://github.com/aydenGill/shop-admin-panel) involves building a robust admin panel for managing an e-commerce platform.
It utilizes **Laravel** for the backend structure and **Livewire** for dynamic frontend interactions.
The panel comes with a comprehensive **API**, ensuring scalability and flexibility.

### Features
- **Admin Dashboard:** Manage products, categories, orders, and customers seamlessly.
- **Laravel & Livewire:** Leverage the power of Laravel's backend with Livewire for reactive UI.
- **Full API:** Enables external integrations and interactions with the shopping platform.

## Contributing
Contributions are welcome! If you have any feedback or suggestions, please don't hesitate to let us know.
We appreciate your contributions and support. Also if you find a bug or would like to create a new feature, please submit a pull request.

## License
This library is licensed under the MIT License. See [LICENSE.txt](https://github.com/razaghimahdi/Shoping-By-KMP/blob/master/LICENSE)

### more ideas:
https://github.com/JetBrains/compose-multiplatform-ios-android-template
https://github.com/JetBrains/compose-multiplatform

Developed by Mahdi Razzaghi Ghaleh