Expenso

Project Url: Spikeysanju/Expenso
Introduction: ๐Ÿ“Š A Minimal Expense Tracker App built to demonstrate the use of modern android architecture component with MVVM Architecture
More: Author   ReportBugs   
Tags:

GitHub Cards Preview

A Simple Expense Tracker App ๐Ÿ“ฑ built to demonstrate the use of modern android architecture component with MVVM Architecture ๐Ÿ—. Made with love โค๏ธ by Spikeysanju


Try latest Expenso app apk from below ๐Ÿ‘‡

Expenso


UI Design ๐ŸŽจ

Click to View Expenso app Design from below ๐Ÿ‘‡

Expenso


Day Mode ๐ŸŒž

Dashboard All Income All Expense Details Add Transaction


We Support Dark Mode Too ๐ŸŒš

Dashboard All Income All Expense Details Add Transaction


Built With ๐Ÿ› 

  • Kotlin - First class and official programming language for Android development.
  • Coroutines - For asynchronous and more..
  • Android Architecture Components - Collection of libraries that help you design robust, testable, and maintainable apps.
    • Stateflow - StateFlow is a state-holder observable flow that emits the current and new state updates to its collectors.
    • Flow - A flow is an asynchronous version of a Sequence, a type of collection whose values are lazily produced.
    • ViewModel - Stores UI-related data that isn't destroyed on UI changes.
    • Room - SQLite object mapping library.
    • Jetpack Navigation - Navigation refers to the interactions that allow users to navigate across, into, and back out from the different pieces of content within your app
    • DataStore - Jetpack DataStore is a data storage solution that allows you to store key-value pairs or typed objects with protocol buffers. DataStore uses Kotlin coroutines and Flow to store data asynchronously, consistently, and transactionally.
  • Material Components for Android - Modular and customizable Material Design UI components for Android.
  • Figma - Figma is a vector graphics editor and prototyping tool which is primarily web-based.


Package Structure ๐Ÿ“ฆ

dev.spikeysanju.expenso # Root Package
โ”œโ”€โ”€ di                  # Hilt DI Modules 
โ”œโ”€โ”€ data                # For data handling.
โ”‚   โ”œโ”€โ”€ local           # Local Persistence Database. Room (SQLite) database
|   โ”‚   โ”œโ”€โ”€ dao         # Data Access Object for Room   
|   |   |โ”€โ”€ database    # Database Instance
|
โ”œโ”€โ”€ model               # Model classes [Transaction]
|
|-- repo                # Used to handle all data operations
|
โ”œโ”€โ”€ view                # Activity/Fragment View layer
โ”‚   โ”œโ”€โ”€ main            # Main root folder
|   โ”‚   โ”œโ”€โ”€ main        # Main Activity for RecyclerView
|   โ”‚   โ””โ”€โ”€ viewmodel   # Transaction ViewModel
|   โ”‚   โ”œโ”€โ”€ adapter     # Adapter for RecyclerView
โ”‚   โ”œโ”€โ”€ Dashboard       # Dashboard root folder
|   |   |__ dashboard   # Dashboard 
โ”‚   โ”œโ”€โ”€ Add             # Add Transaction root folder
|   |   |__ add         # Add Transaction 
โ”‚   โ”œโ”€โ”€ Edit            # Edit Transaction root folder
|   |   |__ edit        # Edit Transaction
โ”‚   โ”œโ”€โ”€ Details         # Add Transaction root folder
|   |   |__ details     # Transaction Details
โ”‚   โ”œโ”€โ”€ About           # About root folder
|   |   |__ about       # About 
โ”‚   โ”œโ”€โ”€ Dialog          # All Dialogs root folder
|   |   |__ dialog      # Error Dialog 
โ”œโ”€โ”€ utils               # All extension functions


Architecture ๐Ÿ—ผ

This app uses MVVM (Model View View-Model) architecture.

Build-tool ๐Ÿงฐ

You need to have Android Studio Beta 3 or above to build this project.
Beta-studio


Ohh You want iOS App Too? ๐Ÿ“ฑ

Well, we've iOS version here, Checkout the iOS version of this app Expenso


Contribute ๐Ÿค

If you want to contribute to this app, you're always welcome! See Contributing Guidelines.


Contact ๐Ÿ“ฉ

Have an project? DM us at ๐Ÿ‘‡

Drop a mail to:- spikeysanju98@gmail.com


Donation ๐Ÿ’ฐ

If this project help you reduce time to develop, you can give me a cup of coffee :)

Buy Me A Coffee


Credits ๐Ÿค—


License ๐Ÿ”–

    Apache 2.0 License


    Copyright 2021 Spikey sanju

    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.
Apps
About Me
GitHub: Trinea
Facebook: Dev Tools