converted to stateless

This commit is contained in:
hannathkadher
2025-01-05 15:37:20 +04:00
parent 0bed2573a0
commit ed06b0ebd6
2 changed files with 106 additions and 97 deletions

View File

@ -0,0 +1,30 @@
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:syncrow_web/pages/spaces_management/all_spaces/model/selected_product_model.dart';
class AddDeviceTypeModelBloc extends Cubit<List<SelectedProduct>> {
AddDeviceTypeModelBloc(List<SelectedProduct> initialProducts)
: super(initialProducts);
void updateProductCount(String productId, int count) {
final existingProduct = state.firstWhere(
(p) => p.productId == productId,
orElse: () => SelectedProduct(productId: productId, count: 0),
);
if (count > 0) {
if (!state.contains(existingProduct)) {
emit([...state, SelectedProduct(productId: productId, count: count)]);
} else {
final updatedList = state.map((p) {
if (p.productId == productId) {
return SelectedProduct(productId: p.productId, count: count);
}
return p;
}).toList();
emit(updatedList);
}
} else {
emit(state.where((p) => p.productId != productId).toList());
}
}
}

View File

@ -1,14 +1,15 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:flutter_svg/flutter_svg.dart'; import 'package:flutter_svg/flutter_svg.dart';
import 'package:syncrow_web/pages/common/buttons/default_button.dart'; import 'package:syncrow_web/pages/common/buttons/default_button.dart';
import 'package:syncrow_web/pages/spaces_management/all_spaces/model/product_model.dart'; import 'package:syncrow_web/pages/spaces_management/all_spaces/model/product_model.dart';
import 'package:syncrow_web/pages/spaces_management/all_spaces/model/selected_product_model.dart'; import 'package:syncrow_web/pages/spaces_management/all_spaces/model/selected_product_model.dart';
import 'package:syncrow_web/pages/spaces_management/all_spaces/widgets/counter_widget.dart'; import 'package:syncrow_web/pages/spaces_management/all_spaces/widgets/counter_widget.dart';
import 'package:syncrow_web/pages/spaces_management/space_model/bloc/add_device_model_bloc.dart';
import 'package:syncrow_web/utils/color_manager.dart'; import 'package:syncrow_web/utils/color_manager.dart';
import 'package:syncrow_web/utils/constants/assets.dart'; import 'package:syncrow_web/utils/constants/assets.dart';
import 'package:syncrow_web/utils/extension/build_context_x.dart';
class AddDeviceTypeModelWidget extends StatefulWidget { class AddDeviceTypeModelWidget extends StatelessWidget {
final List<ProductModel>? products; final List<ProductModel>? products;
final ValueChanged<List<SelectedProduct>>? onProductsSelected; final ValueChanged<List<SelectedProduct>>? onProductsSelected;
final List<SelectedProduct>? initialSelectedProducts; final List<SelectedProduct>? initialSelectedProducts;
@ -20,101 +21,93 @@ class AddDeviceTypeModelWidget extends StatefulWidget {
this.onProductsSelected, this.onProductsSelected,
}); });
@override
_AddDeviceWidgetState createState() => _AddDeviceWidgetState();
}
class _AddDeviceWidgetState extends State<AddDeviceTypeModelWidget> {
late final ScrollController _scrollController;
late List<SelectedProduct> productCounts;
@override
void initState() {
super.initState();
_scrollController = ScrollController();
productCounts = widget.initialSelectedProducts != null
? List.from(widget.initialSelectedProducts!)
: [];
}
@override
void dispose() {
_scrollController.dispose();
super.dispose();
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
final size = MediaQuery.of(context).size; final size = MediaQuery.of(context).size;
// Adjust the GridView properties based on screen width
final crossAxisCount = size.width > 1200 final crossAxisCount = size.width > 1200
? 8 ? 8
: size.width > 800 : size.width > 800
? 5 ? 5
: 3; : 3;
return AlertDialog( return BlocProvider(
title: const Text('Add Devices'), create: (_) => AddDeviceTypeModelBloc(
backgroundColor: ColorsManager.whiteColors, initialSelectedProducts ?? []), // Initialize with initial products
content: SingleChildScrollView( child: AlertDialog(
child: Container( title: const Text('Add Devices'),
width: size.width * 0.9, backgroundColor: ColorsManager.whiteColors,
height: size.height * 0.65, content: SingleChildScrollView(
color: ColorsManager.textFieldGreyColor, child: Container(
child: Column( width: size.width * 0.9,
children: [ height: size.height * 0.65,
const SizedBox(height: 16), color: ColorsManager.textFieldGreyColor,
Expanded( child: Column(
child: Padding( children: [
padding: const EdgeInsets.symmetric(horizontal: 20.0), const SizedBox(height: 16),
child: Scrollbar( Expanded(
controller: _scrollController, child: Padding(
thumbVisibility: false, padding: const EdgeInsets.symmetric(horizontal: 20.0),
child: GridView.builder( child: Scrollbar(
shrinkWrap: true, thumbVisibility: false,
controller: _scrollController, child: BlocBuilder<AddDeviceTypeModelBloc, List<SelectedProduct>>(
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount( builder: (context, productCounts) {
crossAxisCount: crossAxisCount, return GridView.builder(
mainAxisSpacing: 6, shrinkWrap: true,
crossAxisSpacing: 4, gridDelegate:
childAspectRatio: .8, SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: crossAxisCount,
mainAxisSpacing: 6,
crossAxisSpacing: 4,
childAspectRatio: .8,
),
itemCount: products?.length ?? 0,
itemBuilder: (context, index) {
final product = products![index];
return _buildDeviceTypeTile(
context, product, size, productCounts);
},
);
},
), ),
itemCount: widget.products?.length ?? 0,
itemBuilder: (context, index) {
final product = widget.products![index];
return _buildDeviceTypeTile(product, size);
},
), ),
), ),
), ),
],
),
),
),
actions: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
_buildActionButton(
'Cancel',
ColorsManager.boxColor,
ColorsManager.blackColor,
() => Navigator.of(context).pop(),
),
_buildActionButton(
'Continue',
ColorsManager.secondaryColor,
ColorsManager.whiteColors,
() {
Navigator.of(context).pop();
if (onProductsSelected != null) {
final selectedProducts =
context.read<AddDeviceTypeModelBloc>().state;
onProductsSelected!(selectedProducts);
}
},
), ),
], ],
), ),
), ],
), ),
actions: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
_buildActionButton(
'Cancel', ColorsManager.boxColor, ColorsManager.blackColor, () {
Navigator.of(context).pop();
}),
_buildActionButton(
'Continue', ColorsManager.secondaryColor, Colors.white, () {
Navigator.of(context).pop();
if (widget.onProductsSelected != null) {
widget.onProductsSelected!(productCounts);
}
}),
],
),
],
); );
} }
Widget _buildDeviceTypeTile(ProductModel product, Size size) { Widget _buildDeviceTypeTile(BuildContext context, ProductModel product,
Size size, List<SelectedProduct> productCounts) {
final selectedProduct = productCounts.firstWhere( final selectedProduct = productCounts.firstWhere(
(p) => p.productId == product.uuid, (p) => p.productId == product.uuid,
orElse: () => SelectedProduct(productId: product.uuid, count: 0), orElse: () => SelectedProduct(productId: product.uuid, count: 0),
@ -137,28 +130,14 @@ class _AddDeviceWidgetState extends State<AddDeviceTypeModelWidget> {
children: [ children: [
_buildDeviceIcon(product, size), _buildDeviceIcon(product, size),
const SizedBox(height: 4), const SizedBox(height: 4),
_buildDeviceName(product, size), _buildDeviceName(context,product, size),
const SizedBox(height: 4), const SizedBox(height: 4),
CounterWidget( CounterWidget(
initialCount: selectedProduct.count, initialCount: selectedProduct.count,
onCountChanged: (newCount) { onCountChanged: (newCount) {
setState(() { context
if (newCount > 0) { .read<AddDeviceTypeModelBloc>()
if (!productCounts.contains(selectedProduct)) { .updateProductCount(product.uuid, newCount);
productCounts.add(SelectedProduct(
productId: product.uuid, count: newCount));
} else {
selectedProduct.count = newCount;
}
} else {
productCounts
.removeWhere((p) => p.productId == product.uuid);
}
if (widget.onProductsSelected != null) {
widget.onProductsSelected!(productCounts);
}
});
}, },
), ),
], ],
@ -190,12 +169,12 @@ class _AddDeviceWidgetState extends State<AddDeviceTypeModelWidget> {
); );
} }
Widget _buildDeviceName(ProductModel product, Size size) { Widget _buildDeviceName(BuildContext context, product, Size size) {
return SizedBox( return SizedBox(
height: size.width > 800 ? 35 : 25, height: size.width > 800 ? 35 : 25,
child: Text( child: Text(
product.name ?? '', product.name ?? '',
style: context.textTheme.bodySmall style: Theme.of(context).textTheme.bodySmall
?.copyWith(color: ColorsManager.blackColor), ?.copyWith(color: ColorsManager.blackColor),
textAlign: TextAlign.center, textAlign: TextAlign.center,
maxLines: 2, maxLines: 2,