Tab Groups
Tabs organize content into separate panels, accessible by clicking labeled tabs or by focusing via keyboard.
Bottom Navigation Bar
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import com.composables.uikit.styling.textStyles
import androidx.compose.foundation.layout.size
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.alpha
import androidx.compose.ui.graphics.vector.ImageVector
import androidx.compose.ui.unit.dp
import com.composables.icons.lucide.House
import com.composables.icons.lucide.Lucide
import com.composables.icons.lucide.PersonStanding
import com.composables.icons.lucide.Search
import com.composables.uikit.components.BottomNavigationBar
import com.composables.uikit.components.Icon
import com.composables.uikit.components.PrimaryTab
import com.composables.uikit.components.TabGroup
import com.composables.uikit.components.TabPanel
import com.composables.uikit.styling.title
import com.composeunstyled.Text
import com.composeunstyled.theme.Theme
@Composable
fun BottomNavigationBarExample() {
class Category(val key: String, val icon: ImageVector)
val Home = Category("Home", Lucide.House)
val Search = Category("Search", Lucide.Search)
val Profile = Category("Profile", Lucide.PersonStanding)
var selectedTab by remember { mutableStateOf(Home.key) }
val categories = listOf(Home, Search, Profile)
TabGroup(selectedTab = selectedTab, tabs = categories.map { it.key }, modifier = Modifier.fillMaxWidth()) {
categories.forEach { category ->
TabPanel(
key = category.key,
modifier = Modifier.weight(1f).fillMaxWidth(),
contentAlignment = Alignment.Center
) {
Column(horizontalAlignment = Alignment.CenterHorizontally) {
Icon(
imageVector = category.icon,
contentDescription = null,
modifier = Modifier.size(96.dp).alpha(0.4f)
)
Spacer(Modifier.height(8.dp))
Text(category.key, style = Theme[textStyles][title])
}
}
}
BottomNavigationBar(Modifier.fillMaxWidth()) {
categories.forEach { category ->
val selected = selectedTab == category.key
PrimaryTab(
key = category.key,
selected = selected,
onSelected = { selectedTab = category.key },
modifier = Modifier.weight(1f),
icon = { Icon(category.icon, contentDescription = null) },
title = { Text(category.key) }
)
}
}
}
}
Tab Bar
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.foundation.layout.size
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.alpha
import androidx.compose.ui.graphics.vector.ImageVector
import androidx.compose.ui.unit.dp
import com.composables.icons.lucide.House
import com.composables.icons.lucide.Lucide
import com.composables.icons.lucide.PersonStanding
import com.composables.icons.lucide.Search
import com.composables.uikit.components.Icon
import com.composables.uikit.components.SecondaryTab
import com.composables.uikit.components.TabBar
import com.composables.uikit.components.TabGroup
import com.composables.uikit.components.TabPanel
import com.composables.uikit.components.Text
import com.composables.uikit.styling.textStyles
import com.composables.uikit.styling.title
import com.composeunstyled.theme.Theme
@Composable
fun TabBarExample() {
class Category(val key: String, val icon: ImageVector)
val Home = Category("Home", Lucide.House)
val Search = Category("Search", Lucide.Search)
val Profile = Category("Profile", Lucide.PersonStanding)
var selectedTab by remember { mutableStateOf(Home.key) }
val categories = listOf(Home, Search, Profile)
TabGroup(selectedTab = selectedTab, tabs = categories.map { it.key }, modifier = Modifier.fillMaxSize()) {
TabBar {
categories.forEach { category ->
SecondaryTab(
key = category.key,
selected = selectedTab == category.key,
onSelected = { selectedTab = category.key },
title = { Text(category.key) },
icon = { Icon(category.icon, contentDescription = null, modifier = Modifier.size(16.dp)) },
)
}
}
categories.forEach { category ->
TabPanel(category.key, modifier = Modifier.weight(1f).fillMaxWidth(), contentAlignment = Alignment.Center) {
Column(horizontalAlignment = Alignment.CenterHorizontally) {
Icon(category.icon, contentDescription = null, modifier = Modifier.size(96.dp).alpha(0.4f))
Spacer(Modifier.height(8.dp))
Text(category.key, style = Theme[textStyles][title])
}
}
}
}
}