drawer_swipe 0.0.3 drawer_swipe: ^0.0.3 copied to clipboard
Drawer swipe Package for displaying multi layer drawer
import 'package:drawer_swipe/drawer_swipe.dart';
import 'package:flutter/material.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
debugShowCheckedModeBanner: false,
home: MyHomePage(),
);
}
}
class MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
var drawerKey = GlobalKey<SwipeDrawerState>();
@override
Widget build(BuildContext context) {
return Scaffold(
// add this line so you can add your appBar in Body
extendBodyBehindAppBar: true,
body: SwipeDrawer(
radius: 20,
key: drawerKey,
bodyBackgroundPeekSize: 30,
backgroundColor: Colors.red,
// pass drawer widget
drawer: buildDrawer(),
// pass body widget
child: buildBody(),
),
);
}
Widget buildDrawer() {
return Container(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
ListTile(
title: Text('Title'),
),
ListTile(
title: Text('Title'),
),
ListTile(
title: Text('Title'),
),
],
),
);
}
Widget buildBody() {
return Column(
children: [
// build your appBar
AppBar(
title: Text('AppBar title'),
leading: InkWell(
onTap: () {
if (drawerKey.currentState.isOpened()) {
drawerKey.currentState.closeDrawer();
} else {
drawerKey.currentState.openDrawer();
}
},
child: Icon(Icons.menu)),
),
// build your screen body
Expanded(
child: Container(
color: Colors.white,
child: Center(
child: Text('Home Screen'),
),
),
),
],
);
}
}