Agent Skills: Kotlin Compose Skill

Jetpack Compose - composables, state, effects, theming

kotlinjetpack-composeui-componentsthemingstate-management
developmentID: pluginagentmarketplace/custom-plugin-kotlin/kotlin-compose

Skill Files

Browse the full folder contents for kotlin-compose.

Download Skill

Loading file tree…

skills/kotlin-compose/SKILL.md

Skill Metadata

Name
kotlin-compose
Description
Jetpack Compose - composables, state, effects, theming

Kotlin Compose Skill

Build modern UIs with Jetpack Compose declarative patterns.

Topics Covered

State Management

@Composable
fun Counter() {
    var count by remember { mutableIntStateOf(0) }
    Button(onClick = { count++ }) { Text("Count: $count") }
}

// Derived state
val isValid by remember { derivedStateOf { email.isNotBlank() && password.length >= 8 } }

Side Effects

@Composable
fun UserScreen(userId: String) {
    LaunchedEffect(userId) {
        viewModel.loadUser(userId)
    }

    DisposableEffect(Unit) {
        val listener = viewModel.addListener()
        onDispose { listener.remove() }
    }
}

Modifiers

Box(
    modifier = Modifier
        .fillMaxSize()
        .padding(16.dp)
        .background(MaterialTheme.colorScheme.surface)
        .clickable { onClick() }
)

Material 3 Theming

@Composable
fun AppTheme(content: @Composable () -> Unit) {
    val colorScheme = if (isSystemInDarkTheme()) darkColorScheme() else lightColorScheme()
    MaterialTheme(colorScheme = colorScheme, typography = Typography, content = content)
}

Troubleshooting

| Issue | Resolution | |-------|------------| | Infinite recomposition | Use remember or derivedStateOf | | State lost on rotation | Use rememberSaveable or ViewModel |

Usage

Skill("kotlin-compose")