Состояние Flutter ModalBottomSheet (радиокнопки)
Я не могу обновить свое состояние внутри modalBottomSheet, когда использую переключатели. Когда я меняю переключатели, я получаю данные с сервера и хочу обновить состояние.
вот мой код
Здесь я вызываю modalBottomSheet:
GestureDetector(
onTap: () {
showModalBottomSheet(
context: context,
builder:
buildBottomSheet);
},
child: ListTile(
leading: Icon(
Icons.shopping_basket),
title:
Text("choose bag type "),
),
),
А вот мой modalbottomSheet с контейнером, который содержит переключатели.
Widget buildBottomSheet(BuildContext context) {
return StatefulBuilder(builder: (BuildContext context, StateSetter state) {
return Container(
color: Color(0xff757575),
child: Container(
height: MediaQuery.of(context).size.height / 4,
decoration: BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.only(
topLeft: Radius.circular(25), topRight: Radius.circular(25))),
child: Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: <Widget>[
SizedBox(height: 25),
RadioListTile(
groupValue: _con.cart.bagType,
title: Row(
children: <Widget>[
Expanded(
flex: 3,
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Text(
S.of(context).plastic_bag +
" (" +
_con.cart.plasticBagCount.toString() +
" X " +
_con.cart.plasticBagUnitPrice.toString() +
")",
style: Theme.of(context).textTheme.body1,
overflow: TextOverflow.ellipsis,
maxLines: 1,
),
],
),
),
Expanded(
flex: 1,
child: Image.asset("assets/img/business.png",
height: 25, color: Colors.grey),
)
],
),
value: 1,
onChanged: (val) {
state(() {
selectedBagType = val;
});
_con.cart.bagType = val;
print("BBBBBBBBBBBBBBBBBBBBBBBBBB" + val.toString());
_con.listenForBagTypeChange();
},
),
RadioListTile(
groupValue: _con.cart.bagType,
title: Row(
children: <Widget>[
Expanded(
flex: 3,
child: Text(
S.of(context).reusable_bag +
" (" +
_con.cart.reusableBagCount.toString() +
" X " +
_con.cart.reusableBagUnitPrice.toString() +
")",
style: Theme.of(context).textTheme.body1,
overflow: TextOverflow.ellipsis,
maxLines: 1,
),
),
Expanded(
flex: 1,
child: InkWell(
child: Icon(
Icons.shopping_basket,
color: Colors.grey,
size: 30.0,
),
),
)
],
),
value: 2,
onChanged: (val) {
state(() {
selectedBagType = val;
});
_con.cart.bagType = val;
print("AAAAAAAAAAAAAAAAAAAA" + val.toString());
_con.listenForBagTypeChange();
},
),
],
),
),
);
});
}
пожалуйста, кто-нибудь может помочь?