compose-ui▌
new-silvermoon/awesome-android-agent-skills · updated Apr 8, 2026
Follow these guidelines to create performant, reusable, and testable Composables.
Jetpack Compose Best Practices
Instructions
Follow these guidelines to create performant, reusable, and testable Composables.
1. State Hoisting (Unidirectional Data Flow)
Make Composables stateless whenever possible by moving state to the caller.
- Pattern: Function signature should usually look like:
@Composable fun MyComponent( value: String, // State flows down onValueChange: (String) -> Unit, // Events flow up modifier: Modifier = Modifier // Standard modifier parameter ) - Benefit: Decouples the UI from simple state storage, making it easier to preview and test.
- ViewModel Integration: The screen-level Composable retrieves state from the ViewModel (
viewModel.uiState.collectAsStateWithLifecycle()) and passes it down.
2. Modifiers
- Default Parameter: Always provide a
modifier: Modifier = Modifieras the first optional parameter. - Application: Apply this
modifierto the root layout element of your Composable. - Ordering matters:
padding().clickable()is different fromclickable().padding(). Generally apply layout-affecting modifiers (like padding) after click listeners if you want the padding to be clickable.
3. Performance Optimization
remember: Useremember { ... }to cache expensive calculations across recompositions.derivedStateOf: UsederivedStateOf { ... }when a state changes frequently (like scroll position) but the UI only needs to react to a threshold or summary (e.g., show "Jump to Top" button). This prevents unnecessary recompositions.val showButton by remember { derivedStateOf { listState.firstVisibleItemIndex > 0 } }- Lambda Stability: Prefer method references (e.g.,
viewModel::onEvent) or remembered lambdas to prevent unstable types from triggering recomposition of children.
4. Theming and Resources
- Use
MaterialTheme.colorSchemeandMaterialTheme.typographyinstead of hardcoded colors or text styles. - Organize simple UI components into specific files (e.g.,
DesignSystem.ktorComponents.kt) if they are shared across features.
5. Previews
- Create a private preview function for every public Composable.
- Use
@Preview(showBackground = true)and include Light/Dark mode previews if applicable. - Pass dummy data (static) to the stateless Composable for the preview.
Discussion
Product Hunt–style comments (not star reviews)- No comments yet — start the thread.
Ratings
4.8★★★★★56 reviews- ★★★★★Isabella Ghosh· Dec 28, 2024
Useful defaults in compose-ui — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.
- ★★★★★Soo Desai· Dec 24, 2024
We added compose-ui from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.
- ★★★★★Mia Sharma· Dec 24, 2024
Keeps context tight: compose-ui is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Benjamin Srinivasan· Dec 20, 2024
I recommend compose-ui for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.
- ★★★★★Chinedu Srinivasan· Dec 12, 2024
compose-ui is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
- ★★★★★Chaitanya Patil· Dec 8, 2024
compose-ui has been reliable in day-to-day use. Documentation quality is above average for community skills.
- ★★★★★Piyush G· Nov 27, 2024
Keeps context tight: compose-ui is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Mia Iyer· Nov 19, 2024
compose-ui is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
- ★★★★★Hana Sanchez· Nov 15, 2024
compose-ui fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.
- ★★★★★Arjun Brown· Nov 3, 2024
Useful defaults in compose-ui — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.
showing 1-10 of 56