-
-
Notifications
You must be signed in to change notification settings - Fork 358
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Use ViewModels (master) #5530
Comments
I added view models for
Now, the profile screen all has viewmodels. |
Added viewmodels for everything in the settings screen, the about screen and some controls on the main screen. |
and edit history, which spawned a crictical bug that has been fixed in v57.3 |
I have some time available in December, and I'd like to contribute to this. I did a quick search for |
On view models, mainly the map and every single quest form (and other forms) would need one. Currently, all this logic is in the quest form The viewmodel for map, though, shouldn't have such a big scope. However, if you are looking for the best way to contribute to the iOS port, take a look at #5421 (comment) (all the way down, to "Contributing"). At the moment, I think it would be easier to contribute by migrating more UI to Compose simply because it's easier to cut this pie into small pieces. |
This is the master ticket for refactoring to include view models. View models should be used for Fragments and Activities that either have a state that transcends the view lifecycle or access the data layer.
Contributing
As this is a larger undertaking which can be implemented step by step - a Fragment at a time - this ticket shall serve as a master ticket. Whenever you would like to contribute, select a Fragment, post that you are now working on that one here and later post a PR when you are done.
How to
How to find Fragments and Activities that should have view models
Search for activities and fragments that...
onSaveInstanceState
- it means it saves its state manually. This state should be in the ViewModelby inject()
- it means that dependencies are injected which are likely part of the data layer. Data access should be managed by the ViewModelparentFragment as? Listener ?: activity as? Listener
- this pattern is used for communication between fragments. This can be replaced with shared view models, but when using Compose, probably only the top-level fragments will remain as fragments anyway. So, wait with that until using ComposeHow to implement ViewModels
ViewModel documentation
If you are like me and learn best by example / by copying. Look in the code for classes named
*ViewModel
and*ViewModelImpl
. For exampleEditStatisticsViewModelImpl
.This will also give you a good idea in which style ViewModels should be written and what code should go into the ViewModel and what should remain the the View (i.e. the Fragment).
The ViewModels job is to supply the view with the data it needs with a convenient interface and data structure, hold this state and also offer an interface to manipulate the data, if applicable.
Advantages
We want to refactor the code to use ViewModels for the following reasons:
For the planned iOS version, we will migrate (step by step) to Compose Multiplatform as UI framework. This means that use of Android-specific
Fragments
andActivities
must eliminated. A step towards this goal is to separate state and data access from these into platform independent codeFor keeping (view) state that transcends the view lifecycle it is more convenient, as it does not need to be saved and manually re-created
It provides a better separation between view logic and view data. Quite necessary when using Compose as UI framework and at least highly recommended otherwise
It will likely simplify communication between fragments
It's quite standard to use this pattern and recommended by Android architectural design guidelines. The more standard things are used in StreetComplete, the easier it is for new contributors to join
(This ticket supsersedes #5070 which also included a lot of discussion.)
The text was updated successfully, but these errors were encountered: