parent
							
								
									b0be1b56fc
								
							
						
					
					
						commit
						f8f13f1433
					
				| @ -0,0 +1,263 @@ | ||||
| import 'dart:convert'; | ||||
| 
 | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:watermanagement/adddeliveryboy.dart'; | ||||
| import 'package:watermanagement/models/getdeliveryboy_model.dart'; | ||||
| import 'package:watermanagement/settings.dart'; | ||||
| 
 | ||||
| 
 | ||||
| class GetDeliveryboyData extends StatefulWidget { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   @override | ||||
|   State<GetDeliveryboyData> createState() => _GetDeliveryboyDataState(); | ||||
| } | ||||
| 
 | ||||
| class _GetDeliveryboyDataState extends State<GetDeliveryboyData> { | ||||
| 
 | ||||
|   List<GetDeliveryboyDetailsModel> modeldeliveryboyList = []; | ||||
|   TextEditingController deliveryboyNameController = TextEditingController(); | ||||
|   TextEditingController deliveryboyPhoneController = TextEditingController(); | ||||
|   TextEditingController deliveryboyAlterPhoneController = TextEditingController(); | ||||
|   TextEditingController deliveryboyAddress = TextEditingController(); | ||||
| 
 | ||||
|   bool isLoading=false; | ||||
| 
 | ||||
|   Future<void> readJson() async { | ||||
|     var response1= await AppSettings.getAllDeliverboy(); | ||||
|     print(response1); | ||||
|     setState(() { | ||||
|       modeldeliveryboyList = | ||||
|           ((jsonDecode(response1)['data']) as List).map((dynamic model) { | ||||
|             return GetDeliveryboyDetailsModel.fromJson(model); | ||||
|           }).toList(); | ||||
|       isLoading=false; | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   void initState() { | ||||
|     isLoading=true; | ||||
|     readJson(); | ||||
|     super.initState(); | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   Widget renderzUi(){ | ||||
|     if(modeldeliveryboyList.length!=0){ | ||||
| 
 | ||||
|       return  Column( | ||||
|           crossAxisAlignment: CrossAxisAlignment.end, | ||||
|           children: [ | ||||
|             Expanded(child:ListView.builder( | ||||
|                 padding:  EdgeInsets.all(0), | ||||
|                 itemCount: modeldeliveryboyList.length, | ||||
|                 itemBuilder: (BuildContext context, int index) { | ||||
|                   return Card( | ||||
| 
 | ||||
|                     color: modeldeliveryboyList[index].cardColor, | ||||
|                     child: Padding( | ||||
|                       padding:EdgeInsets.all(8) , | ||||
|                       child: Row( | ||||
|                         mainAxisAlignment: MainAxisAlignment.spaceBetween, | ||||
|                         crossAxisAlignment: CrossAxisAlignment.center, | ||||
|                         children: [ | ||||
| 
 | ||||
|                           Container( | ||||
|                             //width: MediaQuery.of(context).size.width * .55, | ||||
|                             child: Row( | ||||
|                               mainAxisAlignment: MainAxisAlignment.start, | ||||
|                               crossAxisAlignment: CrossAxisAlignment.start, | ||||
|                               children: [ | ||||
|                                 Column( | ||||
|                                   mainAxisAlignment: MainAxisAlignment.start, | ||||
|                                   crossAxisAlignment: CrossAxisAlignment.start, | ||||
| 
 | ||||
|                                   children: [ | ||||
|                                     Text('name :',style: labelTextStyle()), | ||||
|                                     Text('phone :',style: labelTextStyle()), | ||||
|                                     Text('alternativeContactNumber :',style: labelTextStyle()), | ||||
|                                     Text('address :',style: labelTextStyle()), | ||||
|                                   ], | ||||
|                                 ), | ||||
|                                 SizedBox(width: 5,), | ||||
|                                 Column( | ||||
|                                   mainAxisAlignment: MainAxisAlignment.start, | ||||
|                                   crossAxisAlignment: CrossAxisAlignment.start, | ||||
|                                   children: [ | ||||
|                                     Text(modeldeliveryboyList[index].deliveryboy_name,style: valuesTextStyle()), | ||||
|                                     Text(modeldeliveryboyList[index].deliveryboy_phone,style: valuesTextStyle()), | ||||
|                                     Text(modeldeliveryboyList[index].deliveryboy_alternativeContactNumber,style: valuesTextStyle()), | ||||
|                                     Text(modeldeliveryboyList[index].deliveryboy_address,style: valuesTextStyle(), | ||||
|                                       overflow: TextOverflow.ellipsis, | ||||
|                                       maxLines: 1), | ||||
| 
 | ||||
|                                   ], | ||||
|                                 ), | ||||
|                               ], | ||||
|                             ), | ||||
| 
 | ||||
| 
 | ||||
|                           ), | ||||
| 
 | ||||
| 
 | ||||
|                           Expanded(child:IconButton( | ||||
|                             icon: const Icon(Icons.edit,color: primaryColor,), | ||||
|                             onPressed: () { | ||||
|                              // showTankerUpdateDialog(modeldeliveryboyList[index]); | ||||
|                             }, | ||||
|                           ),), | ||||
|                           Expanded(child:IconButton( | ||||
|                             icon: const Icon(Icons.delete,color: primaryColor,), | ||||
| 
 | ||||
|                             onPressed: () async{ | ||||
|                              /* showDialog( | ||||
|                                 //if set to true allow to close popup by tapping out of the popup | ||||
|                                 //barrierDismissible: false, | ||||
|                                 context: context, | ||||
|                                 builder: (BuildContext context) => AlertDialog( | ||||
|                                   title: const Text('Do you want to delete tank?', | ||||
|                                       style: TextStyle( | ||||
|                                         color: primaryColor, | ||||
|                                         fontSize: 20, | ||||
|                                       )), | ||||
|                                   actionsAlignment: MainAxisAlignment.spaceBetween, | ||||
|                                   actions: [ | ||||
|                                     TextButton( | ||||
|                                       onPressed: ()async { | ||||
|                                        bool deleteTankStatus = await AppSettings.deleteTanker(modelTanksViewList[index].tanker_name); | ||||
| 
 | ||||
| 
 | ||||
|                                         if(deleteTankStatus){ | ||||
|                                           readJson(); | ||||
|                                           AppSettings.longSuccessToast('tank deleted successfully'); | ||||
|                                           Navigator.of(context).pop(true); | ||||
| 
 | ||||
|                                         } | ||||
|                                         else{ | ||||
|                                           AppSettings.longFailedToast('tank deletion failed'); | ||||
|                                         } | ||||
|                                       }, | ||||
|                                       child: const Text('Yes', | ||||
|                                           style: TextStyle( | ||||
|                                             color: primaryColor, | ||||
|                                             fontSize: 20, | ||||
|                                           )), | ||||
|                                     ), | ||||
|                                     TextButton( | ||||
|                                       onPressed: () { | ||||
|                                         Navigator.of(context).pop(true); | ||||
|                                       }, | ||||
|                                       child: const Text('No', | ||||
|                                           style: TextStyle( | ||||
|                                             color: primaryColor, | ||||
|                                             fontSize: 20, | ||||
|                                           )), | ||||
|                                     ), | ||||
|                                   ], | ||||
|                                 ), | ||||
|                               ); | ||||
| 
 | ||||
| */ | ||||
| 
 | ||||
|                             }, | ||||
|                           ),) | ||||
| 
 | ||||
|                         ], | ||||
| 
 | ||||
|                       ), | ||||
|                     ), | ||||
|                   ); | ||||
|                 }) ), | ||||
|             Padding( | ||||
|               padding: EdgeInsets.fromLTRB(8, 8, 8, 8), | ||||
|               child: CircleAvatar( | ||||
|                 backgroundColor: primaryColor, | ||||
|                 radius: 40, | ||||
|                 child: Column( | ||||
|                   mainAxisSize: MainAxisSize.min, | ||||
|                   children: <Widget>[ | ||||
|                     IconButton( | ||||
|                       iconSize: 40, | ||||
|                       icon: const Icon( | ||||
|                         Icons.add, | ||||
|                         color: Colors.white, | ||||
|                       ), | ||||
|                       onPressed: () async{ | ||||
|                         Navigator.pop(context); | ||||
|                         await Navigator.push( | ||||
|                           context, | ||||
|                           MaterialPageRoute( | ||||
|                               builder: (context) => Deliverboy()), | ||||
|                         ); | ||||
|                         //showBoreAddingDialog(); | ||||
|                       }, | ||||
|                     ), | ||||
|                    /* Padding( | ||||
|                       padding: EdgeInsets.fromLTRB(5, 0, 5, 5), | ||||
|                       child: Text( | ||||
|                         'Add Tanks ', | ||||
|                         style: TextStyle(color: Colors.white), | ||||
|                       ), | ||||
|                     )*/ | ||||
|                   ], | ||||
|                 ), | ||||
|               ), | ||||
|             ), | ||||
|           ]); | ||||
|     } | ||||
|     else{ | ||||
|       return  Center( | ||||
|           child: Padding( | ||||
|             padding: EdgeInsets.fromLTRB(0, 40, 0, 0), | ||||
|             child: Column( | ||||
|               crossAxisAlignment: CrossAxisAlignment.center, | ||||
|               children: [ | ||||
|                 SizedBox(height: MediaQuery.of(context).size.height * .25,), | ||||
|                 Text('Click below icon to add new Deliveryboy'), | ||||
|                 SizedBox( | ||||
|                   height: 20, | ||||
|                 ), | ||||
|                 CircleAvatar( | ||||
|                   backgroundColor: primaryColor, | ||||
|                   radius: 40, | ||||
|                   child: IconButton( | ||||
|                     iconSize: 40, | ||||
|                     icon: const Icon( | ||||
|                       Icons.add, | ||||
|                       color: Colors.white, | ||||
|                     ), | ||||
|                     onPressed: () async { | ||||
|                       Navigator.pop(context); | ||||
|                       await Navigator.push( | ||||
|                         context, | ||||
|                         MaterialPageRoute( | ||||
|                             builder: (context) => Deliverboy()), | ||||
|                       ); | ||||
|                     }, | ||||
|                   ), | ||||
|                 ) | ||||
|               ], | ||||
|             ), | ||||
|           ) | ||||
|       ); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return SafeArea( | ||||
|         child: Scaffold( | ||||
|           appBar: AppSettings.appBar('Deliveryboy'), | ||||
|           body: isLoading?Center( | ||||
|             child: CircularProgressIndicator( | ||||
|               color: primaryColor, | ||||
|               strokeWidth: 5.0, | ||||
|             ), | ||||
|           ):renderzUi(), | ||||
|         )); | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,26 @@ | ||||
| import 'package:flutter/material.dart'; | ||||
| 
 | ||||
| 
 | ||||
| class GetDeliveryboyDetailsModel { | ||||
|   String deliveryboy_name = ''; | ||||
|   String deliveryboy_phone = ''; | ||||
|   String deliveryboy_alternativeContactNumber = ''; | ||||
|   String deliveryboy_address=''; | ||||
| 
 | ||||
|   Color cardColor=Colors.white; | ||||
| 
 | ||||
|   GetDeliveryboyDetailsModel(); | ||||
| 
 | ||||
|   factory GetDeliveryboyDetailsModel.fromJson(Map<String, dynamic> json){ | ||||
|     GetDeliveryboyDetailsModel rtvm = new GetDeliveryboyDetailsModel(); | ||||
| 
 | ||||
|     rtvm.deliveryboy_name = json['name'] ?? ''; | ||||
|     rtvm.deliveryboy_phone = json['phone'] ?? ''; | ||||
|     rtvm.deliveryboy_alternativeContactNumber = json['alternativeContactNumber'] ?? ''; | ||||
|     rtvm.deliveryboy_address = json['address'] ??''; | ||||
| 
 | ||||
| 
 | ||||
|     return rtvm; | ||||
|   } | ||||
| 
 | ||||
| } | ||||
					Loading…
					
					
				
		Reference in new issue