-
-
Notifications
You must be signed in to change notification settings - Fork 357
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
Migrate to Jetpack Compose (master) #5616
Comments
Current blockers and issues with Compose:
|
Re-do of About and Settings screen done, in review. Details here: https://github.com/streetcomplete/StreetComplete/pull/5719/files |
User screens are also done, except for the quest statistics / country statistics screen. See #5595 |
I'll look into the two tutorial screens (start tutorial, overlay tutorial) coming week. |
tutorial screens are done |
Next up would be the buttons and controls on the main screen plus the menus and dialogs there. So, this is an opportunity to redesign the main menu dialog, which I designed the way it is now chiefly because it was the easiest to do. In the future it could e.g. also be a popup menu, or a sheet that slides in (from the top, from the right?) like the undo menu does... I am open to suggestions. What's popular in other apps? |
Other approaches I see:
I actually quite like current StreetComplete "pop up in middle of the screen" menu, but other approaches are probably fine too, provided they happen fast (i.e. noticeably faster than half a second). |
Thanks for the input! I ended up mirroring the current appearance now. I am now working on migrating the UI of the main screen to compose, i.e.
Maybe now, maybe immediately afterwards:
|
…generally has the advantage as they can be used with one finger. And IMHO such a panel optionally including a gesture even (moving up from bottom) would be good too in SC, I don't quite like that you e.g. need to press (/go to) the top right icon for opening the menu. |
the complete user screen is now based on compose (including the statistics screen) |
The main screen, i.e. the buttons, the menus, the dialogs, the team mode, the dropdowns, the edit history sidebar, error handling and handling start parameters is also all based on compose. See #5799 (currently in alpha) |
Next step would be
|
Oh cool, you are contributing! It doesn't need to exactly look the same. It's more important to rather use mostly the normal (material) components than to endlessly customize the whole thing. (I.e. better to have less and maybe reusable code than to have a perfect match with how it looks like currently) |
@westnordost Do you prefer smaller PR's with single items, like, a PR for the button, then PR for another widget, or to let them build into a bigger PR? |
I prefer small PRs which however form a logical unit. E.g. a PR for just one of those buttons when they are not used anywhere yet would be a bit too small. The apply-last-answers-button-row plus building+roof level input form would be ideal as a PR. The apply-last-answers-button-row could maybe be generalized to be easily reusable in other forms with such an UI element, but work on other widgets and this kind of generalization stuff should ideally go into a follow-up PR and done when opportune. |
I have rapidly found that what I thought I knew about compose was not enough to do much more then make the button, and wire it into the existing form currently. I am going to be spending a week or two learning / playing with less complicated projects so I can continue attempting to contribute to this project. in the mean time, will submit a draft PR so not just dead in water |
This is the master ticket for migrating from the Android view system (layout XMLs etc.) to Jetpack Compose as UI framework.
The primary reason for this is #5421: To make possible an iOS version of this app that has a shared codebase for the UI through the use of Compose Multiplatform. The first step however is to migrate to Jetpack Compose and only later switch to Compose Multiplatform.
The first foray into Jetpack Compose has been made in PR #5447, I am also new to this but I tried to follow guidelines closely how things should be done, so feel free to look into that PR to learn how the UI code typically looks like before and after.
Contributing
As this is a larger undertaking which can be implemented step by step - this ticket shall serve as a master ticket. Whenever you would like to contribute, post on which screen or view you would like to work on now here and later post a PR when you are done.
Migration is generally done bottom-up, i.e. start with single views first and then work your way up to the screen-level, see Migration Strategy. For converting a whole screen, it is very advisable to do this only after the Fragment or Activity in question has been refactored to use ViewModels, see #5530.
The text was updated successfully, but these errors were encountered: