Add composable for search toolbar (#714)

This commit is contained in:
David Perez 2024-01-22 16:29:41 -06:00 committed by Álison Fernandes
parent be7ccd3195
commit e3d92966ac

View file

@ -0,0 +1,85 @@
package com.x8bit.bitwarden.ui.platform.components
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.material3.ExperimentalMaterial3Api
import androidx.compose.material3.Icon
import androidx.compose.material3.IconButton
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Text
import androidx.compose.material3.TextField
import androidx.compose.material3.TextFieldDefaults
import androidx.compose.material3.TopAppBar
import androidx.compose.material3.TopAppBarDefaults
import androidx.compose.material3.TopAppBarScrollBehavior
import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.res.stringResource
import com.x8bit.bitwarden.R
/**
* Represents a Bitwarden styled [TopAppBar] that assumes the following components:
*
* - an optional single navigation control in the upper-left defined by [navigationIcon].
* - an editable [TextField] populated by a [searchTerm] in the middle.
*/
@OptIn(ExperimentalMaterial3Api::class)
@Composable
fun BitwardenSearchTopAppBar(
searchTerm: String,
placeholder: String,
onSearchTermChange: (String) -> Unit,
scrollBehavior: TopAppBarScrollBehavior,
navigationIcon: NavigationIcon?,
modifier: Modifier = Modifier,
) {
TopAppBar(
modifier = modifier,
colors = TopAppBarDefaults.topAppBarColors(
containerColor = MaterialTheme.colorScheme.surface,
scrolledContainerColor = MaterialTheme.colorScheme.surfaceContainer,
navigationIconContentColor = MaterialTheme.colorScheme.onSurface,
titleContentColor = MaterialTheme.colorScheme.onSurface,
actionIconContentColor = MaterialTheme.colorScheme.onSurfaceVariant,
),
scrollBehavior = scrollBehavior,
navigationIcon = {
navigationIcon?.let {
IconButton(
onClick = it.onNavigationIconClick,
) {
Icon(
painter = it.navigationIcon,
contentDescription = it.navigationIconContentDescription,
)
}
}
},
title = {
TextField(
colors = TextFieldDefaults.colors(
focusedContainerColor = Color.Transparent,
unfocusedContainerColor = Color.Transparent,
focusedIndicatorColor = Color.Transparent,
unfocusedIndicatorColor = Color.Transparent,
),
placeholder = { Text(text = placeholder) },
value = searchTerm,
onValueChange = onSearchTermChange,
trailingIcon = {
IconButton(
onClick = { onSearchTermChange("") },
) {
Icon(
painter = painterResource(id = R.drawable.ic_close),
contentDescription = stringResource(id = R.string.clear),
)
}
},
modifier = Modifier
.fillMaxWidth(),
)
},
)
}