You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ansu_ui/lib/scaffold/as_scaffold.dart

94 lines
2.4 KiB

part of ansu_ui;
///ASScaffold
///
///made with Scaffold from `Material`
///
///
4 years ago
///
///`title`,`body`,`leading`,`bottomNavigationBar`,`appBarBottom`,`appBar`
///
///title , AppBar 和 AppBarBottom 均为 `null`时不显示scaffold的AppBar
///
///只有AppBarBottom时只显示AppBarBottom中的内容
class ASScaffold extends StatefulWidget {
///标题,可为`String`或`Text`
final dynamic title;
/// `Scaffold` body
final Widget body;
/// `Scaffold` leading
final Widget leading;
4 years ago
/// `Scaffold` bottomNavigationBar
final Widget bottomNavigationBar;
/// `AppBar` appBarBottom
final PreferredSizeWidget appBarBottom;
4 years ago
/// `EndDrawer` endDrawer
4 years ago
///
4 years ago
/// 右方向的抽屉
final Widget endDrawer;
/// `AppBar` appBar
final Widget appBar;
///背景色
final Color backgroundColor;
ASScaffold({
Key key,
this.title,
this.leading,
this.body,
4 years ago
this.bottomNavigationBar,
this.appBarBottom,
4 years ago
this.endDrawer,
this.appBar,
this.backgroundColor = kBackgroundColor,
}) : super(key: key);
@override
_ASScaffoldState createState() => _ASScaffoldState();
}
class _ASScaffoldState extends State<ASScaffold> {
@override
Widget build(BuildContext context) {
return Scaffold(
4 years ago
endDrawer: widget.endDrawer,
backgroundColor: widget.backgroundColor,
4 years ago
bottomNavigationBar: widget.bottomNavigationBar,
appBar: widget.title == null &&
widget.appBar == null &&
widget.appBarBottom == null
4 years ago
? null
: widget.appBar ??
AppBar(
brightness: Brightness.light,
backgroundColor: kForegroundColor,
elevation: 0,
leading: widget.leading ?? ASBackButton(),
centerTitle: true,
title: DefaultTextStyle(
style: TextStyle(
color: kTextColor,
fontSize: 18.sp,
fontWeight: FontWeight.bold,
),
child: widget.title is String
? Text(widget.title)
: widget.title ?? SizedBox(),
),
bottom: widget.appBarBottom ??
PreferredSize(
child: SizedBox(),
preferredSize: Size.fromHeight(0),
),
),
body: widget.body,
);
}
}