|
|
@ -84,21 +84,22 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
|
|
|
|
|
|
|
|
///添加购物车 |
|
|
|
///添加购物车 |
|
|
|
addShopCar() async { |
|
|
|
addShopCar() async { |
|
|
|
|
|
|
|
|
|
|
|
List<dynamic> setMealDataList = []; |
|
|
|
List<dynamic> setMealDataList = []; |
|
|
|
productSetMeals.forEach((element) { |
|
|
|
productSetMeals.forEach((element) { |
|
|
|
List<dynamic> productInfoListBean = []; |
|
|
|
List<dynamic> productInfoListBean = []; |
|
|
|
element.productInfoList.forEach((ele) { |
|
|
|
element.productInfoList.forEach((ele) { |
|
|
|
if(ele.count > 0) |
|
|
|
if (ele.count > 0) { |
|
|
|
productInfoListBean.add({ |
|
|
|
productInfoListBean.add({ |
|
|
|
"productId":ele.productId, |
|
|
|
"productId": ele.productId, |
|
|
|
"skuId":(ele.productAttrInfoList[0].attrName == "") ? (ele.skuInfoList[0].productSkuAttrList[0].skuId): |
|
|
|
"skuId": ele.skuInfoList.length == 1 |
|
|
|
(ele.skuInfoList.firstWhere((e1) => e1.skuName == ele.productAttrInfoList[0].selectSku).id) |
|
|
|
? ele.skuInfoList.first.id |
|
|
|
}); |
|
|
|
: ele.skuInfoList.firstWhere((e2) => e2.isSelected).id |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
} |
|
|
|
}); |
|
|
|
}); |
|
|
|
setMealDataList.add({ |
|
|
|
setMealDataList.add({ |
|
|
|
"groupName":element.groupName, |
|
|
|
"groupName": element.groupName, |
|
|
|
"productInfoList":productInfoListBean |
|
|
|
"productInfoList": productInfoListBean |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
@ -114,17 +115,18 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
"skuPrice": miNiDetail.productSkuVOList[0].skuPrice, |
|
|
|
"skuPrice": miNiDetail.productSkuVOList[0].skuPrice, |
|
|
|
"skuStock": miNiDetail.productSkuVOList[0].skuStock, |
|
|
|
"skuStock": miNiDetail.productSkuVOList[0].skuStock, |
|
|
|
"skuImg": miNiDetail.productSkuVOList[0].skuImg, |
|
|
|
"skuImg": miNiDetail.productSkuVOList[0].skuImg, |
|
|
|
"setMealDataList":setMealDataList |
|
|
|
"setMealDataList": setMealDataList |
|
|
|
}, |
|
|
|
}, |
|
|
|
], |
|
|
|
], |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
BaseData<List<ShoppingCart>> baseDate = await minService.addShoppingCart(requestData); |
|
|
|
BaseData<List<ShoppingCart>> baseDate = |
|
|
|
EasyLoading.dismiss(); |
|
|
|
await minService.addShoppingCart(requestData); |
|
|
|
if (baseDate != null && baseDate.isSuccess) { |
|
|
|
EasyLoading.dismiss(); |
|
|
|
Navigator.of(context).pop(); |
|
|
|
if (baseDate != null && baseDate.isSuccess) { |
|
|
|
} else { |
|
|
|
Navigator.of(context).pop(); |
|
|
|
SmartDialog.showToast(baseDate?.msg, alignment: Alignment.center); |
|
|
|
} else { |
|
|
|
|
|
|
|
SmartDialog.showToast(baseDate?.msg, alignment: Alignment.center); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -210,8 +212,7 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
shrinkWrap: true, |
|
|
|
shrinkWrap: true, |
|
|
|
padding: EdgeInsets.zero, |
|
|
|
padding: EdgeInsets.zero, |
|
|
|
itemBuilder: (context, position) { |
|
|
|
itemBuilder: (context, position) { |
|
|
|
return productMealsList( |
|
|
|
return productMealsList(position); |
|
|
|
position); |
|
|
|
|
|
|
|
}, |
|
|
|
}, |
|
|
|
), |
|
|
|
), |
|
|
|
], |
|
|
|
], |
|
|
@ -304,14 +305,14 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
shrinkWrap: true, |
|
|
|
shrinkWrap: true, |
|
|
|
padding: EdgeInsets.zero, |
|
|
|
padding: EdgeInsets.zero, |
|
|
|
itemBuilder: (context, index) { |
|
|
|
itemBuilder: (context, index) { |
|
|
|
return productMealsItem(position,index); |
|
|
|
return productMealsItem(position, index); |
|
|
|
}, |
|
|
|
}, |
|
|
|
), |
|
|
|
), |
|
|
|
], |
|
|
|
], |
|
|
|
)); |
|
|
|
)); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Widget productMealsItem(int position,int index) { |
|
|
|
Widget productMealsItem(int position, int index) { |
|
|
|
return Container( |
|
|
|
return Container( |
|
|
|
margin: EdgeInsets.symmetric(vertical: 16.h), |
|
|
|
margin: EdgeInsets.symmetric(vertical: 16.h), |
|
|
|
child: Row( |
|
|
|
child: Row( |
|
|
@ -335,7 +336,10 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
Expanded( |
|
|
|
Expanded( |
|
|
|
child: Text( |
|
|
|
child: Text( |
|
|
|
productSetMeals[position].productInfoList[index].productName ?? "", |
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productName ?? |
|
|
|
|
|
|
|
"", |
|
|
|
overflow: TextOverflow.ellipsis, |
|
|
|
overflow: TextOverflow.ellipsis, |
|
|
|
maxLines: 1, |
|
|
|
maxLines: 1, |
|
|
|
style: TextStyle( |
|
|
|
style: TextStyle( |
|
|
@ -345,7 +349,11 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
if (productSetMeals[position].productInfoList[index].productAttrInfoList[0].attrName != "") |
|
|
|
if (productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[0] |
|
|
|
|
|
|
|
.attrName != |
|
|
|
|
|
|
|
"") |
|
|
|
GestureDetector( |
|
|
|
GestureDetector( |
|
|
|
child: Text( |
|
|
|
child: Text( |
|
|
|
"选规格", |
|
|
|
"选规格", |
|
|
@ -356,29 +364,43 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
onTap: () { |
|
|
|
onTap: () { |
|
|
|
showSkuDialog(position,index); |
|
|
|
showSkuDialog(position, index); |
|
|
|
}, |
|
|
|
}, |
|
|
|
), |
|
|
|
), |
|
|
|
if (productSetMeals[position].productInfoList[index].productAttrInfoList[0].attrName != "") |
|
|
|
if (productSetMeals[position] |
|
|
|
GestureDetector( |
|
|
|
.productInfoList[index] |
|
|
|
onTap: (){ |
|
|
|
.productAttrInfoList[0] |
|
|
|
showSkuDialog(position,index); |
|
|
|
.attrName != |
|
|
|
}, |
|
|
|
"") |
|
|
|
child: Icon( |
|
|
|
GestureDetector( |
|
|
|
Icons.chevron_right, |
|
|
|
onTap: () { |
|
|
|
color: Colors.black, |
|
|
|
showSkuDialog(position, index); |
|
|
|
size: 18, |
|
|
|
}, |
|
|
|
), |
|
|
|
child: Icon( |
|
|
|
) |
|
|
|
Icons.chevron_right, |
|
|
|
|
|
|
|
color: Colors.black, |
|
|
|
|
|
|
|
size: 18, |
|
|
|
|
|
|
|
), |
|
|
|
|
|
|
|
) |
|
|
|
], |
|
|
|
], |
|
|
|
), |
|
|
|
), |
|
|
|
SizedBox(height: 8.h), |
|
|
|
SizedBox(height: 8.h), |
|
|
|
Row( |
|
|
|
Row( |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
if (productSetMeals[position].productInfoList[index].productAttrInfoList[0].attrName != "" |
|
|
|
if (productSetMeals[position] |
|
|
|
&& productSetMeals[position].productInfoList[index].count > 0) |
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.skuInfoList |
|
|
|
|
|
|
|
.where((element) => element.isSelected) |
|
|
|
|
|
|
|
.isNotEmpty && |
|
|
|
|
|
|
|
productSetMeals[position].productInfoList[index].count > |
|
|
|
|
|
|
|
0) |
|
|
|
Text( |
|
|
|
Text( |
|
|
|
productSetMeals[position].productInfoList[index].productAttrInfoList[0].selectSku ?? "", |
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.skuInfoList |
|
|
|
|
|
|
|
.firstWhere((element) => element.isSelected) |
|
|
|
|
|
|
|
.skuName ?? |
|
|
|
|
|
|
|
"", |
|
|
|
overflow: TextOverflow.ellipsis, |
|
|
|
overflow: TextOverflow.ellipsis, |
|
|
|
maxLines: 1, |
|
|
|
maxLines: 1, |
|
|
|
style: TextStyle( |
|
|
|
style: TextStyle( |
|
|
@ -391,8 +413,13 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
InkWell( |
|
|
|
InkWell( |
|
|
|
onTap: () { |
|
|
|
onTap: () { |
|
|
|
setState(() { |
|
|
|
setState(() { |
|
|
|
if (productSetMeals[position].productInfoList[index].count >= 1) |
|
|
|
if (productSetMeals[position] |
|
|
|
productSetMeals[position].productInfoList[index].count -= 1; |
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.count >= |
|
|
|
|
|
|
|
1) |
|
|
|
|
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.count -= 1; |
|
|
|
}); |
|
|
|
}); |
|
|
|
}, |
|
|
|
}, |
|
|
|
child: Image.asset( |
|
|
|
child: Image.asset( |
|
|
@ -405,7 +432,10 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
width: 30, |
|
|
|
width: 30, |
|
|
|
alignment: Alignment.center, |
|
|
|
alignment: Alignment.center, |
|
|
|
child: Text( |
|
|
|
child: Text( |
|
|
|
productSetMeals[position].productInfoList[index].count.toString(), |
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.count |
|
|
|
|
|
|
|
.toString(), |
|
|
|
style: TextStyle( |
|
|
|
style: TextStyle( |
|
|
|
color: Colors.black, |
|
|
|
color: Colors.black, |
|
|
|
fontSize: 14.sp, |
|
|
|
fontSize: 14.sp, |
|
|
@ -416,21 +446,33 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
GestureDetector( |
|
|
|
GestureDetector( |
|
|
|
onTap: () { |
|
|
|
onTap: () { |
|
|
|
setState(() { |
|
|
|
setState(() { |
|
|
|
if(productSetMeals[position].productInfoList[index].productAttrInfoList[0].attrName != ""){ |
|
|
|
if (productSetMeals[position] |
|
|
|
showSkuDialog(position,index); |
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[0] |
|
|
|
|
|
|
|
.attrName != |
|
|
|
|
|
|
|
"") { |
|
|
|
|
|
|
|
showSkuDialog(position, index); |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
int total = 0; |
|
|
|
int total = 0; |
|
|
|
productSetMeals[position].productInfoList.forEach((element) { |
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList |
|
|
|
|
|
|
|
.forEach((element) { |
|
|
|
total += element.count; |
|
|
|
total += element.count; |
|
|
|
}); |
|
|
|
}); |
|
|
|
if (total >= productSetMeals[position].optionalNumber) { |
|
|
|
if (total >= |
|
|
|
|
|
|
|
productSetMeals[position].optionalNumber) { |
|
|
|
SmartDialog.showToast("抱歉,无法加购更多", |
|
|
|
SmartDialog.showToast("抱歉,无法加购更多", |
|
|
|
alignment: Alignment.center); |
|
|
|
alignment: Alignment.center); |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
if (productSetMeals[position].productInfoList[index].count == 0) |
|
|
|
if (productSetMeals[position] |
|
|
|
productSetMeals[position].productInfoList[index].count += 1; |
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.count == |
|
|
|
|
|
|
|
0) |
|
|
|
|
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.count += 1; |
|
|
|
}); |
|
|
|
}); |
|
|
|
}, |
|
|
|
}, |
|
|
|
child: Image.asset( |
|
|
|
child: Image.asset( |
|
|
@ -452,16 +494,28 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
); |
|
|
|
); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Widget porAttrItem(int position,int index,int pos,state) { |
|
|
|
Widget porAttrItem(int position, int index, int pos, state) { |
|
|
|
if (productSetMeals[position].productInfoList[index].productAttrInfoList[pos].attrValueList != null && |
|
|
|
if (productSetMeals[position] |
|
|
|
productSetMeals[position].productInfoList[index].productAttrInfoList[pos].attrValueList.length > 0) |
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[pos] |
|
|
|
|
|
|
|
.attrValueList != |
|
|
|
|
|
|
|
null && |
|
|
|
|
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[pos] |
|
|
|
|
|
|
|
.attrValueList |
|
|
|
|
|
|
|
.length > |
|
|
|
|
|
|
|
0) |
|
|
|
return Column( |
|
|
|
return Column( |
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
Padding( |
|
|
|
Padding( |
|
|
|
padding: EdgeInsets.only(top: 16, bottom: 16), |
|
|
|
padding: EdgeInsets.only(top: 16, bottom: 16), |
|
|
|
child: Text( |
|
|
|
child: Text( |
|
|
|
productSetMeals[position].productInfoList[index].productAttrInfoList[pos].attrName, |
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[pos] |
|
|
|
|
|
|
|
.attrName, |
|
|
|
style: TextStyle( |
|
|
|
style: TextStyle( |
|
|
|
color: Color(0xFFB3B3B3), |
|
|
|
color: Color(0xFFB3B3B3), |
|
|
|
fontSize: 14.sp, |
|
|
|
fontSize: 14.sp, |
|
|
@ -469,7 +523,7 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
sweetnessStore(position,index, pos,state), |
|
|
|
sweetnessStore(position, index, pos, state), |
|
|
|
], |
|
|
|
], |
|
|
|
); |
|
|
|
); |
|
|
|
else { |
|
|
|
else { |
|
|
@ -477,23 +531,36 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Widget sweetnessStore(int position,int index,int pos,state) { |
|
|
|
Widget sweetnessStore(int position, int index, int pos, state) { |
|
|
|
return Wrap( |
|
|
|
return Wrap( |
|
|
|
runSpacing: 10.0, |
|
|
|
runSpacing: 10.0, |
|
|
|
spacing: 10.0, |
|
|
|
spacing: 10.0, |
|
|
|
children: productSetMeals[position].productInfoList[index].productAttrInfoList[pos].attrValueList |
|
|
|
children: productSetMeals[position] |
|
|
|
.take(productSetMeals[position].productInfoList[index].productAttrInfoList[pos].attrValueList.length) |
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[pos] |
|
|
|
|
|
|
|
.attrValueList |
|
|
|
|
|
|
|
.take(productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[pos] |
|
|
|
|
|
|
|
.attrValueList |
|
|
|
|
|
|
|
.length) |
|
|
|
.map<Widget>((AttrValueList tag) { |
|
|
|
.map<Widget>((AttrValueList tag) { |
|
|
|
return GestureDetector( |
|
|
|
return GestureDetector( |
|
|
|
onTap: () { |
|
|
|
onTap: () { |
|
|
|
state(() { |
|
|
|
state(() { |
|
|
|
productSetMeals[position].productInfoList[index].productAttrInfoList[pos].selectSku = |
|
|
|
productSetMeals[position] |
|
|
|
tag.attrName; |
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[pos] |
|
|
|
|
|
|
|
.selectSku = tag.attrName; |
|
|
|
}); |
|
|
|
}); |
|
|
|
}, |
|
|
|
}, |
|
|
|
child: sweetnessItem( |
|
|
|
child: sweetnessItem( |
|
|
|
tag.attrName, |
|
|
|
tag.attrName, |
|
|
|
(productSetMeals[position].productInfoList[index].productAttrInfoList[pos].selectSku == tag.attrName), |
|
|
|
(productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList[pos] |
|
|
|
|
|
|
|
.selectSku == |
|
|
|
|
|
|
|
tag.attrName), |
|
|
|
)); |
|
|
|
)); |
|
|
|
}).toList()); |
|
|
|
}).toList()); |
|
|
|
} |
|
|
|
} |
|
|
@ -524,7 +591,7 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
///选择規格弹窗 |
|
|
|
///选择規格弹窗 |
|
|
|
showSkuDialog(int position,int index) async { |
|
|
|
showSkuDialog(int position, int index) async { |
|
|
|
showDialog( |
|
|
|
showDialog( |
|
|
|
context: context, |
|
|
|
context: context, |
|
|
|
builder: (context) { |
|
|
|
builder: (context) { |
|
|
@ -542,18 +609,15 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
Expanded( |
|
|
|
Expanded( |
|
|
|
child: ListView.builder( |
|
|
|
child: ListView.builder( |
|
|
|
itemCount: productSetMeals[position].productInfoList[index] |
|
|
|
itemCount: productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
.productAttrInfoList |
|
|
|
.productAttrInfoList |
|
|
|
.length, |
|
|
|
.length, |
|
|
|
scrollDirection: Axis.vertical, |
|
|
|
scrollDirection: Axis.vertical, |
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
padding: EdgeInsets.zero, |
|
|
|
padding: EdgeInsets.zero, |
|
|
|
itemBuilder: (context, pos) { |
|
|
|
itemBuilder: (context, pos) { |
|
|
|
return porAttrItem( |
|
|
|
return porAttrItem(position, index, pos, state); |
|
|
|
position,index, |
|
|
|
|
|
|
|
pos, |
|
|
|
|
|
|
|
state |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
}, |
|
|
|
}, |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
@ -564,20 +628,45 @@ class _ProductMealsSku extends State<ProductMealsSku> { |
|
|
|
onTap: () { |
|
|
|
onTap: () { |
|
|
|
setState(() { |
|
|
|
setState(() { |
|
|
|
int total = 0; |
|
|
|
int total = 0; |
|
|
|
productSetMeals[position].productInfoList.forEach((element) { |
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList |
|
|
|
|
|
|
|
.forEach((element) { |
|
|
|
total += element.count; |
|
|
|
total += element.count; |
|
|
|
}); |
|
|
|
}); |
|
|
|
if(productSetMeals[position].productInfoList[index].productAttrInfoList[0].selectSku == null){ |
|
|
|
if (productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList |
|
|
|
|
|
|
|
.where((element) => element.selectSku == null) |
|
|
|
|
|
|
|
.isNotEmpty) { |
|
|
|
SmartDialog.showToast("请先选择规格", |
|
|
|
SmartDialog.showToast("请先选择规格", |
|
|
|
alignment: Alignment.center); |
|
|
|
alignment: Alignment.center); |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
if (total >= productSetMeals[position].optionalNumber && productSetMeals[position].productInfoList[index].count != 1) { |
|
|
|
if (total >= productSetMeals[position].optionalNumber && |
|
|
|
|
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.count != |
|
|
|
|
|
|
|
1) { |
|
|
|
SmartDialog.showToast("抱歉,无法加购更多", |
|
|
|
SmartDialog.showToast("抱歉,无法加购更多", |
|
|
|
alignment: Alignment.center); |
|
|
|
alignment: Alignment.center); |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
productSetMeals[position].productInfoList[index].count = 1; |
|
|
|
productSetMeals[position].productInfoList[index].count = |
|
|
|
|
|
|
|
1; |
|
|
|
|
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.skuInfoList |
|
|
|
|
|
|
|
.forEach((element) { |
|
|
|
|
|
|
|
bool flag = true; |
|
|
|
|
|
|
|
productSetMeals[position] |
|
|
|
|
|
|
|
.productInfoList[index] |
|
|
|
|
|
|
|
.productAttrInfoList |
|
|
|
|
|
|
|
.forEach((e1) { |
|
|
|
|
|
|
|
if (!element.skuName.contains(e1.selectSku)) |
|
|
|
|
|
|
|
flag = false; |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
element.isSelected = flag; |
|
|
|
|
|
|
|
}); |
|
|
|
Navigator.of(context).pop(); |
|
|
|
Navigator.of(context).pop(); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}, |
|
|
|
}, |
|
|
|