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.
140 lines
4.9 KiB
140 lines
4.9 KiB
3 years ago
|
import 'package:flutter/material.dart';
|
||
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
||
|
import 'package:huixiang/utils/font_weight.dart';
|
||
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
||
|
import 'package:huixiang/view_widget/round_button.dart';
|
||
|
|
||
|
class PeopleNumView extends StatefulWidget {
|
||
|
final String tableName;
|
||
|
|
||
|
// final Function(int peopleNum) callback;
|
||
|
|
||
|
PeopleNumView(this.tableName);
|
||
|
|
||
|
@override
|
||
|
State<StatefulWidget> createState() {
|
||
|
return _PeopleNumView();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
class _PeopleNumView extends State<PeopleNumView> {
|
||
|
int peopleNum = 1;
|
||
|
|
||
|
@override
|
||
|
Widget build(BuildContext context) {
|
||
|
return SimpleDialog(
|
||
|
titlePadding: EdgeInsets.all(10),
|
||
|
backgroundColor: Colors.transparent,
|
||
|
elevation: 0,
|
||
|
shape: RoundedRectangleBorder(
|
||
|
borderRadius: BorderRadius.circular(6),
|
||
|
),
|
||
|
children: [
|
||
|
Stack(
|
||
|
alignment: Alignment.bottomCenter,
|
||
|
children: [
|
||
|
Container(
|
||
|
width: 295,
|
||
|
height: 247,
|
||
|
decoration: BoxDecoration(
|
||
|
color: Colors.white,
|
||
|
borderRadius: BorderRadius.circular(8),
|
||
|
),
|
||
|
padding: EdgeInsets.symmetric(vertical: 20, horizontal: 20),
|
||
|
child: Column(
|
||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||
|
crossAxisAlignment: CrossAxisAlignment.center,
|
||
|
children: [
|
||
|
Text(
|
||
|
"桌位:${widget.tableName}",
|
||
|
style: TextStyle(
|
||
|
fontSize: 16.sp,
|
||
|
fontWeight: MyFontWeight.regular,
|
||
|
color: Color(0xFF171717),
|
||
|
),
|
||
|
),
|
||
|
Text(
|
||
|
"请选择用餐人数:$peopleNum人",
|
||
|
style: TextStyle(
|
||
|
fontSize: 16.sp,
|
||
|
fontWeight: MyFontWeight.regular,
|
||
|
color: Color(0xFF171717),
|
||
|
),
|
||
|
),
|
||
|
SizedBox(
|
||
|
height: 10,
|
||
|
),
|
||
|
Container(
|
||
|
child: GridView.builder(
|
||
|
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
|
||
|
crossAxisCount: 5,
|
||
|
crossAxisSpacing: 24,
|
||
|
mainAxisSpacing: 18,
|
||
|
childAspectRatio: 1,
|
||
|
),
|
||
|
shrinkWrap: true,
|
||
|
itemCount: 10,
|
||
|
padding: EdgeInsets.zero,
|
||
|
physics: NeverScrollableScrollPhysics(),
|
||
|
itemBuilder: (context, position) {
|
||
|
return InkWell(
|
||
|
onTap: () {
|
||
|
setState(() {
|
||
|
peopleNum = position + 1;
|
||
|
});
|
||
|
},
|
||
|
child: Container(
|
||
|
decoration: BoxDecoration(
|
||
|
color: peopleNum == (position + 1)
|
||
|
? Color(0xFF32A060)
|
||
|
: Colors.transparent,
|
||
|
border: Border.all(
|
||
|
color: Color(0xFF32A060),
|
||
|
width: 1,
|
||
|
),
|
||
|
borderRadius: BorderRadius.circular(3),
|
||
|
),
|
||
|
alignment: Alignment.center,
|
||
|
child: Text(
|
||
|
"${position + 1}",
|
||
|
style: TextStyle(
|
||
|
color: peopleNum == (position + 1)
|
||
|
? Colors.white
|
||
|
: Color(0xFF32A060),
|
||
|
fontWeight: MyFontWeight.regular,
|
||
|
fontSize: 16.sp,
|
||
|
),
|
||
|
),
|
||
|
),
|
||
|
);
|
||
|
},
|
||
|
),
|
||
|
),
|
||
|
SizedBox(
|
||
|
height: 10,
|
||
|
),
|
||
|
RoundButton(
|
||
|
text: "确定",
|
||
|
width: 130.w,
|
||
|
height: 34.h,
|
||
|
textColor: Colors.white,
|
||
|
fontSize: 16.sp,
|
||
|
fontWeight: MyFontWeight.semi_bold,
|
||
|
backgroup: Color(0xFF32A060),
|
||
|
radius: 4.w,
|
||
|
callback: () {
|
||
|
// widget.callback(peopleNum);
|
||
|
// SmartDialog.dismiss();
|
||
|
Navigator.of(context).pop(peopleNum);
|
||
|
},
|
||
|
),
|
||
|
],
|
||
|
),
|
||
|
),
|
||
|
],
|
||
|
),
|
||
|
],
|
||
|
);
|
||
|
}
|
||
|
}
|