Customize your Jetpack Compose toolbar easily

Since Nutrient Android SDK 2024.2, our SDK provides a Toolbar that’s made entirely with Jetpack Compose. This toolbar is fully customizable and can be used with DocumentView. It’s an alternative version of our default toolbar that’s specifically designed to be used more flexibly with Jetpack Compose.

Just like top app bars, our MainToolbar has modifier, title, navigationIcon, and actions as parameters, as well as the documentState:

@Composable
fun MainToolbar(
    modifier: Modifier = Modifier,
    documentState: DocumentState,
    title: @Composable ((String) -> Unit)? = null,
    navigationIcon: @Composable (tintColor: Color) -> Unit = {},
    actions: @Composable RowScope.(tintColor: Color) -> Unit = {}
)

Usage

MainToolbar can be used in the following way:

MainToolbar(documentState = documentState)

Make sure to disable the default toolbar by adding defaultToolbarEnabled(false) to the existing PdfActivityConfiguration as follows:

val pdfActivityConfiguration = PdfActivityConfiguration
        .Builder(context)
        .defaultToolbarEnabled(false)
        .build()

val documentState = rememberDocumentState(pdf.toUri(), pdfActivityConfiguration)

MainToolbar is an independent composable, and to achieve immersive mode, its visibility needs to be handled explicitly. You can access the onImmersiveModeEnabled state from uiListener in DocumentManager and use it to manipulate the visibility of MainToolbar:

var toolbarVisibility by remember { mutableStateOf(true) }
...
// Used inside `DocumentManager` in `DocumentView`.
uiListener = DefaultListeners.uiListeners(onImmersiveModeEnabled = { enabled ->
             toolbarVisibility = enabled
        })
...
AnimatedVisibility(toolbarVisibility) {
             MainToolbar(documentState = documentState)
       }

Exploring further

We have a dedicated GitHub public repository demonstrating everything related to DocumentView and the MainToolbar.