Make your AI coding tool actually understand Compose — Android, Desktop, iOS, and Web.
Backed by real source code from androidx/androidx and compose-multiplatform-core — not vibes.
AI coding tools generate Compose code that compiles but gets the details wrong. Incorrect remember usage, unstable recompositions, broken modifier ordering, deprecated navigation patterns, hallucinated APIs that don't exist. They guess at behavior instead of knowing it.
This skill fixes that by giving your AI assistant two things:
- 17 reference guides covering every major Compose topic — including Compose Multiplatform, design-to-code workflows, animation recipes, and production crash patterns
- 6 source code files pulled directly from
androidx/androidxandcompose-multiplatform-coreso the agent can check how things actually work
| Area | Without the skill | With it |
|---|---|---|
| State | Uses remember { mutableStateOf() } everywhere, even when derivedStateOf or rememberSaveable is the right call |
Picks the right state primitive for each situation |
| Performance | Generates code that recomposes every frame | Applies stability annotations, deferred reads, key {} on lists |
| Navigation | String-based routes (deprecated) | Type-safe routes with @Serializable route classes |
| Modifiers | Random ordering, misses clickable before padding bugs |
Correct ordering with reasoning |
| Side effects | Wrong coroutine scope, bad LaunchedEffect keys |
Correct effect selection and lifecycle-aware keys |
| APIs | Hallucinates parameters that don't exist | Checks against actual source before suggesting |
| Multiplatform | Uses Android-only APIs in shared code | Uses expect/actual, Res.* resources, platform-correct patterns |
| Design-to-code | Literal Figma node translation, wrong modifier ordering | Semantic M3 components, correct ordering, theme tokens |
| Crash safety | No defensive patterns | Guards against zero-size DrawScope, duplicate keys, stale derivedStateOf |
| Topic | What the agent learns |
|---|---|
| State management | remember, mutableStateOf, derivedStateOf, rememberSaveable, state hoisting, snapshotFlow |
| View composition | Structuring composables, slot APIs, @Preview patterns, extraction rules |
| Performance | Recomposition skipping, @Stable/@Immutable, deferred reads, baseline profiles, benchmarking |
| Navigation | Type-safe routes, NavHost, deep links, shared element transitions, back stack |
| Animation | animate*AsState, AnimatedVisibility, Crossfade, updateTransition, shared transitions, 9 recipes (shimmer, swipe-to-dismiss, etc.), gesture-driven patterns, Figma curve mapping |
| Lists and scrolling | LazyColumn/LazyRow/LazyGrid, Pager, key {}, contentType, scroll state |
| Side effects | LaunchedEffect, DisposableEffect, SideEffect, rememberCoroutineScope |
| Modifiers | Ordering rules, custom modifiers, Modifier.Node migration |
| Theming | MaterialTheme, ColorScheme, dynamic color, Typography, shapes, dark theme |
| Accessibility | Semantics, content descriptions, traversal order, touch targets, TalkBack |
| CompositionLocals | LocalContext, LocalDensity, custom locals, when to use vs. parameter passing |
| Deprecated patterns | Removed APIs, migration paths from older Compose versions |
| Styles API (experimental) | Style {}, MutableStyleState, Modifier.styleable(), composition, theme integration, alpha06 gotchas |
| Design-to-code | Composable decomposition algorithm, Figma property mapping, spacing ownership, modifier ordering, design tokens |
| Production crash playbook | 6 crash patterns with root cause + fix, defensive patterns, production state/performance rules |
| Compose Multiplatform | CMP architecture, expect/actual, Res.* resources, API availability matrix, migration guide |
| Platform specifics | Desktop (Window, Tray, MenuBar), iOS (UIKitView, gotchas), Web/WASM (canvas limitations) |
| Source code | Actual .kt from androidx/androidx and compose-multiplatform-core for runtime, UI, foundation, material3, navigation, CMP |
You ask about Compose
|
v
AI reads SKILL.md (workflow + checklists)
|
v
Consults the right reference file
|
+-- state-management.md
+-- performance.md
+-- navigation.md
+-- design-to-compose.md
+-- production-crash-playbook.md
+-- multiplatform.md
+-- platform-specifics.md
+-- ... (17 guides total)
|
+-- source-code/
+-- runtime-source.md
+-- material3-source.md
+-- cmp-source.md
+-- ... (6 source files)
Layer 1: guidance docs (17 files) — practical references with patterns, pitfalls, and do/don't examples. This is what the agent reads first.
Layer 2: source code receipts (6 files) — the actual Kotlin source from androidx/androidx and compose-multiplatform-core. When the agent needs to verify an implementation detail rather than guess, it reads these.
jetpack-compose-expert-skill/
├── SKILL.md # Main workflow + checklists
└── references/
├── state-management.md # State, remember, hoisting, derivedStateOf
├── view-composition.md # Structuring composables, slots, previews
├── modifiers.md # Modifier ordering, custom modifiers, Modifier.Node
├── side-effects.md # LaunchedEffect, DisposableEffect, SideEffect
├── composition-locals.md # CompositionLocal, LocalContext, custom locals
├── lists-scrolling.md # LazyColumn/Row/Grid, Pager, keys, contentType
├── navigation.md # NavHost, type-safe routes, deep links
├── animation.md # animate*AsState, AnimatedVisibility, transitions
├── theming-material3.md # MaterialTheme, ColorScheme, dynamic color
├── performance.md # Recomposition, stability, benchmarking
├── accessibility.md # Semantics, content descriptions, testing
├── deprecated-patterns.md # Removed APIs, migration paths
├── styles-experimental.md # Styles API (@ExperimentalFoundationStyleApi)
├── design-to-compose.md # Figma/screenshot decomposition, property mapping
├── production-crash-playbook.md # Crash patterns, defensive coding, production rules
├── multiplatform.md # CMP architecture, expect/actual, Res.*, migration
├── platform-specifics.md # Desktop, iOS, Web/WASM platform APIs and gotchas
└── source-code/ # Actual .kt source
├── runtime-source.md # Composer, Recomposer, State, Effects
├── ui-source.md # AndroidCompositionLocals, Modifier, Layout
├── foundation-source.md # LazyList, BasicTextField, Gestures
├── material3-source.md # MaterialTheme, all M3 components
├── navigation-source.md # NavHost, ComposeNavigator
└── cmp-source.md # Window, UIKitView, ComposeViewport, Resources
The skill is just markdown files. Every tool below reads the same content. Pick yours.
Skills are file-based — Claude Code discovers them automatically from ~/.claude/skills/ (personal) or .claude/skills/ (project-specific).
Personal skill (available in all your projects):
# Clone the repo
git clone https://github.com/aldefy/compose-skill.git /tmp/compose-skill
# Copy into your personal skills directory
mkdir -p ~/.claude/skills
cp -r /tmp/compose-skill/jetpack-compose-expert-skill ~/.claude/skills/Project-specific skill (just one project):
# Clone the repo
git clone https://github.com/aldefy/compose-skill.git /tmp/compose-skill
# Copy into your project's .claude/skills directory
mkdir -p .claude/skills
cp -r /tmp/compose-skill/jetpack-compose-expert-skill .claude/skills/No CLI command or config file needed. Claude Code picks up SKILL.md from these directories automatically and triggers when you mention Compose, @Composable, remember, LazyColumn, NavHost, etc.
Add an AGENTS.md file to your project root:
# AGENTS.md
## Jetpack Compose
For all Compose/Android UI tasks, follow the instructions in
`jetpack-compose-expert-skill/SKILL.md` and consult the reference
files in `jetpack-compose-expert-skill/references/` before answering.Add the skill to your project as a submodule:
git submodule add https://github.com/aldefy/compose-skill.git .compose-skillCodex discovers AGENTS.md files automatically from the git root down to the current directory.
Add to GEMINI.md in your project root:
# GEMINI.md
## Jetpack Compose Expert
For all Jetpack Compose tasks, follow the workflow and checklists in
`jetpack-compose-expert-skill/SKILL.md`.
Before answering any Compose question, consult the relevant reference:
- State management -> `jetpack-compose-expert-skill/references/state-management.md`
- Performance -> `jetpack-compose-expert-skill/references/performance.md`
- Navigation -> `jetpack-compose-expert-skill/references/navigation.md`
- (see SKILL.md for the full topic -> file mapping)
For implementation details, check actual source code in
`jetpack-compose-expert-skill/references/source-code/`.Add as a submodule:
git submodule add git@github.com:aldefy/compose-skill.git .compose-skillCreate .cursor/rules/compose-skill.mdc:
---
description: Jetpack Compose expert guidance
globs: **/*.kt
---
Follow the instructions in `jetpack-compose-expert-skill/SKILL.md`
for all Compose-related code. Consult reference files in
`jetpack-compose-expert-skill/references/` before suggesting patterns.Or paste the contents of SKILL.md into Settings > Rules for AI.
Add to .github/copilot-instructions.md:
## Jetpack Compose
For Compose/Android UI work, follow the skill instructions in
`jetpack-compose-expert-skill/SKILL.md`. Consult reference files in
`jetpack-compose-expert-skill/references/` for patterns, pitfalls,
and source-code-backed guidance.Create .windsurf/rules/compose-skill.md in your project root:
For all Jetpack Compose tasks, follow the workflow in
`jetpack-compose-expert-skill/SKILL.md` and consult the reference
files in `jetpack-compose-expert-skill/references/` before answering.Note: The legacy
.windsurfrulesfile also works but.windsurf/rules/is the current approach.
Add to .amazonq/rules/compose.md:
For all Jetpack Compose tasks, follow the workflow in
`jetpack-compose-expert-skill/SKILL.md` and consult the reference
files in `jetpack-compose-expert-skill/references/` before answering.It's just markdown. Clone this repo into your project (or add as a submodule), then point your tool's instruction file at jetpack-compose-expert-skill/SKILL.md. The agent reads SKILL.md for the workflow and pulls from references/ as needed.
After setup, just talk to your AI assistant normally:
"My LazyColumn is janky when scrolling — help me fix it"
What happens:
- Agent reads
SKILL.mdfor the workflow - Pulls in
references/lists-scrolling.mdandreferences/performance.md - Checks your code for missing
key {}, unstable item types, heavy compositions in item blocks - If something's unclear, verifies against
references/source-code/foundation-source.md - Gives you a fix based on the actual
LazyListimplementation
No hallucinated APIs. No guessed behavior.
Source code comes from androidx/androidx and JetBrains/compose-multiplatform-core under Apache License 2.0. The guidance docs are original analysis of those sources plus official documentation.
PRs welcome, especially:
- Additional platform-specific gotchas and workarounds
- New animation recipes for common UI patterns
- Production crash patterns from real apps
- Corrections based on newer Compose/CMP releases
- Auto-update tooling for tracking new releases
MIT — see LICENSE.
Source code from androidx/androidx is Apache License 2.0, copyright The Android Open Source Project. Source code from compose-multiplatform-core is Apache License 2.0, copyright JetBrains s.r.o.