Browse Source

新建商品-设置多规格商品详情数据交互完成;

编辑多规格详情数据更改;
设置商品规格页面数据传值处理;
wr_2023_new_business
wurong 1 year ago
parent
commit
bfc6c59c52
  1. 677
      lib/business_system/goods/add_goods/add_goods_page.dart
  2. 8
      lib/business_system/goods/add_goods/edit_specs_detail.dart
  3. 22
      lib/business_system/goods/add_goods/set_goods_specs.dart
  4. 512
      lib/business_system/goods/on_sale/batch_shelf.dart

677
lib/business_system/goods/add_goods/add_goods_page.dart

@ -53,6 +53,7 @@ class _AddGoodsPage extends State<AddGoodsPage> {
bool isKeyBoardShow = false;
FocusNode _focusNode = FocusNode();
List<dynamic> mealDetails = [];
List<dynamic> goodsSpecsDetails = [];
@override
void initState() {
@ -82,14 +83,12 @@ class _AddGoodsPage extends State<AddGoodsPage> {
}
_onRefresh() async {
EasyLoading.show(
status: S.current.zhengzaijiazai,
maskType: EasyLoadingMaskType.black);
EasyLoading.show(
status: S.current.zhengzaijiazai, maskType: EasyLoadingMaskType.black);
await queryProductGroupList();
await queryCategorize();
EasyLoading.dismiss();
if (mounted)
setState(() {});
if (mounted) setState(() {});
}
///
@ -128,7 +127,8 @@ class _AddGoodsPage extends State<AddGoodsPage> {
tenant: BusinessInstance.instance.businessTenant,
storeId: widget.arguments["storeId"]);
}
BaseData<List<GoodsCategoryList>> baseData = await businessService.findCategoryListByDepth().catchError((error) {});
BaseData<List<GoodsCategoryList>> baseData =
await businessService.findCategoryListByDepth().catchError((error) {});
if (baseData != null && baseData.isSuccess) {
goodsCategoryList = baseData.data;
}
@ -146,41 +146,53 @@ class _AddGoodsPage extends State<AddGoodsPage> {
}
BaseData baseData = await businessService.productSave({
"storeId": widget.arguments["storeId"],
"attrStyle": isAttrStyle == true ? 0:1,//1- 0-
"categoryId": "1343391656220557312",//id
"oversold": isOversold == true ? 1:0,//1- 0-
"setMeal": isSetMeal == true ? 0:1,// 0 1
"groupId": "1693436138259218432",//id
"attrStyle": isAttrStyle == true ? 0 : 1, //1- 0-
"categoryId": "1343391656220557312", //id
"oversold": isOversold == true ? 1 : 0, //1- 0-
"setMeal": isSetMeal == true ? 0 : 1, // 0 1
"groupId": "1693436138259218432", //id
"imgs": [
{
"imgPath": "https://pos.upload.lotus-wallet.com/1195/2023/10/1ba87000-d940-49e5-a6ca-f15623d5f841.jpg"
"imgPath":
"https://pos.upload.lotus-wallet.com/1195/2023/10/1ba87000-d940-49e5-a6ca-f15623d5f841.jpg"
}
],//
"needLogistics": isLogistics == true ? 1:0,//1- 0-
"productName": "新建商品",//
"productType": 0,//01app新增商品用不到0
"shortName": "商品简介",//
], //
"needLogistics": isLogistics == true ? 1 : 0, //1- 0-
"productName": "新建商品", //
"productType": 0, //01app新增商品用不到0
"shortName": "商品简介", //
"skuAttrList": [
{
"attrCode": "",//,app新增商品用不到""
"attrName": "",//,app新增商品用不到""
"needImg": 0,//,app新增商品用不到0
"attrCode": "", //,app新增商品用不到""
"attrName": "", //,app新增商品用不到""
"needImg": 0, //,app新增商品用不到0
"attrValueList": [
{"attrValue": "商品规格",//
{
"attrValue": "商品规格", //
"attrValueCode": "", //,app新增商品用不到""
}]//
}
] //
}
],//
], //
"skuList": [
{
"applyPrice": "234",//
"skuAttrCodeDTOList": [{"attrCode": "", "attrValueCode": ""}],//sku对应的规格编码,app新增商品用不到
"skuPrice": "123",//
"packagingFee": "789",//
"skuStock": "666",//
"weight": "222"//
}],//sku列表
"status":isGround == true ? 1:0 //1- 0-
"applyPrice": "234",
//
"skuAttrCodeDTOList": [
{"attrCode": "", "attrValueCode": ""}
],
//sku对应的规格编码,app新增商品用不到
"skuPrice": "123",
//
"packagingFee": "789",
//
"skuStock": "666",
//
"weight": "222"
//
}
], //sku列表
"status": isGround == true ? 1 : 0 //1- 0-
}).catchError((error) {
networkError = AppUtils.dioErrorTypeToString(error.type);
networkStatus = -1;
@ -190,19 +202,19 @@ class _AddGoodsPage extends State<AddGoodsPage> {
if (baseData != null && baseData.isSuccess) {
SmartDialog.show(
widget: SettlementTips(
() {},
text: "新建商品成功",
color: Color(0xFF30415B),
));
() {},
text: "新建商品成功",
color: Color(0xFF30415B),
));
networkStatus = 1;
setState(() {});
} else {
SmartDialog.show(
widget: SettlementTips(
() {},
text: baseData.msg,
color: Color(0xFF30415B),
));
() {},
text: baseData.msg,
color: Color(0xFF30415B),
));
}
} finally {}
}
@ -249,17 +261,19 @@ class _AddGoodsPage extends State<AddGoodsPage> {
children: [
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: (){
onTap: () {
officialCategory();
},
child:textSelectItem("官方分类",categoryName == "" ? "请选择":categoryName),
},
child: textSelectItem(
"官方分类", categoryName == "" ? "请选择" : categoryName),
),
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: (){
onTap: () {
goodsGroup();
},
child:textSelectItem("商品分组",groupName == "" ? "请选择":groupName)),
child: textSelectItem(
"商品分组", groupName == "" ? "请选择" : groupName)),
],
),
),
@ -269,7 +283,9 @@ class _AddGoodsPage extends State<AddGoodsPage> {
margin: EdgeInsets.only(top: 12.h),
child: Column(
children: [
Padding(padding: EdgeInsets.only(top: 18.h,left: 16.w,right: 16.w),
Padding(
padding:
EdgeInsets.only(top: 18.h, left: 16.w, right: 16.w),
child: Row(
children: [
Padding(
@ -284,13 +300,15 @@ class _AddGoodsPage extends State<AddGoodsPage> {
)),
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap:(){
setState((){
onTap: () {
setState(() {
isAttrStyle = !isAttrStyle;
});
},
child: Image.asset(
isAttrStyle == true ? "assets/image/reservation_switch.webp":"assets/image/reservation_unswitch.webp",
isAttrStyle == true
? "assets/image/reservation_switch.webp"
: "assets/image/reservation_unswitch.webp",
width: 44.w,
height: 24.h,
),
@ -301,133 +319,152 @@ class _AddGoodsPage extends State<AddGoodsPage> {
width: double.infinity,
height: 1.w,
color: Color(0x14000000),
margin: EdgeInsets.only(top: 16.h,left: 16.w,right: 16.w),
margin:
EdgeInsets.only(top: 16.h, left: 16.w, right: 16.w),
),
isAttrStyle == true ? GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: (){
Navigator.of(context).pushNamed(
'/router/set_goods_specs');
},
child:Container(
padding: EdgeInsets.only(left: 16.w,right: 16.w,top: 16.h),
child:Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.start,
children: [
Expanded(child:Text(
"商品规格",
style: TextStyle(
color: Color(0xFF0D0D0D),
fontSize: 14.sp,
fontWeight: FontWeight.bold,
isAttrStyle == true
? GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: () {
Navigator.of(context).pushNamed(
'/router/set_goods_specs',
arguments: {
"goodsSpecsDetails": goodsSpecsDetails
}).then((value) {
if (value != null) {
goodsSpecsDetails.clear();
goodsSpecsDetails.addAll(value);
setState(() {});
}
});
},
child: Container(
padding: EdgeInsets.only(
left: 16.w, right: 16.w, top: 16.h),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
crossAxisAlignment:
CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.start,
children: [
Expanded(
child: Text(
"商品规格",
style: TextStyle(
color: Color(0xFF0D0D0D),
fontSize: 14.sp,
fontWeight: FontWeight.bold,
),
)),
Text(
"请设置商品规格",
style: TextStyle(
color: Color(0xFF7A797F),
fontSize: 14.sp,
fontWeight: FontWeight.bold,
),
),
Image.asset(
"assets/image/bs_right.webp",
width: 16.h,
height: 16.h,
),
],
),
)),
Text(
"请设置商品规格",
style: TextStyle(
color: Color(0xFF7A797F),
fontSize: 14.sp,
fontWeight: FontWeight.bold,
Container(
margin: EdgeInsets.only(top: 16.h),
color: Color(0x14000000),
height: 1.h,
width: double.infinity,
),
),
Image.asset(
"assets/image/bs_right.webp",
width: 16.h,
height: 16.h,
),
],
),
Container(
margin: EdgeInsets.only(top: 16.h),
color: Color(0x14000000),
height: 1.h,
width: double.infinity,
],
),
),
],
),
),
): textItem("商品规格", skuController, "请输入商品规格"),
if(isAttrStyle == false)
textItem("商品重量", heftController, "请输入商品重量"),
if(isAttrStyle == false)
textItem("商品售价", priceController, "请输入商品售卖价格"),
if(isAttrStyle == false)
textItem("商品原价", originalPriceController, "请输入商品划线价格"),
if(isAttrStyle == false)
textItem("打包费", packingChargeController, "请输入商品打包费用"),
if(isAttrStyle == false)
textItem("商品库存", stockController, "请输入商品库存"),
if(isAttrStyle == false)
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap:(){
Navigator.of(context).pushNamed(
'/router/set_meal',arguments:{"storeId":widget.arguments["storeId"],"mealDetails":mealDetails}).then((value){
if (value != null){
mealDetails.clear();
mealDetails.addAll(value);
setState((){});
}
});
},
child: Padding(padding: EdgeInsets.symmetric(horizontal: 16.w,vertical:16.h),
child: Column(
children: [
Row(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Expanded(
child:Text(
"设置套餐",
)
: textItem("商品规格", skuController, "请输入商品规格"),
if (isAttrStyle == false)
textItem("商品重量", heftController, "请输入商品重量"),
if (isAttrStyle == false)
textItem("商品售价", priceController, "请输入商品售卖价格"),
if (isAttrStyle == false)
textItem("商品原价", originalPriceController, "请输入商品划线价格"),
if (isAttrStyle == false)
textItem("打包费", packingChargeController, "请输入商品打包费用"),
if (isAttrStyle == false)
textItem("商品库存", stockController, "请输入商品库存"),
if (isAttrStyle == false)
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: () {
Navigator.of(context).pushNamed('/router/set_meal',
arguments: {
"mealDetails": mealDetails
}).then((value) {
if (value != null) {
mealDetails.clear();
mealDetails.addAll(value);
setState(() {});
}
});
},
child: Padding(
padding: EdgeInsets.symmetric(
horizontal: 16.w, vertical: 16.h),
child: Column(
children: [
Row(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Expanded(
child: Text(
"设置套餐",
style: TextStyle(
color: Color(0xD9000000),
fontSize: 14.sp,
fontWeight: FontWeight.bold,
),
),
),
Text(
"套餐选择",
style: TextStyle(
color: Color(0xD9000000),
color: Color(0xFF7A797F),
fontSize: 14.sp,
fontWeight: FontWeight.bold,
),
),
),
Text(
"套餐选择",
style: TextStyle(
color: Color(0xFF7A797F),
fontSize: 14.sp,
fontWeight: FontWeight.bold,
Image.asset(
"assets/image/bs_right.webp",
width: 16.h,
height: 16.h,
),
),
Image.asset(
"assets/image/bs_right.webp",
width: 16.h,
height: 16.h,
),
],
),
Container(
margin:EdgeInsets.only(top: 16.h),
color: Color(0x14000000),
height: 1.h,
width: double.infinity,
),
],
),),
),
],
),
Container(
margin: EdgeInsets.only(top: 16.h),
color: Color(0x14000000),
height: 1.h,
width: double.infinity,
),
],
),
),
),
Container(
width: double.infinity,
padding: EdgeInsets.symmetric(vertical: 16.h),
margin: EdgeInsets.only(top: 111.h, bottom: 34.h,left:16.w,right:16.w),
margin: EdgeInsets.only(
top: 111.h, bottom: 34.h, left: 16.w, right: 16.w),
decoration: BoxDecoration(
color: Color(0xFF30415B),
borderRadius: BorderRadius.circular(27),
),
alignment: Alignment.center,
child: Text(
S
.of(context)
.baocun,
S.of(context).baocun,
style: TextStyle(
color: Colors.white,
fontSize: 16.sp,
@ -541,36 +578,36 @@ class _AddGoodsPage extends State<AddGoodsPage> {
),
Expanded(
child: Container(
padding: EdgeInsets.only(left: 8.w),
margin: EdgeInsets.only(left: 22.w, bottom: 16.h),
decoration: BoxDecoration(
color: Color(0xFFFCFCFC),
border: Border.all(
color: Color(0xFFEBEBEB),
width: 1,
),
borderRadius: BorderRadius.circular(2),
),
alignment: Alignment.topLeft,
child: TextField(
maxLines: 5,
controller: profileController,
onChanged: (value) {
setState(() {
// textLength = value.length;
});
},
decoration: InputDecoration(
border: InputBorder.none,
hintText: "请输入商品商品简介",
hintStyle: TextStyle(
fontSize: 12.sp,
fontWeight: MyFontWeight.bold,
color: Color(0xFF7A797F),
),
),
padding: EdgeInsets.only(left: 8.w),
margin: EdgeInsets.only(left: 22.w, bottom: 16.h),
decoration: BoxDecoration(
color: Color(0xFFFCFCFC),
border: Border.all(
color: Color(0xFFEBEBEB),
width: 1,
),
borderRadius: BorderRadius.circular(2),
),
alignment: Alignment.topLeft,
child: TextField(
maxLines: 5,
controller: profileController,
onChanged: (value) {
setState(() {
// textLength = value.length;
});
},
decoration: InputDecoration(
border: InputBorder.none,
hintText: "请输入商品商品简介",
hintStyle: TextStyle(
fontSize: 12.sp,
fontWeight: MyFontWeight.bold,
color: Color(0xFF7A797F),
),
))
),
),
))
],
),
],
@ -588,7 +625,7 @@ class _AddGoodsPage extends State<AddGoodsPage> {
Row(
children: [
Expanded(
child:Row(
child: Row(
children: [
Padding(
padding: EdgeInsets.only(right: 20.h),
@ -602,13 +639,15 @@ class _AddGoodsPage extends State<AddGoodsPage> {
)),
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap:(){
setState((){
onTap: () {
setState(() {
isLogistics = !isLogistics;
});
},
child: Image.asset(
isLogistics == true ? "assets/image/reservation_switch.webp":"assets/image/reservation_unswitch.webp",
isLogistics == true
? "assets/image/reservation_switch.webp"
: "assets/image/reservation_unswitch.webp",
width: 44.w,
height: 24.h,
),
@ -617,7 +656,7 @@ class _AddGoodsPage extends State<AddGoodsPage> {
),
),
Expanded(
child:Row(
child: Row(
children: [
Padding(
padding: EdgeInsets.only(right: 20.h),
@ -631,13 +670,15 @@ class _AddGoodsPage extends State<AddGoodsPage> {
)),
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap:(){
setState((){
onTap: () {
setState(() {
isGround = !isGround;
});
},
child: Image.asset(
isGround == true ? "assets/image/reservation_switch.webp":"assets/image/reservation_unswitch.webp",
isGround == true
? "assets/image/reservation_switch.webp"
: "assets/image/reservation_unswitch.webp",
width: 44.w,
height: 24.h,
),
@ -656,7 +697,7 @@ class _AddGoodsPage extends State<AddGoodsPage> {
Row(
children: [
Expanded(
child:Row(
child: Row(
children: [
Padding(
padding: EdgeInsets.only(right: 20.h),
@ -670,20 +711,23 @@ class _AddGoodsPage extends State<AddGoodsPage> {
)),
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap:(){
setState((){
onTap: () {
setState(() {
isOversold = !isOversold;
});
},
child: Image.asset(
isOversold == true ? "assets/image/reservation_switch.webp":"assets/image/reservation_unswitch.webp",
isOversold == true
? "assets/image/reservation_switch.webp"
: "assets/image/reservation_unswitch.webp",
width: 44.w,
height: 24.h,
),
),
],
),
), Expanded(
),
Expanded(
child: Row(
children: [
Padding(
@ -698,13 +742,15 @@ class _AddGoodsPage extends State<AddGoodsPage> {
)),
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap:(){
setState((){
onTap: () {
setState(() {
isSetMeal = !isSetMeal;
});
},
child: Image.asset(
isSetMeal == true ? "assets/image/reservation_switch.webp":"assets/image/reservation_unswitch.webp",
isSetMeal == true
? "assets/image/reservation_switch.webp"
: "assets/image/reservation_unswitch.webp",
width: 44.w,
height: 24.h,
),
@ -725,7 +771,7 @@ class _AddGoodsPage extends State<AddGoodsPage> {
);
}
Widget textSelectItem(left,selectName) {
Widget textSelectItem(left, selectName) {
return Container(
padding: EdgeInsets.symmetric(horizontal: 16.w),
child: Column(
@ -787,72 +833,72 @@ class _AddGoodsPage extends State<AddGoodsPage> {
Widget mustTextItem(left, rightController, right) {
return Container(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Row(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Expanded(
child: Text.rich(
Expanded(
child: Text.rich(
TextSpan(
children: [
TextSpan(
children: [
TextSpan(
text: "*",
style: TextStyle(
color: Color(0xFFE02020),
fontSize: 14.sp,
fontWeight: FontWeight.w500,
),
),
TextSpan(
text: left,
style: TextStyle(
color: Color(0xD9000000),
fontSize: 14.sp,
fontWeight: MyFontWeight.bold,
),
),
],
text: "*",
style: TextStyle(
color: Color(0xFFE02020),
fontSize: 14.sp,
fontWeight: FontWeight.w500,
),
),
),
),
Expanded(
child: TextField(
controller: rightController,
decoration: InputDecoration(
hintText: right ?? "",
hintTextDirection: TextDirection.rtl,
hintStyle: TextStyle(
color: Color(0xFF7A797F),
TextSpan(
text: left,
style: TextStyle(
color: Color(0xD9000000),
fontSize: 14.sp,
fontWeight: MyFontWeight.bold,
),
border: InputBorder.none,
),
textAlign: TextAlign.right,
style: TextStyle(
color: Color(0xFF000000),
fontSize: 14.sp,
fontWeight: MyFontWeight.bold),
),
flex: 2,
],
),
],
),
),
Container(
margin: EdgeInsets.only(bottom: 16.h),
color: Color(0x14000000),
height: 1.h,
width: double.infinity,
Expanded(
child: TextField(
controller: rightController,
decoration: InputDecoration(
hintText: right ?? "",
hintTextDirection: TextDirection.rtl,
hintStyle: TextStyle(
color: Color(0xFF7A797F),
fontSize: 14.sp,
fontWeight: MyFontWeight.bold,
),
border: InputBorder.none,
),
textAlign: TextAlign.right,
style: TextStyle(
color: Color(0xFF000000),
fontSize: 14.sp,
fontWeight: MyFontWeight.bold),
),
flex: 2,
),
],
));
),
Container(
margin: EdgeInsets.only(bottom: 16.h),
color: Color(0x14000000),
height: 1.h,
width: double.infinity,
),
],
));
}
Widget textItem(left, rightController, right) {
return Container(
padding: EdgeInsets.symmetric(horizontal: 16.w),
padding: EdgeInsets.symmetric(horizontal: 16.w),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
@ -909,9 +955,9 @@ class _AddGoodsPage extends State<AddGoodsPage> {
backgroundColor: Colors.transparent,
builder: (context) {
return StatefulBuilder(builder: (
context,
state,
) {
context,
state,
) {
return Container(
width: double.infinity,
height: 365.h,
@ -932,18 +978,18 @@ class _AddGoodsPage extends State<AddGoodsPage> {
children: [
Expanded(
child: Container(
alignment: Alignment.center,
margin: EdgeInsets.only(
top: 12.h, bottom: 12.h, left: 41.w),
child: Text(
"选择官方分类",
style: TextStyle(
fontWeight: MyFontWeight.bold,
fontSize: 16.sp,
color: Color(0xFF1A1A1A),
),
),
)),
alignment: Alignment.center,
margin: EdgeInsets.only(
top: 12.h, bottom: 12.h, left: 41.w),
child: Text(
"选择官方分类",
style: TextStyle(
fontWeight: MyFontWeight.bold,
fontSize: 16.sp,
color: Color(0xFF1A1A1A),
),
),
)),
GestureDetector(
onTap: () {
state(() {
@ -961,9 +1007,10 @@ class _AddGoodsPage extends State<AddGoodsPage> {
),
],
),
Expanded(child:ListView.builder(
Expanded(
child: ListView.builder(
padding: EdgeInsets.zero,
itemCount: goodsCategoryList?.length ??0,
itemCount: goodsCategoryList?.length ?? 0,
scrollDirection: Axis.vertical,
shrinkWrap: true,
physics: BouncingScrollPhysics(),
@ -974,21 +1021,24 @@ class _AddGoodsPage extends State<AddGoodsPage> {
categoryIndex = position;
});
},
child: categoryItem(goodsCategoryList[position],position),
child:
categoryItem(goodsCategoryList[position], position),
);
},
)),
GestureDetector(
onTap: () {
setState(() {
categoryName = goodsCategoryList[categoryIndex].categoryName;
categoryName =
goodsCategoryList[categoryIndex].categoryName;
Navigator.of(context).pop();
});
},
child: Container(
width: double.infinity,
alignment: Alignment.center,
margin: EdgeInsets.symmetric(vertical:25.h,horizontal:16.w),
margin: EdgeInsets.symmetric(
vertical: 25.h, horizontal: 16.w),
padding: EdgeInsets.symmetric(vertical: 16.h),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(27),
@ -1010,10 +1060,10 @@ class _AddGoodsPage extends State<AddGoodsPage> {
});
}
Widget categoryItem(GoodsCategoryList goodsCategoryList,index){
return Container(
Widget categoryItem(GoodsCategoryList goodsCategoryList, index) {
return Container(
height: 52.h,
margin: EdgeInsets.only(bottom: 12,left:16.w,right: 16.w),
margin: EdgeInsets.only(bottom: 12, left: 16.w, right: 16.w),
child: Stack(
alignment: Alignment.bottomRight,
children: [
@ -1026,17 +1076,13 @@ class _AddGoodsPage extends State<AddGoodsPage> {
: Color(0xFFF7F7F7),
borderRadius: BorderRadius.circular(4.w),
border: Border.all(
color: categoryIndex == index
? Color(0xFF30415B)
: Colors.white,
color:
categoryIndex == index ? Color(0xFF30415B) : Colors.white,
width: categoryIndex == index ? 1.w : 0,
),
),
padding: EdgeInsets.only(
top: 16.h,
bottom: 16.h,
left: 16.w,
right: 17.w),
top: 16.h, bottom: 16.h, left: 16.w, right: 17.w),
child: Text(
goodsCategoryList?.categoryName ?? "",
style: TextStyle(
@ -1066,9 +1112,9 @@ class _AddGoodsPage extends State<AddGoodsPage> {
backgroundColor: Colors.transparent,
builder: (context) {
return StatefulBuilder(builder: (
context,
state,
) {
context,
state,
) {
return Container(
width: double.infinity,
height: 365.h,
@ -1089,18 +1135,18 @@ class _AddGoodsPage extends State<AddGoodsPage> {
children: [
Expanded(
child: Container(
alignment: Alignment.center,
margin: EdgeInsets.only(
top: 12.h, bottom: 12.h, left: 41.w),
child: Text(
"选择官方分类",
style: TextStyle(
fontWeight: MyFontWeight.bold,
fontSize: 16.sp,
color: Color(0xFF1A1A1A),
),
),
)),
alignment: Alignment.center,
margin: EdgeInsets.only(
top: 12.h, bottom: 12.h, left: 41.w),
child: Text(
"选择官方分类",
style: TextStyle(
fontWeight: MyFontWeight.bold,
fontSize: 16.sp,
color: Color(0xFF1A1A1A),
),
),
)),
GestureDetector(
onTap: () {
state(() {
@ -1118,7 +1164,8 @@ class _AddGoodsPage extends State<AddGoodsPage> {
),
],
),
Expanded(child:ListView.builder(
Expanded(
child: ListView.builder(
padding: EdgeInsets.zero,
itemCount: productGroupList?.records?.length ?? 0,
scrollDirection: Axis.vertical,
@ -1131,21 +1178,25 @@ class _AddGoodsPage extends State<AddGoodsPage> {
groupIndex = position;
});
},
child: groupItem(productGroupList.records[position],position),
child: groupItem(
productGroupList.records[position], position),
);
},
)),
GestureDetector(
onTap: () {
setState(() {
groupName = productGroupList?.records[groupIndex]?.groupName ?? "";
groupName =
productGroupList?.records[groupIndex]?.groupName ??
"";
Navigator.of(context).pop();
});
},
child: Container(
width: double.infinity,
alignment: Alignment.center,
margin: EdgeInsets.symmetric(vertical:25.h,horizontal:16.w),
margin: EdgeInsets.symmetric(
vertical: 25.h, horizontal: 16.w),
padding: EdgeInsets.symmetric(vertical: 16.h),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(27),
@ -1167,10 +1218,10 @@ class _AddGoodsPage extends State<AddGoodsPage> {
});
}
Widget groupItem(Records records,index){
return Container(
Widget groupItem(Records records, index) {
return Container(
height: 52.h,
margin: EdgeInsets.only(bottom: 12,left:16.w,right: 16.w),
margin: EdgeInsets.only(bottom: 12, left: 16.w, right: 16.w),
child: Stack(
alignment: Alignment.bottomRight,
children: [
@ -1178,24 +1229,18 @@ class _AddGoodsPage extends State<AddGoodsPage> {
height: 52.h,
width: double.infinity,
decoration: BoxDecoration(
color: groupIndex == index
? Color(0xFFEFF5FF)
: Color(0xFFF7F7F7),
color:
groupIndex == index ? Color(0xFFEFF5FF) : Color(0xFFF7F7F7),
borderRadius: BorderRadius.circular(4.w),
border: Border.all(
color: groupIndex == index
? Color(0xFF30415B)
: Colors.white,
color: groupIndex == index ? Color(0xFF30415B) : Colors.white,
width: groupIndex == index ? 1.w : 0,
),
),
padding: EdgeInsets.only(
top: 16.h,
bottom: 16.h,
left: 16.w,
right: 17.w),
top: 16.h, bottom: 16.h, left: 16.w, right: 17.w),
child: Text(
records?.groupName ?? "",
records?.groupName ?? "",
style: TextStyle(
fontSize: 14.sp,
fontWeight: MyFontWeight.medium,

8
lib/business_system/goods/add_goods/edit_specs_detail.dart

@ -125,10 +125,10 @@ class _EditSpecsDetail extends State<EditSpecsDetail> {
specsDetail.add({
"skuName": element.specsDetailName,
"goodPrice": element.goodPriceController.text,
"originalPrice": element.originalPriceController.text,
"packagingFee": element.packagingFeeController.text,
"specsWeight": element.specsWeightController.text,
"skuStock": element.skuStockController.text
"originalPrice": element.originalPriceController.text == "" ? "0" :element.originalPriceController.text,
"packagingFee": element.packagingFeeController.text == "" ? "0" :element.packagingFeeController.text,
"specsWeight": element.specsWeightController.text == "" ? "0" :element.specsWeightController.text,
"skuStock": element.skuStockController.text == "" ? "0" :element.skuStockController.text
});
});
if (flag) {

22
lib/business_system/goods/add_goods/set_goods_specs.dart

@ -3,7 +3,6 @@ import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
import 'package:huixiang/view_widget/my_appbar.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import '../../../retrofit/business_api.dart';
import '../../../retrofit/data/edit_specs_detail_list.dart';
import '../../../retrofit/data/set_specs_list.dart';
import '../../../utils/font_weight.dart';
import '../../../view_widget/settlement_tips_dialog.dart';
@ -43,6 +42,14 @@ class _SetGoodsSpecs extends State<SetGoodsSpecs> {
}
});
});
List<dynamic> goodsSpecsDetails = widget?.arguments["goodsSpecsDetails"] ??[];
goodsSpecsDetails.forEach((element) {
var tempValue = SetSpecsList();
tempValue.specsNameController.text = element["specsName"];
tempValue.specsValues = element["specsValue"];
specsDetails.addAll(element["valueDetail"]);
specs.add(tempValue);
});
}
///
@ -257,6 +264,7 @@ class _SetGoodsSpecs extends State<SetGoodsSpecs> {
onTap: () {
bool flag = false;
String tipText = "";
List<dynamic> goodsSpecsDetail = [];
specs.forEach((element) {
if (element.specsNameController.text
.trim() ==
@ -270,7 +278,16 @@ class _SetGoodsSpecs extends State<SetGoodsSpecs> {
flag = true;
tipText = "未添加规格值,请先添加规格值";
return;
}else if(specsDetails.length == 0){
flag = true;
tipText = "请设置规格明细";
return;
}
goodsSpecsDetail.add({
"specsName": element.specsNameController.text,
"specsValue":element.specsValues,
"valueDetail":specsDetails
});
});
if (flag) {
SmartDialog.show(
@ -281,7 +298,8 @@ class _SetGoodsSpecs extends State<SetGoodsSpecs> {
color: Color(0xFF30415B),
));
} else {
// Navigator.of(context).pop();
print(goodsSpecsDetail);
Navigator.of(context).pop(goodsSpecsDetail);
}
},
child: Container(

512
lib/business_system/goods/on_sale/batch_shelf.dart

@ -27,6 +27,7 @@ class BatchShelf extends StatefulWidget {
final Map<String, dynamic> arguments;
BatchShelf({this.arguments});
@override
State<StatefulWidget> createState() {
return _BatchShelf();
@ -66,13 +67,17 @@ class _BatchShelf extends State<BatchShelf> {
status: S.current.zhengzaijiazai,
maskType: EasyLoadingMaskType.black);
SharedPreferences.getInstance().then((value) {
businessService = BusinessApiService(Dio(),
businessService = BusinessApiService(
Dio(),
context: context,
token: BusinessInstance.instance.businessToken,
tenant: BusinessInstance.instance.businessTenant,
storeId: widget.arguments["storeId"],);
storeId: widget.arguments["storeId"],
);
queryProductGroupList();
queryGoodsList(groupIndex != -1 ? productGroupList.records[groupIndex].id : "", isSing: false);
queryGoodsList(
groupIndex != -1 ? productGroupList.records[groupIndex].id : "",
isSing: false);
});
}
@ -97,8 +102,7 @@ class _BatchShelf extends State<BatchShelf> {
"order": "ascending",
"size": 100,
"sort": "sort"
}).catchError((error) {
});
}).catchError((error) {});
if (!mounted) return;
if (baseData != null && baseData.isSuccess) {
productGroupList = baseData.data;
@ -114,7 +118,7 @@ class _BatchShelf extends State<BatchShelf> {
queryGoodsList(groupId, {isSing = true}) async {
try {
BaseData<BusinessGoods> baseData =
await businessService.findAdminProductLis({
await businessService.findAdminProductLis({
"groupId": groupId,
"hasStock": "",
"keyword": "",
@ -150,7 +154,7 @@ class _BatchShelf extends State<BatchShelf> {
}
queryGoodsUpdate() async {
try{
try {
EasyLoading.show(
status: S.current.zhengzaijiazai,
maskType: EasyLoadingMaskType.black);
@ -169,16 +173,17 @@ class _BatchShelf extends State<BatchShelf> {
if (baseData != null && baseData.isSuccess) {
_pageIndex = 1;
adminProductVoList.clear();
await queryGoodsList(groupIndex == -1
? ""
: productGroupList?.records[groupIndex]?.id ?? "", isSing: false);
await queryGoodsList(
groupIndex == -1
? ""
: productGroupList?.records[groupIndex]?.id ?? "",
isSing: false);
setState(() {});
SmartDialog.showToast("商品下架成功", alignment: Alignment.center);
} else {
SmartDialog.showToast(baseData.msg, alignment: Alignment.center);
}
}
finally{
} finally {
EasyLoading.dismiss();
}
}
@ -195,24 +200,21 @@ class _BatchShelf extends State<BatchShelf> {
brightness: Brightness.dark,
action: GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: (){
onTap: () {
List<Map<String, String>> goodsMeal = [];
if(titleName == "批量下架"){
if (productIds.length != 0)
productIds.clear();
if (titleName == "批量下架") {
if (productIds.length != 0) productIds.clear();
adminProductVoList.forEach((element) {
if (element.isSelect) productIds.add(element.id);
});
if (productIds.length == 0) {
SmartDialog.showToast("请选择要下架的商品",
alignment: Alignment.center);
SmartDialog.showToast("请选择要下架的商品", alignment: Alignment.center);
return;
} else {
showGoodsStateDialog();
}
}else{
if(goodsMeal.length != 0)
goodsMeal.clear();
} else {
if (goodsMeal.length != 0) goodsMeal.clear();
adminProductVoList.forEach((element) {
if (element.isSelect)
goodsMeal.add({
@ -222,8 +224,7 @@ class _BatchShelf extends State<BatchShelf> {
});
Navigator.of(context).pop(goodsMeal);
if (goodsMeal.length == 0) {
SmartDialog.showToast("请选择要增加的商品",
alignment: Alignment.center);
SmartDialog.showToast("请选择要增加的商品", alignment: Alignment.center);
return;
}
}
@ -241,105 +242,108 @@ class _BatchShelf extends State<BatchShelf> {
),
),
),
body: networkStatus == -1 ? noNetwork() : Row(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Container(
width: 100.w,
height: double.infinity,
padding: EdgeInsets.only(bottom: 70.h),
color: Color(0xFFFAFAFA),
child:networkStatus == 0
? ListView.builder(
itemCount: 10,
physics: BouncingScrollPhysics(),
shrinkWrap: true,
itemBuilder: (context, position) {
return shelfLeftItemSm();
},
)
: ListView.builder(
itemCount: productGroupList?.records?.length ?? 0,
physics: BouncingScrollPhysics(),
shrinkWrap: true,
itemBuilder: (context, position) {
return GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: () {
groupIndex = position;
_pageIndex = 1;
adminProductVoList.clear();
queryGoodsList(productGroupList?.records[position].id,);
},
child: shelfLeftItem(
productGroupList.records[position],
position),
);
},
),
),
Container(
width: MediaQuery.of(context).size.width - 100.w,
child: SmartRefresher(
controller: _refreshController,
enablePullDown: true,
enablePullUp:
adminProductVoList.length != 0 ? true : false,
header: MyHeader(
color: Color(0xFF30415B),
),
physics: BouncingScrollPhysics(),
footer: CustomFooter(
builder: (context, mode) {
return MyFooter(mode);
},
body: networkStatus == -1
? noNetwork()
: Row(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Container(
width: 100.w,
height: double.infinity,
padding: EdgeInsets.only(bottom: 70.h),
color: Color(0xFFFAFAFA),
child: networkStatus == 0
? ListView.builder(
itemCount: 10,
physics: BouncingScrollPhysics(),
shrinkWrap: true,
itemBuilder: (context, position) {
return shelfLeftItemSm();
},
)
: ListView.builder(
itemCount: productGroupList?.records?.length ?? 0,
physics: BouncingScrollPhysics(),
shrinkWrap: true,
itemBuilder: (context, position) {
return GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: () {
groupIndex = position;
_pageIndex = 1;
adminProductVoList.clear();
queryGoodsList(
productGroupList?.records[position].id,
);
},
child: shelfLeftItem(
productGroupList.records[position], position),
);
},
),
),
onLoading: () {
_pageIndex++;
queryGoodsList(groupIndex == -1
? ""
: productGroupList?.records[groupIndex].id);
},
onRefresh: () {
_pageIndex = 1;
adminProductVoList.clear();
_onRefresh(isShowLoad: false);
},
child: Container(
color: Colors.white,
child: networkStatus == 0
? ListView.builder(
itemCount: 10,
Container(
width: MediaQuery.of(context).size.width - 100.w,
child: SmartRefresher(
controller: _refreshController,
enablePullDown: true,
enablePullUp:
adminProductVoList.length != 0 ? true : false,
header: MyHeader(
color: Color(0xFF30415B),
),
physics: BouncingScrollPhysics(),
shrinkWrap: true,
itemBuilder: (context, position) {
return shelfGoodsItemSm();
footer: CustomFooter(
builder: (context, mode) {
return MyFooter(mode);
},
),
onLoading: () {
_pageIndex++;
queryGoodsList(groupIndex == -1
? ""
: productGroupList?.records[groupIndex].id);
},
)
: ((adminProductVoList == null ||
adminProductVoList.length == 0)
? NoDataView(
src:
"assets/image/bs_no data_logo.webp",
isShowBtn: false,
text: "该分组暂无添加商品",
fontSize: 16.sp,
margin: EdgeInsets.all(20.h),
)
: ListView.builder(
itemCount:
adminProductVoList?.length ?? 0,
controller: controller,
physics: BouncingScrollPhysics(),
shrinkWrap: true,
itemBuilder: (context, position) {
return shelfGoodsItem(adminProductVoList[position]);
onRefresh: () {
_pageIndex = 1;
adminProductVoList.clear();
_onRefresh(isShowLoad: false);
},
)))),
),
],
),
child: Container(
color: Colors.white,
child: networkStatus == 0
? ListView.builder(
itemCount: 10,
physics: BouncingScrollPhysics(),
shrinkWrap: true,
itemBuilder: (context, position) {
return shelfGoodsItemSm();
},
)
: ((adminProductVoList == null ||
adminProductVoList.length == 0)
? NoDataView(
src: "assets/image/bs_no data_logo.webp",
isShowBtn: false,
text: "该分组暂无添加商品",
fontSize: 16.sp,
margin: EdgeInsets.all(20.h),
)
: ListView.builder(
itemCount:
adminProductVoList?.length ?? 0,
controller: controller,
physics: BouncingScrollPhysics(),
shrinkWrap: true,
itemBuilder: (context, position) {
return shelfGoodsItem(
adminProductVoList[position]);
},
)))),
),
],
),
);
}
@ -419,7 +423,7 @@ class _BatchShelf extends State<BatchShelf> {
}
///list
Widget shelfLeftItem(Records records, index){
Widget shelfLeftItem(Records records, index) {
return Container(
color: groupIndex == index ? Colors.white : Color(0xFFFAFAFA),
alignment: Alignment.center,
@ -430,25 +434,25 @@ class _BatchShelf extends State<BatchShelf> {
children: [
Expanded(
child: Text(
records?.groupName ?? "",
textAlign: TextAlign.center,
style: TextStyle(
color:
records?.groupName ?? "",
textAlign: TextAlign.center,
style: TextStyle(
color:
groupIndex == index ? Color(0xFF30415B) : Color(0xFF626264),
fontSize: 12.sp,
fontWeight: groupIndex == index
? MyFontWeight.semi_bold
: MyFontWeight.regular,
),
)),
fontSize: 12.sp,
fontWeight: groupIndex == index
? MyFontWeight.semi_bold
: MyFontWeight.regular,
),
)),
],
),
);
}
Widget shelfGoodsItem(AdminProductVoList adminProductVoList){
Widget shelfGoodsItem(AdminProductVoList adminProductVoList) {
return Container(
margin: EdgeInsets.only(bottom: 21.h,left: 16.w),
margin: EdgeInsets.only(bottom: 21.h, left: 16.w),
child: Row(
children: [
MImage(
@ -458,21 +462,25 @@ class _BatchShelf extends State<BatchShelf> {
fit: BoxFit.cover,
radius: BorderRadius.circular(4),
),
SizedBox(width:12.w,),
Expanded(child:Column(
SizedBox(
width: 12.w,
),
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(padding:EdgeInsets.only(top: 2.h),
child:Text(
adminProductVoList?.productName ?? "",
maxLines:1,
overflow: TextOverflow.ellipsis,
style: TextStyle(
fontSize: 14.sp,
fontWeight: MyFontWeight.medium,
color: Color(0xFF000000),
),
)),
Padding(
padding: EdgeInsets.only(top: 2.h),
child: Text(
adminProductVoList?.productName ?? "",
maxLines: 1,
overflow: TextOverflow.ellipsis,
style: TextStyle(
fontSize: 14.sp,
fontWeight: MyFontWeight.medium,
color: Color(0xFF000000),
),
)),
Row(
children: [
Text(
@ -483,8 +491,11 @@ class _BatchShelf extends State<BatchShelf> {
color: Color(0xFFA29E9E),
),
),
SizedBox(width: 8.w,),
Expanded(child: Text(
SizedBox(
width: 8.w,
),
Expanded(
child: Text(
"销量${adminProductVoList?.sellCount ?? 0}",
style: TextStyle(
fontSize: 10.sp,
@ -496,7 +507,8 @@ class _BatchShelf extends State<BatchShelf> {
value: adminProductVoList.isSelect,
onChanged: (a) {
setState(() {
adminProductVoList.isSelect = !adminProductVoList.isSelect;
adminProductVoList.isSelect =
!adminProductVoList.isSelect;
});
},
shape: RoundedRectangleBorder(
@ -507,10 +519,13 @@ class _BatchShelf extends State<BatchShelf> {
),
],
),
SizedBox(height:7.h,),
SizedBox(
height: 7.h,
),
Row(
children: [
Expanded(child:Text.rich(
Expanded(
child: Text.rich(
TextSpan(
children: [
TextSpan(
@ -532,48 +547,49 @@ class _BatchShelf extends State<BatchShelf> {
],
),
)),
if(titleName == "选择商品")
GestureDetector(
behavior:HitTestBehavior.opaque,
onTap:(){
setState((){
if(adminProductVoList.goodsNumber <= 1)
return;
adminProductVoList?.goodsNumber = adminProductVoList.goodsNumber - 1;
if (titleName == "选择商品")
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: () {
setState(() {
if (adminProductVoList.goodsNumber <= 1) return;
adminProductVoList?.goodsNumber =
adminProductVoList.goodsNumber - 1;
});
},
child: Container(
padding: EdgeInsets.symmetric(horizontal: 10.w),
child: Icon(
Icons.remove_circle_outline,
color: Color(0xFF30415B),
size: 24,
))),
if (titleName == "选择商品")
Text(
adminProductVoList?.goodsNumber?.toString() ?? "",
style: TextStyle(
color: Color(0xD9000000),
fontSize: 20.sp,
fontWeight: MyFontWeight.regular,
),
),
if (titleName == "选择商品")
GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: () {
setState(() {
adminProductVoList.goodsNumber =
adminProductVoList.goodsNumber + 1;
});
},
child: Container(
padding: EdgeInsets.symmetric(horizontal:10.w),
child: Icon(
Icons.remove_circle_outline,
color: Color(0xFF30415B),
size: 24,
))),
if(titleName == "选择商品")
Text(
adminProductVoList?.goodsNumber?.toString() ?? "",
style: TextStyle(
color: Color(0xD9000000),
fontSize: 20.sp,
fontWeight: MyFontWeight.regular,
padding: EdgeInsets.symmetric(horizontal: 10.w),
child: Icon(
Icons.add_circle,
color: Color(0xFF30415B),
size: 24,
)),
),
),
if(titleName == "选择商品")
GestureDetector(
behavior:HitTestBehavior.opaque,
onTap:(){
setState((){
adminProductVoList.goodsNumber = adminProductVoList.goodsNumber + 1;
});
},
child: Container(
padding: EdgeInsets.symmetric(horizontal:10.w),
child: Icon(
Icons.add_circle,
color: Color(0xFF30415B),
size: 24,
)),
),
],
),
],
@ -624,69 +640,39 @@ class _BatchShelf extends State<BatchShelf> {
),
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: EdgeInsets.only(bottom: 11.h, top: 2.h),
child: Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
highlightColor: Color(0XFFD8D8D8),
child: Container(
decoration: BoxDecoration(
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
width: 124.w,
height: 20.h,
),
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: EdgeInsets.only(bottom: 11.h, top: 2.h),
child: Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
highlightColor: Color(0XFFD8D8D8),
child: Container(
decoration: BoxDecoration(
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
width: 124.w,
height: 20.h,
),
Row(
children: [
Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
highlightColor: Color(0XFFD8D8D8),
child: Container(
decoration: BoxDecoration(
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
width: 43.w,
height: 18.h,
),
),
SizedBox(
width: 8.w,
),
Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
highlightColor: Color(0XFFD8D8D8),
child: Container(
decoration: BoxDecoration(
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
width: 43.w,
height: 18.h,
),
),
Spacer(),
Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
highlightColor: Color(0XFFD8D8D8),
child: Container(
decoration: BoxDecoration(
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
width: 16.h,
height: 16.h,
),
),
),
Row(
children: [
Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
highlightColor: Color(0XFFD8D8D8),
child: Container(
decoration: BoxDecoration(
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
],
width: 43.w,
height: 18.h,
),
),
SizedBox(
height: 7.h,
width: 8.w,
),
Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
@ -696,12 +682,42 @@ class _BatchShelf extends State<BatchShelf> {
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
width: 28.w,
height: 20.h,
width: 43.w,
height: 18.h,
),
),
Spacer(),
Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
highlightColor: Color(0XFFD8D8D8),
child: Container(
decoration: BoxDecoration(
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
width: 16.h,
height: 16.h,
),
),
],
)),
),
SizedBox(
height: 7.h,
),
Shimmer.fromColors(
baseColor: Color(0XFFD8D8D8),
highlightColor: Color(0XFFD8D8D8),
child: Container(
decoration: BoxDecoration(
color: Color(0XFFD8D8D8),
borderRadius: BorderRadius.circular(2),
),
width: 28.w,
height: 20.h,
),
),
],
)),
],
),
);

Loading…
Cancel
Save