npx claudepluginhub aldefy/compose-skill --plugin compose-expertThis skill uses the workspace's default tool permissions.
> **Installation notice:** This skill is now distributed as a plugin.
references/accessibility.mdreferences/animation.mdreferences/atomic-design.mdreferences/auto-init.mdreferences/composition-locals.mdreferences/deprecated-patterns.mdreferences/design-to-compose.mdreferences/lists-scrolling.mdreferences/material3-motion.mdreferences/modifiers.mdreferences/multiplatform.mdreferences/navigation-migration.mdreferences/navigation.mdreferences/paging-mvi-testing.mdreferences/paging-offline.mdreferences/paging.mdreferences/performance.mdreferences/platform-specifics.mdreferences/pr-review.mdreferences/production-crash-playbook.mdProvides Jetpack Compose patterns for state hoisting, remember variants, slot APIs, modifiers, side effects, theming, animations, and performance in Android UI development.
Provides expert patterns for Android and Kotlin development: Jetpack Compose UI, Clean Architecture, coroutines, Room, navigation, Hilt DI, testing. Use when building apps or reviewing Android code.
Guides building native Android UIs with Jetpack Compose, including state management via remember/mutableStateOf, state hoisting, and ViewModel integration.
Share bugs, ideas, or general feedback.
Installation notice: This skill is now distributed as a plugin. If you copied files into
~/.claude/skills/manually, you are on an unmaintained install path and will not receive updates. Migrate via:/plugin marketplace add aldefy/compose-skill /plugin install compose-expertSee MIGRATION.md for Codex and Copilot CLI instructions. This banner will remain through v2.x and escalate in v3.0.
The frontmatter description: is intentionally short to satisfy Codex / Copilot
CLI's 1024-character cap on that field (see issue #12). The full trigger surface
lives here so it stays available to Claude after the skill loads.
@Composable, remember, mutableStateOf, derivedStateOf, rememberSaveable,
LaunchedEffect, DisposableEffect, SideEffect, rememberCoroutineScope,
Scaffold, NavHost, NavController, MaterialTheme, ColorScheme,
Typography, LazyColumn, LazyRow, LazyVerticalGrid, HorizontalPager,
Modifier, Modifier.Node, recomposition, CompositionLocal, Style,
styleable, MutableStyleState.
Compose Multiplatform, CMP, KMP, commonMain, expect, actual,
ComposeUIViewController, Window composable, UIKitView, ComposeViewport,
Res.drawable, Res.string, SkikoMain.
tv-material, tv-foundation, Carousel, NavigationDrawer (TV),
D-pad, focus indication, FocusRequester on TV, 10-foot UI,
living room, tv compose, Android TV, Google TV, leanback migration.
PagingSource, Pager, PagingConfig, PagingData, LazyPagingItems,
collectAsLazyPagingItems, RemoteMediator, LoadState,
asSnapshot, TestPager, cachedIn.
atomic design, atoms, molecules, organisms, templates,
design tokens, design system, component library, reusable component,
Figma to Compose, design to compose, build this UI, implement this design,
spec to code, redline.
"my compose screen is slow", "my recomposition is broken", "how do I pass data between screens", "how do I build a TV app", "Android UI", "Kotlin UI", "compose layout", "compose navigation", "compose animation", "compose styles", "desktop compose", "iOS compose", "compose web".
Any GitHub PR URL matching github.com/.*/pull/\d+, or phrases:
"review this PR", "review this diff", "review this code",
"check this code", "check this diff", "what's wrong with this".
On match, follow references/pr-review.md exclusively.
Auto-detect Compose projects on session_start — see references/auto-init.md.
Use this table first. Match the user's signal to one reference file and read it before
answering. source-code/ files are supporting evidence — load a references/*.md file
first, then cite source-code/ for implementation proof when receipts matter.
remember, rememberSaveable, mutableStateOf vs mutableIntStateOf, state hoisting → references/state-management.mdderivedStateOf, snapshotFlow, StateFlow in UI, recomposition scope boundaries → references/state-management.md (secondary: references/performance.md)LaunchedEffect, SideEffect, DisposableEffect, rememberUpdatedState, rememberCoroutineScope → references/side-effects.md@Stable/@Immutable, Compose compiler metrics, baseline profiles, strong skipping → references/performance.mdCompositionLocal, ambient values, theming propagation, LocalContext misuse, custom locals → references/composition-locals.mdanimate*AsState, AnimatedVisibility, Crossfade, updateTransition, Animatable, rememberInfiniteTransition → references/animation.mdModifier.graphicsLayer, Canvas drawing, custom motion spec → references/animation.md (secondary: references/modifiers.md for graphicsLayer)MotionTokens, MotionScheme, animation duration tokens, M3 easing curves → references/material3-motion.mdLazyColumn, LazyRow, LazyVerticalGrid, LazyHorizontalGrid, key/itemKey, contentType, LazyListState, scroll state, sticky headers → references/lists-scrolling.mdHorizontalPager, VerticalPager, PagerState → references/lists-scrolling.mdLayout, SubcomposeLayout, layout modifier, draw modifier, Painter, Modifier.Node → references/modifiers.mdNavHost, NavController, back stack, deep links, type-safe @Serializable routes, navigation graph, nested graphs → references/navigation.mdNavDisplay, NavKey, rememberNavBackStack, NavBackStackEntry changes → references/navigation-migration.mdreferences/navigation-migration.md (secondary: references/navigation.md)PagingSource, PagingData, Pager setup, PagingConfig, pagingDataFlow, invalidation → references/paging.mdLazyPagingItems, collectAsLazyPagingItems, itemKey, itemContentType, LoadState in UI, retry/refresh → references/paging.mdRemoteMediator, offline-first paging, network + cache paging, loadState.source.refresh → references/paging-offline.mdasSnapshot, TestPager), CombinedLoadStates, paging anti-patterns → references/paging-mvi-testing.mdMaterialTheme, ColorScheme, Typography, Shapes, dynamic color, M3 tokens, color roles → references/theming-material3.mdreferences/atomic-design.mdreferences/design-to-compose.mdStyle {}, MutableStyleState, Modifier.styleable() (experimental Foundation Styles API) → references/styles-experimental.mdexpect/actual, commonMain, Res.drawable, Res.string, platform-specific composables → references/multiplatform.mdComposeUIViewController (iOS), Window/Tray/MenuBar (Desktop), UIKitView, ComposeViewport (Web), platform interop → references/platform-specifics.mdandroidx.tv, D-pad focus, FocusRequester on TV, Carousel, NavigationDrawer (TV), 10-foot UI, leanback migration → references/tv-compose.mdAndroidView, ComposeView, AbstractComposeView, hybrid migration, View → Compose interop → references/view-composition.mdModifier.semantics, TalkBack, touch target size, contentDescription, WCAG, traversal order → references/accessibility.mdremember leak, zero-size DrawScope, duplicate keys, stale derivedStateOf → references/production-crash-playbook.mdreferences/pr-review.mdreferences/deprecated-patterns.md@OptIn, @ExperimentalFoundationStyleApi, unstable API usage → references/styles-experimental.md (for Styles); for general guidance, the relevant topic filereferences/auto-init.mdreferences/source-code/*.md file:
references/source-code/runtime-source.mdreferences/source-code/ui-source.mdreferences/source-code/foundation-source.mdreferences/source-code/material3-source.mdreferences/source-code/navigation-source.mdreferences/source-code/cmp-source.mdNon-opinionated, practical guidance for writing correct, performant Compose code —
across Android, Desktop, iOS, and Web. Covers Jetpack Compose and Compose Multiplatform.
Backed by analysis of actual source code from androidx/androidx and
JetBrains/compose-multiplatform-core.
Activate when the input contains a GitHub PR URL (github.com/.+/pull/\d+) or
explicit review phrases: "review this PR", "review this diff", "check this code",
"what's wrong with this".
When Review Mode activates:
references/pr-review.md and follow its workflow exclusivelyWhen helping with Compose code, follow this checklist:
references/design-to-compose.mdreferences/animation.md for recipesRead the relevant reference file(s) from references/ before answering:
| Topic | Reference File |
|---|---|
@State, remember, mutableStateOf, state hoisting, derivedStateOf, snapshotFlow | references/state-management.md |
| Structuring composables, slots, extraction, preview | references/view-composition.md — for design system structure, also see references/atomic-design.md |
Modifier ordering, custom modifiers, Modifier.Node | references/modifiers.md |
LaunchedEffect, DisposableEffect, SideEffect, rememberCoroutineScope | references/side-effects.md |
CompositionLocal, LocalContext, LocalDensity, custom locals | references/composition-locals.md |
LazyColumn, LazyRow, LazyGrid, Pager, keys, content types | references/lists-scrolling.md |
NavHost, type-safe routes, deep links, shared element transitions | references/navigation.md |
animate*AsState, AnimatedVisibility, Crossfade, transitions | references/animation.md — for M3 token selection, also see references/material3-motion.md |
MaterialTheme, ColorScheme, dynamic color, Typography, shapes | references/theming-material3.md — for motion, see references/material3-motion.md; for design tokens, see references/atomic-design.md |
| Recomposition skipping, stability, baseline profiles, benchmarking | references/performance.md |
| Semantics, content descriptions, traversal order, testing | references/accessibility.md |
| Removed/replaced APIs, migration paths from older Compose versions | references/deprecated-patterns.md |
Styles API (experimental): Style {}, MutableStyleState, Modifier.styleable() | references/styles-experimental.md |
| Figma/screenshot decomposition, design tokens, spacing, modifier ordering | references/design-to-compose.md |
| Production crash patterns, defensive coding, state/performance rules | references/production-crash-playbook.md |
Compose Multiplatform, expect/actual, resources (Res.*), migration | references/multiplatform.md |
| Desktop (Window, Tray, MenuBar), iOS (UIKitView), Web (ComposeViewport) | references/platform-specifics.md |
| TV Compose: Surface, Carousel, NavigationDrawer, Cards, focus, D-pad | references/tv-compose.md |
M3 motion tokens, MotionTokens, MotionScheme, animation duration, easing | references/material3-motion.md |
| PR URL, code review, "review this PR", "what's wrong with this" | references/pr-review.md |
| Session start, project detection | references/auto-init.md |
| Atomic design, design system, reusable component, component library, design tokens | references/atomic-design.md |
When the request involves building a component (composable that renders UI):
references/atomic-design.mdWhen referencing Compose internals, point to the exact source file:
// See: compose/runtime/runtime/src/commonMain/kotlin/androidx/compose/runtime/Composer.kt
Compose thinks in three phases: Composition → Layout → Drawing. State reads in each phase only trigger work for that phase and later ones.
Recomposition is frequent and cheap — but only if you help the compiler skip unchanged scopes. Use stable types, avoid allocations in composable bodies.
Modifier order matters. Modifier.padding(16.dp).background(Color.Red) is visually
different from Modifier.background(Color.Red).padding(16.dp).
State should live as low as possible and be hoisted only as high as needed. Don't put everything in a ViewModel just because you can.
Side effects exist to bridge Compose's declarative world with imperative APIs. Use the right one for the job — misusing them causes bugs that are hard to trace.
Compose Multiplatform shares the runtime but not the platform. UI code in
commonMain is portable. Platform-specific APIs (LocalContext, BackHandler,
Window) require expect/actual or conditional source sets.
Beyond the guidance docs, this skill bundles the actual source code from
androidx/androidx (branch: androidx-main) and JetBrains/compose-multiplatform-core
(branch: jb-main). When you need to verify how something works internally, or the
user asks "show me the actual implementation", read the raw source from
references/source-code/:
| Module | Source Reference | Key Files Inside |
|---|---|---|
| Runtime | references/source-code/runtime-source.md | Composer.kt, Recomposer.kt, State.kt, Effects.kt, CompositionLocal.kt, Remember.kt, SlotTable.kt, Snapshot.kt |
| UI | references/source-code/ui-source.md | AndroidCompositionLocals.android.kt, Modifier.kt, Layout.kt, LayoutNode.kt, ModifierNodeElement.kt, DrawModifier.kt |
| Foundation | references/source-code/foundation-source.md | LazyList.kt, LazyGrid.kt, BasicTextField.kt, Clickable.kt, Scrollable.kt, Pager.kt |
| Material3 | references/source-code/material3-source.md | MaterialTheme.kt, ColorScheme.kt, Button.kt, Scaffold.kt, TextField.kt, NavigationBar.kt |
| Navigation | references/source-code/navigation-source.md | NavHost.kt, ComposeNavigator.kt, NavGraphBuilder.kt, DialogNavigator.kt |
| CMP | references/source-code/cmp-source.md | Window.kt, ComposeUIViewController.kt, UIKitView.kt, ComposeViewport.kt, ResourceReader.kt |
references/state-management.md)references/source-code/androidx/androidx (branch: androidx-main)
├── compose/runtime/runtime/src/commonMain/kotlin/androidx/compose/runtime/
├── compose/ui/ui/src/androidMain/kotlin/androidx/compose/ui/platform/
├── compose/ui/ui/src/commonMain/kotlin/androidx/compose/ui/
├── compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/
├── compose/material3/material3/src/commonMain/kotlin/androidx/compose/material3/
├── compose/navigation/navigation-compose/src/commonMain/kotlin/androidx/navigation/compose/
├── tv/tv-material/src/main/java/androidx/tv/material3/
└── tv/tv-foundation/src/main/java/androidx/tv/foundation/
compose-multiplatform-core (branch: jb-main)
├── compose/ui/ui/src/desktopMain/kotlin/androidx/compose/ui/window/
├── compose/ui/ui/src/iosMain/kotlin/androidx/compose/ui/window/
├── compose/ui/ui/src/webMain/kotlin/androidx/compose/ui/window/
├── compose/ui/ui/src/skikoMain/kotlin/androidx/compose/ui/
└── compose/foundation/foundation/src/skikoMain/kotlin/androidx/compose/foundation/
compose-multiplatform (resources library)
└── components/resources/library/src/commonMain/