Skip to content
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

Migrated Custom Image Selector to Jetpack Compose #5964

Draft
wants to merge 21 commits into
base: main
Choose a base branch
from

Conversation

rohit9625
Copy link
Contributor

Description (required)

Fixes #5963

What changes did you make and why?
I've created the UI for the Custom Image Selector with some minor UI changes. We can't upload from Custom Selector as I am still working on it. Please feel free to test this branch on your device and let me know your thoughts. I am open to suggestions on the UI and functionality.

Tests performed (required)

Tested ProdDebug on Samsung A14 with API level 34.

Screenshots (for UI changes only)

@nicolas-raoul
Copy link
Member

I know it is a draft, but I could not resist trying 😊
It looks great and feels faster!
Not sure if useful but here are some observations:

I get this when coming from a previous version of the app:

java.lang.RuntimeException: Unable to start activity ComponentInfo{fr.free.nrw.commons/fr.free.nrw.commons.customselector.ui.selector.CustomSelectorActivity}: java.lang.NullPointerException: findViewById(...) must not be null
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:4129)

After deleting the app's data it opens fine.

When I select a pic and tap "Upload" or "Mark as not for upload", nothing happens.

I see no "Show already actioned images" switch.

After long-pressing a picture, I can not swipe it up (select for upload) or down (mark as not for upload).

@rohit9625
Copy link
Contributor Author

Thank you @nicolas-raoul for your valuable feedback 😊

MediaStore.Images.Media.DATE_ADDED,
MediaStore.Images.Media.MIME_TYPE
)
val cursor = context.contentResolver.query(
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you add a // TODO: comment - we also use Room in the app, and it supports returning a Flow from a query. Eventually migrating this query to Room and returning the Flow directly would simplify this code, and for now, a TODO comment will serve as a nice breadcrumb trail toward a better overall architecture.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for reviewing @psh. I doubt how Room can help fetch images from phone storage.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Migrate Custom Image Selector from XML to Jetpack Compose
3 participants