androidkotlinandroid-jetpack-composeandroid-jetpackandroid-compose-appbar

Error: "@Composable invocations can only happen from the context of a @Composable function"


I'm trying to show a toast message when clicking on a toolbar action, but I got this error

@composable invocations can only happen from the context of a @composable function

Code:

@Composable
fun Toolbar() {
    TopAppBar(title = { Text(text = "Jetpack Compose") }, navigationIcon = {
        IconButton(onClick = {}) {
            Icon(Icons.Filled.Menu)
        }
    }, actions = {
        IconButton(onClick = {
            showMessage(message = "test")
        }) {
            Icon(vectorResource(id = R.drawable.ic_baseline_save_24))
        }
    })
}

@Preview
@Composable
fun ToolbarPreview(){
    Toolbar()
}

@Composable
fun showMessage(message:String){
    Toast.makeText(ContextAmbient.current, message, Toast.LENGTH_SHORT).show()
}

Solution

  • The onClick parameter doesn't accept a composable function. Remove the @Composable annotation in the showMessage.
    Use something like:

    @Composable
    fun Toolbar() {
    
        val context = LocalContext.current
    
        TopAppBar(title = {},
                actions = {
            IconButton(onClick = {
                showMessage(context, message = "test")
            }){}
        })
    }
    
    fun showMessage(context: Context, message:String){
        Toast.makeText(context, message, Toast.LENGTH_SHORT).show()
    }