- Welcome
- Getting started
- Latest updates
- Foundations
-
Components
- Accordion
- Alert
- Alignment
- App Search Modal
- 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
- Image Gallery
- Infinite scroll
- Info Banner
- Inset Banner
- Link
- List
- Map
- Mobile scroll container
- Modal
- Navigation bar
- Navigation Tab Group
- Nudger
- Overlay
- Page indicator
- Pagination
- Panel
- Phone input
- Picker
- Popover
- Price
- Progress bar
- Radio button
- Rating
- Rating Bar
- Scrollable calendar
- Search Modal
- Section header
- Section list
- Select
- Skeleton
- Skip link
- Slider
- Snackbar
- Snippet
- Spinner
- Split input
- Star rating
- Swap Button
- Switch
- Table
- Text
- Text input
- Theming
- Ticket
- Toast
- Tooltip
- Touchable native feedback
- Touchable overlay
- Search Input Summary
- Content
- Accessibility
- Contributing
- Localisation
Card
Cards are used to group related items. They allow complex datasets to be broken down into individual, distinct areas for easy consumption.
Card
Default
Day | Night |
---|---|
Divided Card
Day | Night |
---|---|
Card Wrapper
Day | Night |
---|---|
Installation
Backpack Compose is available through Maven Central. Check the main Readme for a complete installation guide.
Usage
Example of a Card with default (small) corner:
import net.skyscanner.backpack.compose.card.BpkCard
BpkCard {
// content
}
Example of a Card with large corner:
import net.skyscanner.backpack.compose.card.BpkCard
import net.skyscanner.backpack.compose.card.BpkCardCorner
BpkCard(corner = BpkCardCorner.Large) {
// content
}
Example of a Card with no padding:
import net.skyscanner.backpack.compose.card.BpkCard
import net.skyscanner.backpack.compose.card.BpkCardPadding
BpkCard(padding = BpkCardPadding.None) {
// content
}
Example of a clickable Card:
import net.skyscanner.backpack.compose.card.BpkCard
BpkCard(
onClick = {},
onClickLabel = "Semantic and accessibility label",
) {
// content
}
Example of a focused Card:
import net.skyscanner.backpack.compose.card.BpkCard
import net.skyscanner.backpack.compose.card.BpkCardElevation
BpkCard(elevation = BpkCardElevation.Focus) {
// content
}
Example of a Divided Card:
import net.skyscanner.backpack.compose.dividedcard.BpkDividedCard
import net.skyscanner.backpack.compose.dividedcard.dividedCardWidth
BpkDividedCard(
modifier = Modifier.fillMaxWidth(),
primaryContent = {
Image(
modifier = Modifier
.height(BpkSpacing.Xxl * 2)
.dividedCardWidth(BpkSpacing.Xxl),
painter = painterResource(id = R.drawable.image),
contentDescription = "content description",
contentScale = ContentScale.Crop
)
},
secondaryContent = {
BpkText(
modifier = Modifier.fillMaxWidth(),
text = stringResource("BpkDividedCard sample"),
)
},
onClick = {}
)
Example of a Card Wrapper:
import net.skyscanner.backpack.compose.cardwrapper.BpkCardWrapper
import net.skyscanner.backpack.compose.card.BpkCardElevation
import net.skyscanner.backpack.compose.card.BpkCardPadding
import net.skyscanner.backpack.compose.card.BpkCardCorner
BpkCardWrapper(
modifier = Modifier.fillMaxWidth(),
backgroundColor = BpkTheme.colors.coreEco,
cardPadding = BpkCardPadding.None,
corner = BpkCardCorner.Large,
elevation = BpkCardElevation.Focus,
headerContent = {
// header content
},
cardContent = {
// card content
},
onClick = {}
)
Made with ❤️ by Skyscanner © 2024
© 2024 Skyscanner Backpack. Page last updated on Feb 22, 2023, 11:12