BREAKING CHANGE IN 1.0.0
In the builder param remove scrollController and use ModalScrollController.of(context) instead to access the modal's scrollController. Check the CHANGELOG for more information
Create awesome and powerful modal bottom sheets.
| Cupertino Modal | Multiple Modals | Material Modal | Bar Modal | Create your own | 
|---|---|---|---|---|
|  |  |  |  |  | 
Explore the Web Demo or clone the repository.
Why not showModalBottomSheet?
Inspired by showModalBottomSheet, it completes with some must-need features:
- Support for inside scrollview + dragging down to close (showModalBottomSheetwon't work correctly with scrollviews.
- Support for WillPopScopeto prevent closing the dialog.
- Support for scroll to top when tapping status bar (iOS only)
- Cupertino modal bottom sheet
- Create custom modal bottom sheet
How to install it? Follow Instructions
showMaterialModalBottomSheet(
  context: context,
  builder: (context) => Container(),
)| Param | Description | 
|---|---|
| bool expand = false | The expandparameter specifies id the modal bottom sheet will be full screen size or will fit the content child | 
| bool useRootNavigator = false | The useRootNavigatorparameter ensures that the root navigator is used to display the bottom sheet when set totrue. This is useful in the case that a modal bottom sheet needs to be displayed above all other content but the caller is inside anotherNavigator. | 
| bool isDismissible = true | The isDismissibleparameter specifies whether the bottom sheet will be dismissed when user taps on the scrim. | 
| Color barrierColor | The barrierColorparameter controls the color of the scrim for this route | 
| bool enableDrag = true | The enableDragparameter specifies whether the bottom sheet can be dragged up and down and dismissed by swiping downwards. | 
| AnimationController secondAnimation | The secondAnimationparameter allows you to provide an animation controller that will be used to animate  push/pop of the modal route. Using this param is advised against and will be probably removed in future versions | 
| bool bounce = false | The bounceparameter specifies if the bottom sheet can go beyond the top boundary while dragging | 
| Duration duration = const Duration(milliseconds: 400) | The durationof modal opening | 
| double closeProgressThreshold = 0.6 | The closeProgressThresholdspecifies when the bottom sheet will be dismissed when user drags it. | 
The optional backgroundColor, elevation, shape, and clipBehavior parameters can be passed in to customize the appearance and behavior of material bottom sheets.
Assign the ModalScrollController.of(context) to your primary modal to sync the scroll with the modal's drag
showMaterialModalBottomSheet(
  context: context,
  builder: (context) => SingleChildScrollView(
    controller: ModalScrollController.of(context),
    child: Container(),
  ),
);iOS 13 came with an amazing new modal navigation and now it is available to use with Flutter.
showCupertinoModalBottomSheet(
  context: context,
  builder: (context) => Container(),
)See generic paramameter in the Material section above
The optional backgroundColor parameters can be passed in to customize the backgroundColor cupertino bottom sheets.
Useful if you want a blurred transparent background as the example Cupertino Photo Share
Why?
MaterialPageRouteandCupertinoPageRoutedo not allow animated translation to/from routes that are not the same type.
Replace your current route class with MaterialWithModalsPageRoute.
Notice this route type behaves the same as MaterialPageRoute and supports custom PageTransitionsBuilder and PageTransitionsTheme.
How can I replace my current route?
 1. 
Using Navigator.of(context).push
 
Navigator.of(context).pushNavigator.of(context).push(MaterialPageRoute(builder: (context) => Container()));`Replace it with
Navigator.of(context).push(MaterialWithModalsPageRoute(builder: (context) => Container()));2.
Using onGenerateRoute parameter of MaterialApp, CupertinoApp or Navigator
 
onGenerateRoute parameter of MaterialApp, CupertinoApp or NavigatoronGenerateRoute: (settings) {
   ...
    return MaterialPageRoute(settings: settings, builder: (context) => Container());
},Replace it to
onGenerateRoute: (settings) {
  ...
   return MaterialWithModalsPageRoute(settings: settings, builder: (context) => Container());
},  3. 
Using pageRouteBuilder parameter of WidgetApp
 
pageRouteBuilder parameter of WidgetApppageRouteBuilder: <T>(RouteSettings settings, WidgetBuilder builder) => MaterialWithModalsPageRoute<T>(settings: settings, builder: builder)4.
Using routes parameter from MaterialApp or CupertinoApp
 
routes parameter from MaterialApp or CupertinoAppUnfortunately this parameter uses MaterialPageRoute and CupertinoPageRoute respectively and cannot be changed.
You can modify the way you call the previous route with one of the previous methods or try option 2
Is there an alternative in case I can't change my current route? Yes!
Learn how to animate previous route with CupertinoScaffold:
- Wrap previous route inside a CupertinoScaffold. Example withroutesparameter fromMaterialApporCupertinoApp
  routes: <String, WidgetBuilder>{
    '/previous_route_where_you_push_modal': (BuildContext context) => CupertinoScaffold(body: Container()),
   },- Push modal with this method
CupertinoScaffold.showCupertinoModalBottomSheet(context:context, builder: (context) => Container())Don't use this solution at the same time as MaterialWithModalsPageRoute
It supports native features as bouncing, blurred background, dark mode, stacking modals and inside navigation.
a. If you want to push a new modal bottom sheet just call showCupertinoModalBottomSheet again (works with both options)
b. For inside navigaton add a new Navigator or CupertinoTabScaffold inside
c. Also it supports flutter features as WillPopScope to prevent the modal bottom to be closed.
Try showBarModalBottomSheet for a bottomSheet with the appearance used by Facebook or Slack
Check in the example project showAvatarModalBottomSheet for how to create your own ModalBottomSheet
Ask a question and ping me @jamesblasco
- 
Support closing by dragging fast on a modal with a scroll view. 
- 
Improve animation curves when user is not dragging. 
- 
Allow to set the initial size of the bottom sheet 
- 
Support hero animations Pull Request #2 

