- 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
Dialog
Dialogs inform users about a specific task and may contain critical information, or require decisions or acknowledgement.
Dialog
Success
Day | Night |
---|---|
Warning
Day | Night |
---|---|
Destructive
Day | Night |
---|---|
Flare
Day | Night |
---|---|
Image
Day | Night |
---|---|
Installation
Backpack Compose is available through Maven Central. Check the main Readme for a complete installation guide.
Usage
Example of a success dialog with three buttons
import net.skyscanner.backpack.compose.dialog.BpkSuccessDialog
import net.skyscanner.backpack.compose.icons.BpkIcons
BpkSuccessDialog(
icon = BpkIcons.Lg.Tick,
title = stringResource(id = R.string.dialog_title),
text = stringResource(id = R.string.dialog_text),
confirmButton = DialogButton(stringResource(id = R.string.dialog_confirmation)) { /** onClick **/ },
secondaryButton = DialogButton(stringResource(id = R.string.dialog_skip)) { /** onClick **/ },
linkButton = DialogButton(stringResource(id = R.string.dialog_link_optional)) { /** onClick **/ },
) {
// onDismiss
}
Example of a warning dialog with two buttons
import net.skyscanner.backpack.compose.dialog.BpkWarningDialog
import net.skyscanner.backpack.compose.icons.BpkIcons
BpkWarningDialog(
icon = BpkIcons.Lg.AlertAdd,
title = stringResource(id = R.string.dialog_title),
text = stringResource(id = R.string.dialog_text),
confirmButton = DialogButton(stringResource(id = R.string.dialog_confirmation)) { /** onClick **/ },
secondaryButton = DialogButton(stringResource(id = R.string.dialog_skip)) { /** onClick **/ },
) {
// onDismiss
}
Example of a destructive dialog with two buttons
import net.skyscanner.backpack.compose.dialog.BpkDestructiveDialog
import net.skyscanner.backpack.compose.icons.BpkIcons
BpkDestructiveDialog(
icon = BpkIcons.Lg.Trash,
title = stringResource(id = R.string.dialog_title),
text = stringResource(id = R.string.dialog_text),
confirmButton = DialogButton(stringResource(id = R.string.dialog_delete)) { /** onClick **/ },
linkButton = DialogButton(stringResource(id = R.string.dialog_cancel)) { /** onClick **/ },
onDismissRequest = onDismiss,
) {
// onDismiss
}
Example of a flare dialog
import androidx.compose.foundation.Image
import net.skyscanner.backpack.compose.dialog.BpkFlareDialog
import net.skyscanner.backpack.compose.icons.BpkIcons
BpkFlareDialog(
title = stringResource(id = R.string.dialog_title),
text = stringResource(id = R.string.dialog_text),
confirmButton = DialogButton(stringResource(id = R.string.dialog_confirmation)) { /** onClick **/ },
secondaryButton = DialogButton(stringResource(id = R.string.dialog_skip)) { /** onClick **/ },
onDismissRequest = { /** onDismiss **/ },
) {
Image(
painter = painterResource(R.drawable.flare_image),
contentDescription = stringResource(R.string.flare_image_content_description),
contentScale = ContentScale.Crop,
)
}
Example of an image dialog
import androidx.compose.foundation.Image
import net.skyscanner.backpack.compose.dialog.BpkImageDialog
import net.skyscanner.backpack.compose.icons.BpkIcons
import androidx.compose.ui.text.style.TextAlign
BpkImageDialog(
title = stringResource(id = R.string.dialog_title),
text = stringResource(id = R.string.dialog_text),
confirmButton = DialogButton(stringResource(id = R.string.dialog_confirmation), onDismiss),
secondaryButton = DialogButton(stringResource(id = R.string.dialog_skip), onDismiss),
onDismissRequest = onDismiss,
textAlign = TextAlign.Start
) {
Image(
painter = painterResource(R.drawable.canadian_rockies_canada),
contentDescription = stringResource(R.string.image_rockies_content_description),
contentScale = ContentScale.Crop,
)
}
Made with ❤️ by Skyscanner © 2024
© 2024 Skyscanner Backpack. Page last updated on Oct 31, 2022, 13:16