- Welcome
- Getting started
- Latest updates
- Foundations
-
Components
- Accordion
- Alert
- Alignment
- Aria live
- Autosuggest
- Badge
- Banner alert
- Bar chart
- Blockquote
- Bottom navigation
- Bottom sheet
- Breadcrumb
- Breakpoint
- Button
- Calendar
- Card
- Card List
- Card button
- Carousel
- Checkbox
- Chip
- Chip group
- Code
- Content cards
- Data Table
- Datepicker
- Description list
- Dialog
- Divider
- Drawer
- Field Set
- Flare
- Flat list
- Flight leg
- Floating action button
- Floating notification
- Form label
- Form validation
- Graphic promotion
- Horizontal navigation
- Icon
- Image
- Infinite scroll
- Link
- List
- Map
- Mobile scroll container
- Modal
- Navigation bar
- Nudger
- Overlay
- Page indicator
- Pagination
- Panel
- Phone input
- Picker
- Popover
- Price
- Progress bar
- Radio button
- Rating
- Scrollable calendar
- Section header
- Section list
- Select
- Skeleton
- Skip link
- Slider
- Snackbar
- Snippet
- Spinner
- Split input
- Star rating
- Switch
- Table
- Text
- Text input
- Theming
- Ticket
- Toast
- Tooltip
- Touchable native feedback
- Touchable overlay
- Content
- Accessibility
Chip group
A row of chip components to allow travellers to filter options
ChipGroup
Single Select Rail
Day | Night |
---|---|
![]() |
![]() |
Single Select Wrap
Day | Night |
---|---|
![]() |
![]() |
Multi Select Rail
Day | Night |
---|---|
![]() |
![]() |
Multi Select Rail Without Sticky Chip
Day | Night |
---|---|
![]() |
![]() |
Multi Select Wrap
Day | Night |
---|---|
![]() |
![]() |
Installation
Backpack Compose is available through Maven Central. Check the main Readme for a complete installation guide.
Usage
Example of a Rail SingleSelectChipGroup:
import net.skyscanner.backpack.compose.chipgroup.single.BpkSingleSelectChipGroup
import net.skyscanner.backpack.compose.chipgroup.single.BpkSingleChipGroupType
import net.skyscanner.backpack.compose.chipgroup.single.BpkSingleChipItem
var selectedIndex by remember { mutableStateOf(0) }
BpkSingleSelectChipGroup(
chips = listOf(BpkSingleChipItem("City", BpkIcon.Deals)),
selectedIndex = selectedIndex,
onItemClicked = {/*on click */},
type = BpkSingleChipGroupType.Rail,
)
Example of a Wrap SingleSelectChipGroup:
import net.skyscanner.backpack.compose.chipgroup.single.BpkSingleSelectChipGroup
import net.skyscanner.backpack.compose.chipgroup.single.BpkSingleChipGroupType
import net.skyscanner.backpack.compose.chipgroup.single.BpkSingleChipItem
var selectedIndex by remember { mutableStateOf(0) }
BpkSingleSelectChipGroup(
chips = listOf(BpkSingleChipItem("City", BpkIcon.Deals)),
selectedIndex = selectedIndex,
onItemClicked = {/*on click */},
type = BpkSingleChipGroupType.Wrap,
)
Example of a Rail MultiSelectChipGroup Without Sticky Chip:
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiChipGroupType
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiChipItem
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiSelectChipGroup
// This is just for demonstration purposes, You should get this list from ViewModel
val chips = listOf(
BpkMultiChipItem(
text = "City1",
type = BpkChipType.Selectable
) { /* handle click*/ },
BpkMultiChipItem(
text = "City2",
type = BpkChipType.Selectable,
selected = true,
icon = BpkIcon.Heart
) { /* handle click*/ }
)
BpkMultiSelectChipGroup(
chips = chips,
type = BpkMultiChipGroupType.Rail(),
)
Example of a Rail MultiSelectChipGroup With Sticky Chip:
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiChipGroupType
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiChipItem
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkStickyChipItem
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiSelectChipGroup
import net.skyscanner.backpack.compose.chip.BpkChipType
// This is just for demonstration purposes, You should get this list from ViewModel
val chips = listOf(
BpkMultiChipItem(
text = "City1",
type = BpkChipType.Selectable
) { /* handle click*/ },
BpkMultiChipItem(
text = "City2",
type = BpkChipType.Selectable,
selected = true,
icon = BpkIcon.Heart
) { /* handle click*/ }
)
BpkMultiSelectChipGroup(
chips = chips,
type = BpkMultiChipGroupType.Rail(
BpkStickyChipItem(
text = stringResource(R.string.sticky_chip),
icon = BpkIcon.Filter,
) {
/*on click */
},
),
)
Example of a Wrap MultiSelectChipGroup:
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiChipGroupType
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiChipItem
import net.skyscanner.backpack.compose.chipgroup.multiple.BpkMultiSelectChipGroup
import androidx.lifecycle.compose.collectAsStateWithLifecycle
// This is just for demonstration purposes, You should get this list from ViewModel
val chips = listOf(
BpkMultiChipItem(
text = "City1",
type = BpkChipType.Selectable
) { /* handle click*/ },
BpkMultiChipItem(
text = "City2",
type = BpkChipType.Selectable,
selected = true,
icon = BpkIcon.Heart
) { /* handle click*/ }
)
BpkMultiSelectChipGroup(
chips = chips,
type = BpkMultiChipGroupType.Wrap,
)
Made with ❤️ by Skyscanner © 2023
© 2023 Skyscanner Backpack. Page last updated on Jun 30, 2023, 13:17