Skip to main content

Code with me: Savings Tracker App- Part 1: Setting up File Structure

 My goal for this project is to create a savings tracker app. With this project, I will also be learning how to implement clean app architecture and use Provider for State Management. I may even endeavor to create my own SQL database for local storage. 

I came across this tutorial on how to use Provider and the MVVM app architecture. I like this tutorial because he broke down the Model View View Model architecture in a way that I was able to grasp. 


What is a View Model?

The Model is the business logic portion of the app. Business logic is the core function of the app. It is what you would be able to do on paper if you didn't have a computer. For my savings tracker app, the business logic is the function that allows you to add and subtract money from the savings fund. 

What is a View?

The View is the UI of the app. It is the screens and buttons that the user interacts with. To have clean architecture it is important to keep the business logic and any databases or APIs completely separate from the UI. 


What is Model?

The Model is the part of your app that gets data from outside of your app like a database or API. You should write all of the code that fetches the data in a separate file from your UI or business logic. 

What is a Service?

There is also something called Services. This is what stands between each of the three components and sends data to and from each of them. The service can also be described similarly to the model. It holds the functions that fetch the data. 


In my app, I will create three folders in my lib folder: Business Logic, UI, Services. Inside of these folders, I will set up the initial files I think my app will need. I will not put anything inside of these files just yet. 





 Next time I will start coding the business logic portion of my app starting with the transaction view model. 

Comments