This is a comprehensive review and generation assistant for Jetpack Compose projects that enforces modern Android patterns across eleven reference categories, from API usage to accessibility. It follows a structured checklist covering state management (ViewModel + StateFlow), lifecycle-aware collection, Material 3 compliance, recomposition stability, and performance optimizations like proper LazyColumn keys. Output is organized by file with before/after snippets and prioritized summaries. The approach is pragmatic: it targets Compose BOM 2024.x, assumes MVVM with unidirectional data flow, and explicitly avoids style nitpicking unless there's a clear rule violation. If you're working on any Compose codebase and want enforcement of current best practices without the noise, this gives you a methodical way to catch real issues.
npx -y skills add anhvt52/jetpack-compose-skills --skill modern-jetpack-compose --agent claude-codeInstalls into .claude/skills of the current project.
Review or generate Jetpack Compose code for correctness, modern API usage, and adherence to Android best practices. Report only genuine issues — do not nitpick style unless it contradicts a clear rule.
When reviewing existing code, follow these steps in order:
references/api.mdreferences/composables.mdreferences/state.mdreferences/effects.mdreferences/recomposition.mdreferences/navigation.mdreferences/design.mdreferences/accessibility.mdreferences/performance.mdreferences/kotlin.mdreferences/hygiene.mdWhen generating new code, load the relevant reference files for the feature being built before writing any code, so output is idiomatic from the start.
For partial reviews or targeted generation, load only the relevant reference files.
Organize findings by file. For each issue:
Skip files with no issues. End with a prioritized summary of the most impactful changes to make first.
Example output:
Line 14: Use collectAsStateWithLifecycle() instead of collectAsState().
// Before
val uiState by viewModel.uiState.collectAsState()
// After
val uiState by viewModel.uiState.collectAsStateWithLifecycle()
Line 42: Provide key in LazyColumn for stable item identity.
// Before
LazyColumn {
items(books) { book ->
BookItem(book)
}
}
// After
LazyColumn {
items(books, key = { it.id }) { book ->
BookItem(book)
}
}
Line 67: Image missing contentDescription — required for accessibility.
// Before
Image(painter = painterResource(R.drawable.cover), contentDescription = null)
// After — if decorative:
Image(painter = painterResource(R.drawable.cover), contentDescription = null) // OK if truly decorative
// After — if meaningful:
Image(
painter = painterResource(R.drawable.cover),
contentDescription = stringResource(R.string.book_cover_description)
)
collectAsState() on line 14 does not respect lifecycle — replace with collectAsStateWithLifecycle().key in LazyColumn on line 42 causes unnecessary recomposition.contentDescription.references/api.md — deprecated APIs and their modern replacements.references/composables.md — composable structure, naming, and composition patterns.references/state.md — state management, ViewModel, StateFlow, and data flow.references/effects.md — side effects: LaunchedEffect, DisposableEffect, SideEffect.references/recomposition.md — recomposition stability, @Stable/@Immutable, derivedStateOf.references/navigation.md — Navigation Compose, type-safe nav, nested graphs.references/design.md — Material 3 / Expressive theming, adaptive layouts.references/accessibility.md — TalkBack, semantics, content descriptions, touch targets.references/performance.md — LazyList optimization, remember, scope of state reads.references/kotlin.md — modern Kotlin patterns for Android.references/hygiene.md — code hygiene, testing, lint.sickn33/antigravity-awesome-skills
wshobson/agents
kotlin/kotlin-agent-skills