import 'package:cheminova/models/product_model.dart'; import 'package:cheminova/provider/product_provider.dart'; import 'package:cheminova/screens/data_submit_successfull.dart'; import 'package:cheminova/widgets/common_app_bar.dart'; import 'package:cheminova/widgets/common_background.dart'; import 'package:cheminova/widgets/common_drawer.dart'; import 'package:cheminova/widgets/common_elevated_button.dart'; import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; class AddProductsScreen extends StatefulWidget { const AddProductsScreen({super.key}); @override State createState() => _AddProductsScreenState(); } class _AddProductsScreenState extends State { List selectedProducts = []; List filteredProducts = []; final searchController = TextEditingController(); @override void initState() { super.initState(); final provider = Provider.of(context, listen: false); filteredProducts = provider.productList; } void filterProducts(String query) { setState(() { final provider = Provider.of(context, listen: false); filteredProducts = provider.productList.where((product) { final productNameLower = product.name.toLowerCase(); final productSkuLower = product.SKU.toLowerCase(); final searchLower = query.toLowerCase(); return productNameLower.contains(searchLower) || productSkuLower.contains(searchLower); }).toList(); }); } @override Widget build(BuildContext context) { return CommonBackground( child: Scaffold( backgroundColor: Colors.transparent, appBar: CommonAppBar( actions: [ IconButton( onPressed: () { Navigator.pop(context); }, icon: Image.asset('assets/Back_attendance.png'), padding: const EdgeInsets.only(right: 20), ), ], title: const Text('Add Products', style: TextStyle( fontSize: 20, color: Colors.black, fontWeight: FontWeight.w400, fontFamily: 'Anek')), backgroundColor: Colors.transparent, elevation: 0, ), drawer: const CommonDrawer(), body: Consumer( builder: (context, provider, child) { if (provider.isLoading) { return const Center(child: CircularProgressIndicator()); } return Stack( children: [ Column( children: [ if (selectedProducts.isNotEmpty) Expanded( child: ListView.builder( itemCount: selectedProducts.length, itemBuilder: (context, index) { return ProductBlock( product: selectedProducts[index]); }, ), ), ], ), Align( alignment: selectedProducts.isEmpty ? Alignment.center : Alignment.bottomCenter, child: Padding( padding: const EdgeInsets.all(16.0), child: Column( mainAxisSize: MainAxisSize.min, children: [ FloatingActionButton.extended( onPressed: () { showModalBottomSheet( context: context, builder: (BuildContext context) { return StatefulBuilder( builder: (context, setState) { return Column( children: [ Padding( padding: const EdgeInsets.all(8.0), child: TextField( controller: searchController, decoration: const InputDecoration( labelText: 'Search by name or SKU', border: OutlineInputBorder(), prefixIcon: Icon(Icons.search), ), onChanged: (value) { filterProducts(value); setState(() {}); }, ), ), Expanded( child: ListView.builder( itemCount: filteredProducts.length, itemBuilder: (context, index) { bool isAlreadySelected = selectedProducts.contains( filteredProducts[index]); return Card( child: ListTile( title: Text( filteredProducts[index] .name, style: TextStyle( color: isAlreadySelected ? Colors.grey : Colors.black, ), ), subtitle: Text( filteredProducts[index].SKU, style: TextStyle( color: isAlreadySelected ? Colors.grey : Colors.black, ), ), onTap: isAlreadySelected ? null : () { setState(() { selectedProducts.add( filteredProducts[ index]); }); Navigator.pop( context); }, ), ); }, ), ), ], ); }, ); }, ).whenComplete(() { setState(() {}); }); }, backgroundColor: Colors.white, icon: const Icon(Icons.add, color: Colors.black), label: const Text( 'Add Products', style: TextStyle(color: Colors.black), ), ), if (selectedProducts.isNotEmpty) ...[ const SizedBox(height: 16.0), CommonElevatedButton( borderRadius: 30, width: double.infinity, height: kToolbarHeight - 10, text: 'SUBMIT', backgroundColor: const Color(0xff004791), onPressed: () { Navigator.push( context, MaterialPageRoute( builder: (context) => const DataSubmitSuccessfull(), ), ); }, ), ], ], ), ), ), ], ); }, ), ), ); } } class ProductBlock extends StatefulWidget { final Product product; const ProductBlock({super.key, required this.product}); @override _ProductBlockState createState() => _ProductBlockState(); } class _ProductBlockState extends State { final saleController = TextEditingController(); final inventoryController = TextEditingController(); String? errorMessage; @override void initState() { super.initState(); } void validateInput() { setState(() { if (saleController.text.isNotEmpty && inventoryController.text.isNotEmpty) { int sale = int.parse(saleController.text); int inventory = int.parse(inventoryController.text); if (inventory > sale) { errorMessage = 'Inventory should be less than or equal to sales'; } else { errorMessage = null; } } else { errorMessage = null; } }); } @override Widget build(BuildContext context) { return Card( // color: !widget.product.isPurchased ? Colors.white54 : Colors.white, color: Colors.white, margin: const EdgeInsets.all(8), child: Padding( padding: const EdgeInsets.all(16), child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Text('Product: ${widget.product.name}', style: const TextStyle(fontSize: 16)), Text('SKU: ${widget.product.SKU}', style: const TextStyle(fontSize: 15)), const SizedBox(height: 8), TextField( controller: saleController, decoration: const InputDecoration(labelText: 'Sale'), keyboardType: TextInputType.number, // enabled: widget.product.isPurchased, enabled: true, onChanged: (_) => validateInput(), ), TextField( controller: inventoryController, decoration: const InputDecoration(labelText: 'Inventory'), keyboardType: TextInputType.number, // enabled: widget.product.isPurchased, enabled: true, onChanged: (_) => validateInput(), ), if (errorMessage != null) Padding( padding: const EdgeInsets.only(top: 8.0), child: Text( errorMessage!, style: const TextStyle(color: Colors.red), ), ), ], ), ), ); } }