build_app
This commit is contained in:
		
							parent
							
								
									922f6f3671
								
							
						
					
					
						commit
						88e339f51c
					
				
							
								
								
									
										6
									
								
								testflutter102-dbtdt-d/authsec_mysql/mysql/wf_table/wf_table.sql
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										6
									
								
								testflutter102-dbtdt-d/authsec_mysql/mysql/wf_table/wf_table.sql
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,6 @@ | ||||
| CREATE TABLE dbtdt.Adv3(id BIGINT NOT NULL AUTO_INCREMENT, datagrid_field2 VARCHAR(400), country VARCHAR(400), dymlt2 VARCHAR(400), dymlti1 VARCHAR(400), stmlit VARCHAR(400), stmmlt2 VARCHAR(400), state VARCHAR(400), datagrid_field VARCHAR(400), dy2 int, dy1 int,  PRIMARY KEY (id)); | ||||
| 
 | ||||
| CREATE TABLE dbtdt.Support(id BIGINT NOT NULL AUTO_INCREMENT, description VARCHAR(400), name VARCHAR(400),  PRIMARY KEY (id)); | ||||
| 
 | ||||
| CREATE TABLE dbtdt.Country(id BIGINT NOT NULL AUTO_INCREMENT, active VARCHAR(400), description VARCHAR(400), name VARCHAR(400),  PRIMARY KEY (id)); | ||||
| 
 | ||||
| @ -0,0 +1,112 @@ | ||||
| import 'dart:typed_data'; | ||||
| import 'package:dio/dio.dart'; | ||||
| import 'package:http_parser/http_parser.dart'; | ||||
| import '../../../../resources/api_constants.dart'; | ||||
| import '../../../../data/network/base_network_service.dart'; | ||||
| import '../../../../data/network/network_api_service.dart'; | ||||
| 
 | ||||
| class Adv3ApiService { | ||||
|   final String baseUrl = ApiConstants.baseUrl; | ||||
| 
 | ||||
|       final BaseNetworkService _helper = NetworkApiService(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|    Future<List<Map<String, dynamic>>> getEntities() async { | ||||
| 
 | ||||
|     try { | ||||
|       final response = await _helper.getGetApiResponse('$baseUrl/Adv3/Adv3'); | ||||
|       final entities = (response as List).cast<Map<String, dynamic>>(); | ||||
|       return entities; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all entities: $e'); | ||||
|     } | ||||
|   } | ||||
| Future<List<Map<String, dynamic>>> getAllWithPagination( | ||||
|        int page, int size) async { | ||||
|     try { | ||||
|             final response = | ||||
|           await _helper.getGetApiResponse('$baseUrl/Adv3/Adv3/getall/page?page=$page&size=$size'); | ||||
|       final entities = | ||||
|           (response['content'] as List).cast<Map<String, dynamic>>(); | ||||
|       return entities; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all without pagination: $e'); | ||||
|     } | ||||
|   } | ||||
|   Future<Map<String, dynamic>> createEntity( | ||||
|        Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|             print("in post api$entity"); | ||||
|       final response = | ||||
|           await _helper.getPostApiResponse('$baseUrl/Adv3/Adv3', entity); | ||||
| 
 | ||||
|       print(entity); | ||||
| 
 | ||||
|       // Assuming the response is a Map<String, dynamic> | ||||
|       Map<String, dynamic> responseData = response; | ||||
| 
 | ||||
|       return responseData; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to create entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   Future<void> updateEntity( int entityId, Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|      await _helper.getPutApiResponse('$baseUrl/Adv3/Adv3/$entityId', | ||||
|       entity);                print(entity); | ||||
| 
 | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to update entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<void> deleteEntity( int entityId) async { | ||||
|     try { | ||||
|  await _helper.getDeleteApiResponse('$baseUrl/Adv3/Adv3/$entityId'); | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to delete entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,96 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'dart:convert'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:file_picker/file_picker.dart'; | ||||
| import 'package:image_picker/image_picker.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../Adv3_viewModel/Adv3_view_model_screen.dart'; | ||||
| import 'Adv3_fields.dart';import 'package:base_project/BuilderField/shared/ui/entity_screens.dart'; | ||||
| import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import '../../../../widgets/custom_button.dart'; | ||||
| import '../../../../widgets/custom_text_form_field.dart';  | ||||
| import '../../../../widgets/custom_dropdown_field.dart'; | ||||
| import 'dart:math'; | ||||
| import 'package:qr_flutter/qr_flutter.dart'; | ||||
| import 'package:barcode_widget/barcode_widget.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
|   | ||||
| import 'package:autocomplete_textfield/autocomplete_textfield.dart'; | ||||
| import 'package:http/http.dart' as http; | ||||
| import 'package:flutter/services.dart'; | ||||
| import 'package:image_picker/image_picker.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| import '../../../../Reuseable/reusable_date_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_time_picker_field.dart' | ||||
| ;import 'package:multi_select_flutter/multi_select_flutter.dart'; | ||||
| import 'package:just_audio/just_audio.dart'; | ||||
| import 'package:video_player/video_player.dart'; | ||||
| import 'package:google_fonts/google_fonts.dart'; | ||||
| import 'package:lottie/lottie.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import 'dart:io'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import '../../../../Reuseable/reusable_dropdown_field.dart'; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| class Adv3CreateEntityScreen extends StatefulWidget { | ||||
|   const Adv3CreateEntityScreen({super.key}); | ||||
| 
 | ||||
|   @override | ||||
|   _Adv3CreateEntityScreenState createState() => _Adv3CreateEntityScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _Adv3CreateEntityScreenState extends State<Adv3CreateEntityScreen> { | ||||
| 
 | ||||
| final Map<String, dynamic> formData = {}; | ||||
|   final _formKey = GlobalKey<FormState>(); | ||||
|    | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<Adv3ViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityCreateScreen( | ||||
|           fields: Adv3Fields.getFields(context), | ||||
|           onSubmit: (data) => _handleSubmit(data), | ||||
|           title: 'Adv3', | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   Future<void> _handleSubmit(Map<String, dynamic> formData) async { | ||||
|     final provider = | ||||
|         Provider.of<Adv3ViewModelScreen>(context, listen: false); | ||||
|     final success = await provider.createEntity(formData); | ||||
| 
 | ||||
|     if (success && mounted) { | ||||
|       Navigator.pop(context); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,104 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../../../../BuilderField/shared/ui/entity_details.dart'; | ||||
| import '../Adv3_viewModel/Adv3_view_model_screen.dart'; | ||||
| import 'Adv3_update_entity_screen.dart'; | ||||
| 
 | ||||
| class Adv3DetailsScreen extends StatefulWidget { | ||||
|   final Map<String, dynamic> entity; | ||||
| 
 | ||||
|   const Adv3DetailsScreen({ | ||||
|     super.key, | ||||
|     required this.entity, | ||||
|   }); | ||||
| 
 | ||||
|   @override | ||||
|   State<Adv3DetailsScreen> createState() => _Adv3DetailsScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _Adv3DetailsScreenState extends State<Adv3DetailsScreen> { | ||||
|   void _navigateToUpdateScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => Adv3ViewModelScreen(), | ||||
|           child: Adv3UpdateEntityScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       // Refresh the details screen with updated data | ||||
|       setState(() {}); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _showDeleteDialog(Map<String, dynamic> entity) { | ||||
|     showDialog( | ||||
|       context: context, | ||||
|       builder: (BuildContext context) { | ||||
|         return AlertDialog( | ||||
|           title: const Text('Confirm Deletion'), | ||||
|           content: const Text('Are you sure you want to delete this Adv3?'), | ||||
|           actions: [ | ||||
|             TextButton( | ||||
|               child: const Text('Cancel'), | ||||
|               onPressed: () { | ||||
|                 Navigator.of(context).pop(); | ||||
|               }, | ||||
|             ), | ||||
|             TextButton( | ||||
|               child: const Text('Delete'), | ||||
|               onPressed: () async { | ||||
|                 Navigator.of(context).pop(); | ||||
|                 final vm = | ||||
|                     Provider.of<Adv3ViewModelScreen>(context, listen: false); | ||||
|                 final success = await vm.deleteEntity(entity['id']); | ||||
|                 if (success && mounted) { | ||||
|                   Navigator.pop(context); // Go back to list | ||||
|                 } | ||||
|               }, | ||||
|             ), | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<Adv3ViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityDetails( | ||||
|           entity: widget.entity, | ||||
|           onEdit: (entity) => _navigateToUpdateScreen(entity), | ||||
|           onDelete: (entity) => _showDeleteDialog(entity), | ||||
|           title: 'Adv3', | ||||
|           displayFields: [ | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   {'key': 'country', 'label': 'country', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'state', 'label': 'state', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'stmlit', 'label': 'stmlit', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'stmmlt2', 'label': 'stmmlt2', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'dy2', 'label': 'dy2', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'dy1', 'label': 'dy1', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'dymlti1', 'label': 'dymlti1', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'dymlt2', 'label': 'dymlt2', 'type': 'select'}, | ||||
| 
 | ||||
|           ], | ||||
|           isLoading: viewModel.isLoading, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,164 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
| import 'package:base_project/BuilderField/shared/ui/entity_list.dart'; | ||||
| import 'Adv3_create_entity_screen.dart'; | ||||
| import 'Adv3_update_entity_screen.dart'; | ||||
| import '../Adv3_viewModel/Adv3_view_model_screen.dart'; | ||||
| import 'Adv3_details_screen.dart';import 'package:flutter/services.dart'; | ||||
| import 'package:speech_to_text/speech_to_text.dart' as stt; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../widgets/custom_icon_button.dart'; | ||||
| import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import '../../../../theme/app_decoration.dart'; | ||||
| import 'package:multi_select_flutter/multi_select_flutter.dart'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| 
 | ||||
| class Adv3_entity_list_screen extends StatefulWidget { | ||||
|   static const String routeName = '/entity-list'; | ||||
| 
 | ||||
|   @override | ||||
|   _Adv3_entity_list_screenState createState() => _Adv3_entity_list_screenState(); | ||||
| } | ||||
| 
 | ||||
| class _Adv3_entity_list_screenState extends State<Adv3_entity_list_screen> { | ||||
|   @override | ||||
|   void initState() { | ||||
|     super.initState(); | ||||
|     _loadData(); | ||||
|   } | ||||
| 
 | ||||
|   void _loadData() { | ||||
|     WidgetsBinding.instance.addPostFrameCallback((_) { | ||||
|       if (mounted) { | ||||
|         final vm = Provider.of<Adv3ViewModelScreen>(context, listen: false); | ||||
|         vm.getAllWithPagination(refresh: true); | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToCreateScreen() { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => Adv3ViewModelScreen(), | ||||
|           child: const Adv3CreateEntityScreen(), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       final vm = Provider.of<Adv3ViewModelScreen>(context, listen: false); | ||||
|       vm.refreshData(); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToUpdateScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => Adv3ViewModelScreen(), | ||||
|           child: Adv3UpdateEntityScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       final vm = Provider.of<Adv3ViewModelScreen>(context, listen: false); | ||||
|       vm.refreshData(); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToDetailsScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => Adv3ViewModelScreen(), | ||||
|           child: Adv3DetailsScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   void _showDeleteDialog(Map<String, dynamic> entity) { | ||||
|  final parentContext = context;  | ||||
|     showDialog( | ||||
|       context: context, | ||||
|       builder: (BuildContext context) { | ||||
|         return AlertDialog( | ||||
|           title: const Text('Confirm Deletion'), | ||||
|           content: const Text('Are you sure you want to delete this Adv3?'), | ||||
|           actions: [ | ||||
|             TextButton( | ||||
|               child: const Text('Cancel'), | ||||
|               onPressed: () { | ||||
|                 Navigator.of(context).pop(); | ||||
|               }, | ||||
|             ), | ||||
|             TextButton( | ||||
|               child: const Text('Delete'), | ||||
|               onPressed: () async { | ||||
|                 Navigator.of(context).pop(); | ||||
|                 final vm = | ||||
|                     Provider.of<Adv3ViewModelScreen>(parentContext, listen: false); | ||||
|                 await vm.deleteEntity(entity['id']); | ||||
|               }, | ||||
|             ), | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<Adv3ViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityList( | ||||
|           entities: viewModel.filteredList, | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|           hasMoreData: viewModel.hasMoreData, | ||||
|           searchQuery: viewModel.searchQuery, | ||||
|           onSearchChanged: (query) => viewModel.searchadv3(query), | ||||
|           onEdit: (entity) => _navigateToUpdateScreen(entity), | ||||
|           onDelete: (entity) => _showDeleteDialog(entity), | ||||
|           onTap: (entity) => _navigateToDetailsScreen(entity), | ||||
|           onRefresh: () => viewModel.refreshData(), | ||||
|           onLoadMore: () => viewModel.getAllWithPagination(), | ||||
|           title: 'Adv3', | ||||
|           onAddNew: _navigateToCreateScreen, | ||||
|           displayFields: [ | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   {'key': 'country', 'label': 'country', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'state', 'label': 'state', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'stmlit', 'label': 'stmlit', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'stmmlt2', 'label': 'stmmlt2', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'dy2', 'label': 'dy2', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'dy1', 'label': 'dy1', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'dymlti1', 'label': 'dymlti1', 'type': 'select'}, | ||||
| 
 | ||||
|   {'key': 'dymlt2', 'label': 'dymlt2', 'type': 'select'}, | ||||
| 
 | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,228 @@ | ||||
| import 'package:base_project/BuilderField/shared/fields/number_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/password_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/phone_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/custom_text_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/base_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/date_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/datetime_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/email_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/url_field.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/custom_text_field.dart' as shared_text; | ||||
| import '../../../../BuilderField/shared/fields/one_to_one_relation_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/calculated_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/one_to_many_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/value_list_picker_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/captcha_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/switch_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/url_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/audio_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/checkbox_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/file_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/image_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/radio_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/video_upload_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/autocomplete_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/autocomplete_multiselect_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/one_to_one_relation_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/data_grid_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dynamic_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dynamic_multiselect_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/static_multiselect_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/currency_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/field_group_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/qr_code_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/barcode_field.dart'; | ||||
| import '../Adv3_viewModel/Adv3_view_model_screen.dart';/// Field definitions for Adv3 entity | ||||
| /// This defines the structure and validation for Adv3 forms | ||||
| class Adv3Fields { | ||||
|   /// Get field definitions for Adv3 entity | ||||
|   static List<BaseField> getFields(BuildContext context) { | ||||
|     final viewModel = | ||||
|         Provider.of<Adv3ViewModelScreen>(context, listen: false); | ||||
|     return [ | ||||
|       // Basic Information | ||||
|   DataGridField( | ||||
|         fieldKey: 'datagrid_field', | ||||
|         label: 'datagrid Field', | ||||
|         dataLoader: () => viewModel.getdatagrid_fieldGrid(), | ||||
|       ), | ||||
| 
 | ||||
|   DataGridField( | ||||
|         fieldKey: 'datagrid_field2', | ||||
|         label: 'datagrid Field2', | ||||
|         dataLoader: () => viewModel.getdatagrid_field2Grid(), | ||||
|       ), | ||||
| 
 | ||||
| DropdownField( | ||||
|         fieldKey: 'country', | ||||
|         label: 'country', | ||||
|         hint: 'Select country', | ||||
|         options: const [ | ||||
| 
 | ||||
|   | ||||
|           {'id': 'bharat', 'name': 'bharat'}, | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
|   | ||||
|           {'id': 'nepal', 'name': 'nepal'}, | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
|   | ||||
|           {'id': 'bhutan', 'name': 'bhutan'}, | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
|          | ||||
|         ], | ||||
|         valueKey: 'id', | ||||
|         displayKey: 'name', | ||||
|       ), | ||||
| 
 | ||||
| DropdownField( | ||||
|         fieldKey: 'state', | ||||
|         label: 'state', | ||||
|         hint: 'Select state', | ||||
|         options: const [ | ||||
| 
 | ||||
|   | ||||
|           {'id': 'maharastra', 'name': 'maharastra'}, | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
|   | ||||
|           {'id': 'bihar', 'name': 'bihar'}, | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
|   | ||||
|           {'id': 'test', 'name': 'test'}, | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
|          | ||||
|         ], | ||||
|         valueKey: 'id', | ||||
|         displayKey: 'name', | ||||
|       ), | ||||
| 
 | ||||
|  StaticMultiSelectField( | ||||
|         fieldKey: 'stmlit', | ||||
|         label: 'Select stmlit', | ||||
|         options: const [ | ||||
| 
 | ||||
|   | ||||
| 'bihar', | ||||
|      | ||||
| 
 | ||||
|   | ||||
| 'sikkim', | ||||
|      | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| ], | ||||
|       ), | ||||
| 
 | ||||
| 
 | ||||
|  StaticMultiSelectField( | ||||
|         fieldKey: 'stmmlt2', | ||||
|         label: 'Select stmmlt2', | ||||
|         options: const [ | ||||
| 
 | ||||
|   | ||||
| 'p2', | ||||
|      | ||||
| 
 | ||||
|   | ||||
| 'p3', | ||||
|      | ||||
| 
 | ||||
|   | ||||
| 'ap', | ||||
|      | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| ], | ||||
|       ), | ||||
| 
 | ||||
| 
 | ||||
|  DynamicDropdownField( | ||||
|         fieldKey: 'dy2', | ||||
|         label: 'Select dy2', | ||||
|          hint: 'Search and select', | ||||
|         optionsLoader: () => viewModel.getdy2(), | ||||
| 
 | ||||
|   | ||||
|         valueKey: 'id', | ||||
|         displayKey: 'name', | ||||
|   | ||||
| 
 | ||||
|       ), | ||||
| 
 | ||||
| 
 | ||||
|  DynamicDropdownField( | ||||
|         fieldKey: 'dy1', | ||||
|         label: 'Select dy1', | ||||
|          hint: 'Search and select', | ||||
|         optionsLoader: () => viewModel.getdy1(), | ||||
| 
 | ||||
|   | ||||
|         valueKey: 'id', | ||||
|         displayKey: 'description', | ||||
|   | ||||
| 
 | ||||
|       ), | ||||
| 
 | ||||
| 
 | ||||
|  DynamicMultiSelectDropdownField( | ||||
|         fieldKey: 'dymlti1', | ||||
|         label: 'dymlti1', | ||||
|         hint: 'Type to search and press enter', | ||||
|         optionsLoader: () async { | ||||
|           final list = await viewModel.getdymlti1(); | ||||
|           return list | ||||
| 
 | ||||
|   | ||||
|               .map((e) => e['name']?.toString() ?? '') | ||||
|               .where((e) => e.isNotEmpty) | ||||
|               .toList(); | ||||
|   | ||||
| 
 | ||||
|         }, | ||||
|       ), | ||||
| 
 | ||||
| 
 | ||||
|  DynamicMultiSelectDropdownField( | ||||
|         fieldKey: 'dymlt2', | ||||
|         label: 'dymlt2', | ||||
|         hint: 'Type to search and press enter', | ||||
|         optionsLoader: () async { | ||||
|           final list = await viewModel.getdymlt2(); | ||||
|           return list | ||||
| 
 | ||||
|   | ||||
|               .map((e) => e['description']?.toString() ?? '') | ||||
|               .where((e) => e.isNotEmpty) | ||||
|               .toList(); | ||||
|   | ||||
| 
 | ||||
|         }, | ||||
|       ), | ||||
| 
 | ||||
| 
 | ||||
|     ]; | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,91 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'dart:convert'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../Adv3_viewModel/Adv3_view_model_screen.dart'; | ||||
| import 'package:base_project/BuilderField/shared/ui/entity_screens.dart'; | ||||
| import 'Adv3_fields.dart';import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import 'package:barcode_widget/barcode_widget.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| import '../../../../widgets/custom_button.dart'; | ||||
| import '../../../../widgets/custom_text_form_field.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:autocomplete_textfield/autocomplete_textfield.dart'; | ||||
| import 'package:qr_flutter/qr_flutter.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
| 
 | ||||
| import 'dart:math'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_time_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_dropdown_field.dart'; | ||||
| import 'package:flutter/services.dart'; | ||||
| class Adv3UpdateEntityScreen extends StatefulWidget { | ||||
|     final Map<String, dynamic> entity; | ||||
| 
 | ||||
| 
 | ||||
|   Adv3UpdateEntityScreen({required this.entity}); | ||||
| 
 | ||||
|   @override | ||||
|   _Adv3UpdateEntityScreenState createState() => _Adv3UpdateEntityScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _Adv3UpdateEntityScreenState extends State<Adv3UpdateEntityScreen> { | ||||
|   final _formKey = GlobalKey<FormState>(); | ||||
| 
 | ||||
| @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<Adv3ViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
| // Start with all fields, then remove upload fields (generic filter by keys) | ||||
|         final Set<String> hiddenKeys = {  | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  }; | ||||
|         final fields = Adv3Fields.getFields(context) | ||||
|             .where((f) => !hiddenKeys.contains(f.fieldKey)) | ||||
|             .toList();        return EntityUpdateScreen( | ||||
|           fields: fields, | ||||
|           initialData: widget.entity, | ||||
|           onSubmit: (data) => _handleSubmit(data), | ||||
|           title: 'Adv3', | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   Future<void> _handleSubmit(Map<String, dynamic> formData) async { | ||||
|     final provider = | ||||
|         Provider.of<Adv3ViewModelScreen>(context, listen: false); | ||||
|     final success = await provider.updateEntity(widget.entity['id'], formData); | ||||
| 
 | ||||
|     if (success && mounted) { | ||||
|       Navigator.pop(context); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,157 @@ | ||||
| import 'package:dio/dio.dart'; | ||||
| import '../../../../data/network/base_network_service.dart'; | ||||
| import '../../../../data/network/network_api_service.dart'; | ||||
| import '../../../../resources/api_constants.dart'; | ||||
| import 'package:base_project/data/response/api_response.dart'; | ||||
| 
 | ||||
| class Adv3RepoScreen { | ||||
| 
 | ||||
|   final String baseUrl = ApiConstants.baseUrl; | ||||
|   final BaseNetworkService _helper = NetworkApiService(); | ||||
|   final String _endpointPath = '/Adv3/Adv3'; | ||||
| 
 | ||||
|   Future<ApiResponse<List<Map<String, dynamic>>>> getEntities() async { | ||||
|     try { | ||||
|       final response = | ||||
|           await _helper.getGetApiResponse('$baseUrl$_endpointPath'); | ||||
|       print('Response received: $response'); | ||||
|       List<Map<String, dynamic>> entities = const []; | ||||
|       if (response is List) { | ||||
|         entities = response | ||||
|             .whereType<Map>() | ||||
|             .map((e) => Map<String, dynamic>.from(e as Map)) | ||||
|             .toList(); | ||||
|       } else if (response is Map<String, dynamic>) { | ||||
|         final dynamic content = response['content']; | ||||
|         if (content is List) { | ||||
|           entities = content | ||||
|               .whereType<Map>() | ||||
|               .map((e) => Map<String, dynamic>.from(e as Map)) | ||||
|               .toList(); | ||||
|         } | ||||
|       } | ||||
|       return ApiResponse.success(entities); | ||||
|     } catch (e) { | ||||
|       print(' error got $e'); | ||||
|       return ApiResponse.error('Failed to get all entities: $e'); | ||||
|     } | ||||
|   }  | ||||
| 
 | ||||
|   Future<ApiResponse<List<Map<String, dynamic>>>> getAllWithPagination( | ||||
|       int page, int size) async { | ||||
|     try { | ||||
|       final response = await _helper.getGetApiResponse( | ||||
|           '$baseUrl$_endpointPath/getall/page?page=$page&size=$size'); | ||||
| 
 | ||||
|       if (response is Map<String, dynamic> && response['content'] is List) { | ||||
|         final List<Map<String, dynamic>> entities = | ||||
|             (response['content'] as List).cast<Map<String, dynamic>>().toList(); | ||||
|         return ApiResponse.success(entities); | ||||
|       } else { | ||||
|         return ApiResponse.error('Invalid response format'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to get all without pagination: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<Map<String, dynamic>>> createEntity( | ||||
|       Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|       print("in post api$entity"); | ||||
|       final response = | ||||
|           await _helper.getPostApiResponse('$baseUrl$_endpointPath', entity); | ||||
|       return ApiResponse.success(response as Map<String, dynamic>); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to create entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<Map<String, dynamic>>> updateEntity( | ||||
|       int entityId, Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|       final response = await _helper.getPutApiResponse( | ||||
|           '$baseUrl$_endpointPath/$entityId', entity); | ||||
|       return ApiResponse.success(response as Map<String, dynamic>); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to update entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<void>> deleteEntity(int entityId) async { | ||||
|     try { | ||||
|       await _helper.getDeleteApiResponse('$baseUrl$_endpointPath/$entityId'); | ||||
|       return ApiResponse.success(null); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to delete entity: $e'); | ||||
|     } | ||||
|   } | ||||
|  Future<dynamic> getdatagrid_fieldGrid() async { | ||||
|     try { | ||||
|       String apiUrl = "$baseUrl/Country_ListFilter1/Country_ListFilter1"; | ||||
|       final response = await _helper.getGetApiResponse(apiUrl); | ||||
|       return response; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to Upload datagrid Field: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|  Future<dynamic> getdatagrid_field2Grid() async { | ||||
|     try { | ||||
|       String apiUrl = "$baseUrl/Country_ListFilter1/Country_ListFilter1"; | ||||
|       final response = await _helper.getGetApiResponse(apiUrl); | ||||
|       return response; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to Upload datagrid Field2: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  Future<dynamic> getdy2() async { | ||||
|     try { | ||||
|       String apiUrl = "$baseUrl/Country_ListFilter1/Country_ListFilter1"; | ||||
|       final response = await _helper.getGetApiResponse(apiUrl); | ||||
|       return response; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to Get: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|  Future<dynamic> getdy1() async { | ||||
|     try { | ||||
|       String apiUrl = "$baseUrl/Country_ListFilter1/Country_ListFilter1"; | ||||
|       final response = await _helper.getGetApiResponse(apiUrl); | ||||
|       return response; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to Get: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|  Future<dynamic> getdymlti1() async { | ||||
|     try { | ||||
|       String apiUrl = "$baseUrl/Country_ListFilter1/Country_ListFilter1"; | ||||
|       final response = await _helper.getGetApiResponse(apiUrl); | ||||
|       return response; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to Get: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|  Future<dynamic> getdymlt2() async { | ||||
|     try { | ||||
|       String apiUrl = "$baseUrl/Country_ListFilter1/Country_ListFilter1"; | ||||
|       final response = await _helper.getGetApiResponse(apiUrl); | ||||
|       return response; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to Get: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,506 @@ | ||||
| import 'package:base_project/data/response/status.dart'; | ||||
| import 'dart:typed_data'; | ||||
| import 'package:dio/dio.dart'; | ||||
| import 'package:http_parser/http_parser.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import '../../../../BuilderField/shared/utils/entity_field_store.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import '../Adv3_Repo/Adv3_repo_screen.dart'; | ||||
| 
 | ||||
| class Adv3ViewModelScreen extends ChangeNotifier{ | ||||
|   final Adv3RepoScreen repo = Adv3RepoScreen(); | ||||
| 
 | ||||
|   | ||||
|   // State variables | ||||
|   List<Map<String, dynamic>> _adv3List = []; | ||||
|   List<Map<String, dynamic>> _filteredList = []; | ||||
|   bool _isLoading = false; | ||||
|   String _errorMessage = ''; | ||||
|   int _currentPage = 0; | ||||
|   int _pageSize = 10; | ||||
|   bool _hasMoreData = true; | ||||
|   String _searchQuery = ''; | ||||
| 
 | ||||
|   // Getters | ||||
|   List<Map<String, dynamic>> get adv3List => _adv3List; | ||||
|   List<Map<String, dynamic>> get filteredList => _filteredList; | ||||
|   bool get isLoading => _isLoading; | ||||
|   String get errorMessage => _errorMessage; | ||||
|   bool get hasMoreData => _hasMoreData; | ||||
|   String get searchQuery => _searchQuery; | ||||
| 
 | ||||
|   // Set loading state | ||||
|   void _setLoading(bool loading) { | ||||
|     _isLoading = loading; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Set error message | ||||
|   void _setError(String error) { | ||||
|     _errorMessage = error; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Clear error | ||||
|   void clearError() { | ||||
|     _errorMessage = ''; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Get adv3 list | ||||
|   Future<void> getEntities() async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.getEntities(); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         _adv3List = response.data ?? []; | ||||
|         _filteredList = List.from(_adv3List); | ||||
|         _currentPage = 0; | ||||
|         _hasMoreData = true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to fetch adv3 list'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to fetch adv3 list: $e'); | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Get adv3 list with pagination | ||||
|   Future<void> getAllWithPagination({bool refresh = false}) async { | ||||
|     if (refresh) { | ||||
|       _currentPage = 0; | ||||
|       _adv3List.clear(); | ||||
|       _filteredList.clear(); | ||||
|       _hasMoreData = true; | ||||
|     } | ||||
| 
 | ||||
|     if (!_hasMoreData || _isLoading) return; | ||||
| 
 | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.getAllWithPagination(_currentPage, _pageSize); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         final newItems = response.data ?? []; | ||||
| 
 | ||||
|         if (refresh) { | ||||
|           _adv3List = newItems; | ||||
|         } else { | ||||
|           _adv3List.addAll(newItems); | ||||
|         } | ||||
| 
 | ||||
|         _filteredList = List.from(_adv3List); | ||||
|         _currentPage++; | ||||
| 
 | ||||
|         // Check if we have more data | ||||
|         _hasMoreData = newItems.length == _pageSize; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to fetch Adv3 list'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to fetch adv3 list: $e'); | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   // Create Adv3 | ||||
|   Future<bool> createEntity(Map<String, dynamic> entity) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|       final response = await repo.createEntity(entity); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
| // Get the response ID for image upload | ||||
| 
 | ||||
|         final responseId = response.data!['id'].toString(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'adv3 created successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Refresh the list | ||||
|         await getEntities(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to create Adv3'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to create Adv3', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to create adv3: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to create Adv3: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Update adv3 | ||||
|   Future<bool> updateEntity(int id, Map<String, dynamic> entity) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.updateEntity(id, entity); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'Adv3 updated successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Update the item in the list | ||||
|         final index = _adv3List.indexWhere((item) => item['id'] == id); | ||||
|         if (index != -1) { | ||||
|           _adv3List[index] = response.data!; | ||||
|           _filteredList = List.from(_adv3List); | ||||
|           notifyListeners(); | ||||
|         } | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to update Adv3'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to update Adv3', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to update adv3: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to update Adv3: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Delete adv3 | ||||
|   Future<bool> deleteEntity(int id) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.deleteEntity(id); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'Adv3 deleted successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Remove the item from the list | ||||
|         _adv3List.removeWhere((item) => item['id'] == id); | ||||
|         _filteredList = List.from(_adv3List); | ||||
|         notifyListeners(); | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to delete Adv3'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to delete Adv3', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to delete adv3: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to delete Adv3: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Search adv3 | ||||
|   void searchadv3(String query) { | ||||
|     _searchQuery = query; | ||||
| 
 | ||||
|     if (query.isEmpty) { | ||||
|       _filteredList = List.from(_adv3List); | ||||
|     } else { | ||||
|       _filteredList = _adv3List.where((item) { | ||||
|         return | ||||
| 
 | ||||
|               | ||||
| (item['datagrid_field']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['datagrid_field2']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['country']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['state']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['stmlit']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['stmmlt2']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['dy2']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['dy1']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['dymlti1']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['dymlt2']?.toString().toLowerCase().contains(query.toLowerCase()) ??false)  | ||||
| 
 | ||||
| 
 | ||||
| ; | ||||
|       }).toList(); | ||||
|     } | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Clear search | ||||
|   void clearSearch() { | ||||
|     _searchQuery = ''; | ||||
|     _filteredList = List.from(_adv3List); | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Refresh data | ||||
|   Future<void> refreshData() async { | ||||
|     await getAllWithPagination(refresh: true); | ||||
|   } | ||||
|   late List<Map<String, dynamic>> datagrid_fielddataFuture = | ||||
|       []; // Data from fetchData | ||||
| 
 | ||||
|  Future<List<Map<String, dynamic>>>   getdatagrid_fieldGrid() async { | ||||
| 
 | ||||
|       try { | ||||
|      final value = await repo.getdatagrid_fieldGrid(); | ||||
|         datagrid_fielddataFuture =  (value as List) | ||||
|             .map((item) => item as Map<String, dynamic>) | ||||
|             .toList(); | ||||
| 
 | ||||
|    return datagrid_fielddataFuture; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   late List<Map<String, dynamic>> datagrid_field2dataFuture = | ||||
|       []; // Data from fetchData | ||||
| 
 | ||||
|  Future<List<Map<String, dynamic>>>   getdatagrid_field2Grid() async { | ||||
| 
 | ||||
|       try { | ||||
|      final value = await repo.getdatagrid_field2Grid(); | ||||
|         datagrid_field2dataFuture =  (value as List) | ||||
|             .map((item) => item as Map<String, dynamic>) | ||||
|             .toList(); | ||||
| 
 | ||||
|    return datagrid_field2dataFuture; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| List<Map<String, dynamic>> dy2Items = []; | ||||
| 
 | ||||
|  Future<List<Map<String, dynamic>>>   getdy2() async { | ||||
| 
 | ||||
|       try { | ||||
|      final value = await repo.getdy2(); | ||||
|         dy2Items =  (value as List) | ||||
|             .map((item) => item as Map<String, dynamic>) | ||||
|             .toList(); | ||||
| 
 | ||||
|    return dy2Items; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| List<Map<String, dynamic>> dy1Items = []; | ||||
| 
 | ||||
|  Future<List<Map<String, dynamic>>>   getdy1() async { | ||||
| 
 | ||||
|       try { | ||||
|      final value = await repo.getdy1(); | ||||
|         dy1Items =  (value as List) | ||||
|             .map((item) => item as Map<String, dynamic>) | ||||
|             .toList(); | ||||
| 
 | ||||
|    return dy1Items; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| List<Map<String, dynamic>> dymlti1Items = []; | ||||
| 
 | ||||
|  Future<List<Map<String, dynamic>>>   getdymlti1() async { | ||||
| 
 | ||||
|       try { | ||||
|      final value = await repo.getdymlti1(); | ||||
|         dymlti1Items =  (value as List) | ||||
|             .map((item) => item as Map<String, dynamic>) | ||||
|             .toList(); | ||||
| 
 | ||||
|    return dymlti1Items; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| List<Map<String, dynamic>> dymlt2Items = []; | ||||
| 
 | ||||
|  Future<List<Map<String, dynamic>>>   getdymlt2() async { | ||||
| 
 | ||||
|       try { | ||||
|      final value = await repo.getdymlt2(); | ||||
|         dymlt2Items =  (value as List) | ||||
|             .map((item) => item as Map<String, dynamic>) | ||||
|             .toList(); | ||||
| 
 | ||||
|    return dymlt2Items; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,80 @@ | ||||
| import 'dart:typed_data'; | ||||
| import 'package:dio/dio.dart'; | ||||
| import 'package:http_parser/http_parser.dart'; | ||||
| import '../../../../resources/api_constants.dart'; | ||||
| import '../../../../data/network/base_network_service.dart'; | ||||
| import '../../../../data/network/network_api_service.dart'; | ||||
| 
 | ||||
| class SupportApiService { | ||||
|   final String baseUrl = ApiConstants.baseUrl; | ||||
| 
 | ||||
|       final BaseNetworkService _helper = NetworkApiService(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|    Future<List<Map<String, dynamic>>> getEntities() async { | ||||
| 
 | ||||
|     try { | ||||
|       final response = await _helper.getGetApiResponse('$baseUrl/Support/Support'); | ||||
|       final entities = (response as List).cast<Map<String, dynamic>>(); | ||||
|       return entities; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all entities: $e'); | ||||
|     } | ||||
|   } | ||||
| Future<List<Map<String, dynamic>>> getAllWithPagination( | ||||
|        int page, int size) async { | ||||
|     try { | ||||
|             final response = | ||||
|           await _helper.getGetApiResponse('$baseUrl/Support/Support/getall/page?page=$page&size=$size'); | ||||
|       final entities = | ||||
|           (response['content'] as List).cast<Map<String, dynamic>>(); | ||||
|       return entities; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all without pagination: $e'); | ||||
|     } | ||||
|   } | ||||
|   Future<Map<String, dynamic>> createEntity( | ||||
|        Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|             print("in post api$entity"); | ||||
|       final response = | ||||
|           await _helper.getPostApiResponse('$baseUrl/Support/Support', entity); | ||||
| 
 | ||||
|       print(entity); | ||||
| 
 | ||||
|       // Assuming the response is a Map<String, dynamic> | ||||
|       Map<String, dynamic> responseData = response; | ||||
| 
 | ||||
|       return responseData; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to create entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   Future<void> updateEntity( int entityId, Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|      await _helper.getPutApiResponse('$baseUrl/Support/Support/$entityId', | ||||
|       entity);                print(entity); | ||||
| 
 | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to update entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<void> deleteEntity( int entityId) async { | ||||
|     try { | ||||
|  await _helper.getDeleteApiResponse('$baseUrl/Support/Support/$entityId'); | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to delete entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,80 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'dart:convert'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:file_picker/file_picker.dart'; | ||||
| import 'package:image_picker/image_picker.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../Support_viewModel/Support_view_model_screen.dart'; | ||||
| import 'Support_fields.dart';import 'package:base_project/BuilderField/shared/ui/entity_screens.dart'; | ||||
| import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import '../../../../widgets/custom_button.dart'; | ||||
| import '../../../../widgets/custom_text_form_field.dart';  | ||||
| import '../../../../widgets/custom_dropdown_field.dart'; | ||||
| import 'dart:math'; | ||||
| import 'package:qr_flutter/qr_flutter.dart'; | ||||
| import 'package:barcode_widget/barcode_widget.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
|   | ||||
| import 'package:autocomplete_textfield/autocomplete_textfield.dart'; | ||||
| import 'package:http/http.dart' as http; | ||||
| import 'package:flutter/services.dart'; | ||||
| import 'package:image_picker/image_picker.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| import '../../../../Reuseable/reusable_date_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_time_picker_field.dart' | ||||
| ;import 'package:multi_select_flutter/multi_select_flutter.dart'; | ||||
| import 'package:just_audio/just_audio.dart'; | ||||
| import 'package:video_player/video_player.dart'; | ||||
| import 'package:google_fonts/google_fonts.dart'; | ||||
| import 'package:lottie/lottie.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import 'dart:io'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import '../../../../Reuseable/reusable_dropdown_field.dart'; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| class SupportCreateEntityScreen extends StatefulWidget { | ||||
|   const SupportCreateEntityScreen({super.key}); | ||||
| 
 | ||||
|   @override | ||||
|   _SupportCreateEntityScreenState createState() => _SupportCreateEntityScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _SupportCreateEntityScreenState extends State<SupportCreateEntityScreen> { | ||||
| 
 | ||||
| final Map<String, dynamic> formData = {}; | ||||
|   final _formKey = GlobalKey<FormState>(); | ||||
|    | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<SupportViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityCreateScreen( | ||||
|           fields: SupportFields.getFields(context), | ||||
|           onSubmit: (data) => _handleSubmit(data), | ||||
|           title: 'Support', | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   Future<void> _handleSubmit(Map<String, dynamic> formData) async { | ||||
|     final provider = | ||||
|         Provider.of<SupportViewModelScreen>(context, listen: false); | ||||
|     final success = await provider.createEntity(formData); | ||||
| 
 | ||||
|     if (success && mounted) { | ||||
|       Navigator.pop(context); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,88 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../../../../BuilderField/shared/ui/entity_details.dart'; | ||||
| import '../Support_viewModel/Support_view_model_screen.dart'; | ||||
| import 'Support_update_entity_screen.dart'; | ||||
| 
 | ||||
| class SupportDetailsScreen extends StatefulWidget { | ||||
|   final Map<String, dynamic> entity; | ||||
| 
 | ||||
|   const SupportDetailsScreen({ | ||||
|     super.key, | ||||
|     required this.entity, | ||||
|   }); | ||||
| 
 | ||||
|   @override | ||||
|   State<SupportDetailsScreen> createState() => _SupportDetailsScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _SupportDetailsScreenState extends State<SupportDetailsScreen> { | ||||
|   void _navigateToUpdateScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => SupportViewModelScreen(), | ||||
|           child: SupportUpdateEntityScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       // Refresh the details screen with updated data | ||||
|       setState(() {}); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _showDeleteDialog(Map<String, dynamic> entity) { | ||||
|     showDialog( | ||||
|       context: context, | ||||
|       builder: (BuildContext context) { | ||||
|         return AlertDialog( | ||||
|           title: const Text('Confirm Deletion'), | ||||
|           content: const Text('Are you sure you want to delete this Support?'), | ||||
|           actions: [ | ||||
|             TextButton( | ||||
|               child: const Text('Cancel'), | ||||
|               onPressed: () { | ||||
|                 Navigator.of(context).pop(); | ||||
|               }, | ||||
|             ), | ||||
|             TextButton( | ||||
|               child: const Text('Delete'), | ||||
|               onPressed: () async { | ||||
|                 Navigator.of(context).pop(); | ||||
|                 final vm = | ||||
|                     Provider.of<SupportViewModelScreen>(context, listen: false); | ||||
|                 final success = await vm.deleteEntity(entity['id']); | ||||
|                 if (success && mounted) { | ||||
|                   Navigator.pop(context); // Go back to list | ||||
|                 } | ||||
|               }, | ||||
|             ), | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<SupportViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityDetails( | ||||
|           entity: widget.entity, | ||||
|           onEdit: (entity) => _navigateToUpdateScreen(entity), | ||||
|           onDelete: (entity) => _showDeleteDialog(entity), | ||||
|           title: 'Support', | ||||
|           displayFields: [ | ||||
|   {'key': 'name', 'label': 'Name', 'type': 'text'}, | ||||
| 
 | ||||
|   {'key': 'description', 'label': 'Description', 'type': 'textarea'}, | ||||
| 
 | ||||
|           ], | ||||
|           isLoading: viewModel.isLoading, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,148 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
| import 'package:base_project/BuilderField/shared/ui/entity_list.dart'; | ||||
| import 'Support_create_entity_screen.dart'; | ||||
| import 'Support_update_entity_screen.dart'; | ||||
| import '../Support_viewModel/Support_view_model_screen.dart'; | ||||
| import 'Support_details_screen.dart';import 'package:flutter/services.dart'; | ||||
| import 'package:speech_to_text/speech_to_text.dart' as stt; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../widgets/custom_icon_button.dart'; | ||||
| import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import '../../../../theme/app_decoration.dart'; | ||||
| import 'package:multi_select_flutter/multi_select_flutter.dart'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| 
 | ||||
| class Support_entity_list_screen extends StatefulWidget { | ||||
|   static const String routeName = '/entity-list'; | ||||
| 
 | ||||
|   @override | ||||
|   _Support_entity_list_screenState createState() => _Support_entity_list_screenState(); | ||||
| } | ||||
| 
 | ||||
| class _Support_entity_list_screenState extends State<Support_entity_list_screen> { | ||||
|   @override | ||||
|   void initState() { | ||||
|     super.initState(); | ||||
|     _loadData(); | ||||
|   } | ||||
| 
 | ||||
|   void _loadData() { | ||||
|     WidgetsBinding.instance.addPostFrameCallback((_) { | ||||
|       if (mounted) { | ||||
|         final vm = Provider.of<SupportViewModelScreen>(context, listen: false); | ||||
|         vm.getAllWithPagination(refresh: true); | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToCreateScreen() { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => SupportViewModelScreen(), | ||||
|           child: const SupportCreateEntityScreen(), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       final vm = Provider.of<SupportViewModelScreen>(context, listen: false); | ||||
|       vm.refreshData(); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToUpdateScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => SupportViewModelScreen(), | ||||
|           child: SupportUpdateEntityScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       final vm = Provider.of<SupportViewModelScreen>(context, listen: false); | ||||
|       vm.refreshData(); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToDetailsScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => SupportViewModelScreen(), | ||||
|           child: SupportDetailsScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   void _showDeleteDialog(Map<String, dynamic> entity) { | ||||
|  final parentContext = context;  | ||||
|     showDialog( | ||||
|       context: context, | ||||
|       builder: (BuildContext context) { | ||||
|         return AlertDialog( | ||||
|           title: const Text('Confirm Deletion'), | ||||
|           content: const Text('Are you sure you want to delete this Support?'), | ||||
|           actions: [ | ||||
|             TextButton( | ||||
|               child: const Text('Cancel'), | ||||
|               onPressed: () { | ||||
|                 Navigator.of(context).pop(); | ||||
|               }, | ||||
|             ), | ||||
|             TextButton( | ||||
|               child: const Text('Delete'), | ||||
|               onPressed: () async { | ||||
|                 Navigator.of(context).pop(); | ||||
|                 final vm = | ||||
|                     Provider.of<SupportViewModelScreen>(parentContext, listen: false); | ||||
|                 await vm.deleteEntity(entity['id']); | ||||
|               }, | ||||
|             ), | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<SupportViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityList( | ||||
|           entities: viewModel.filteredList, | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|           hasMoreData: viewModel.hasMoreData, | ||||
|           searchQuery: viewModel.searchQuery, | ||||
|           onSearchChanged: (query) => viewModel.searchsupport(query), | ||||
|           onEdit: (entity) => _navigateToUpdateScreen(entity), | ||||
|           onDelete: (entity) => _showDeleteDialog(entity), | ||||
|           onTap: (entity) => _navigateToDetailsScreen(entity), | ||||
|           onRefresh: () => viewModel.refreshData(), | ||||
|           onLoadMore: () => viewModel.getAllWithPagination(), | ||||
|           title: 'Support', | ||||
|           onAddNew: _navigateToCreateScreen, | ||||
|           displayFields: [ | ||||
|   {'key': 'name', 'label': 'Name', 'type': 'text'}, | ||||
| 
 | ||||
|   {'key': 'description', 'label': 'Description', 'type': 'textarea'}, | ||||
| 
 | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,70 @@ | ||||
| import 'package:base_project/BuilderField/shared/fields/number_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/password_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/phone_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/custom_text_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/base_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/date_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/datetime_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/email_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/url_field.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/custom_text_field.dart' as shared_text; | ||||
| import '../../../../BuilderField/shared/fields/one_to_one_relation_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/calculated_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/one_to_many_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/value_list_picker_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/captcha_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/switch_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/url_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/audio_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/checkbox_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/file_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/image_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/radio_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/video_upload_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/autocomplete_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/autocomplete_multiselect_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/one_to_one_relation_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/data_grid_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dynamic_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dynamic_multiselect_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/static_multiselect_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/currency_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/field_group_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/qr_code_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/barcode_field.dart'; | ||||
| import '../Support_viewModel/Support_view_model_screen.dart';/// Field definitions for Support entity | ||||
| /// This defines the structure and validation for Support forms | ||||
| class SupportFields { | ||||
|   /// Get field definitions for Support entity | ||||
|   static List<BaseField> getFields(BuildContext context) { | ||||
|     final viewModel = | ||||
|         Provider.of<SupportViewModelScreen>(context, listen: false); | ||||
|     return [ | ||||
|       // Basic Information | ||||
|  CustomTextField( | ||||
|         fieldKey: 'name', | ||||
|         label: 'Name', | ||||
|         hint: 'Enter Name', | ||||
|         isRequired: true, | ||||
|         maxLength: 50, | ||||
|       ), | ||||
| 
 | ||||
| CustomTextField( | ||||
|         fieldKey: 'description', | ||||
|         label: 'Description', | ||||
|         hint: 'Enter Description', | ||||
|         isRequired: false, | ||||
|         maxLength: 1000, | ||||
|       ), | ||||
| 
 | ||||
|     ]; | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,75 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'dart:convert'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../Support_viewModel/Support_view_model_screen.dart'; | ||||
| import 'package:base_project/BuilderField/shared/ui/entity_screens.dart'; | ||||
| import 'Support_fields.dart';import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import 'package:barcode_widget/barcode_widget.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| import '../../../../widgets/custom_button.dart'; | ||||
| import '../../../../widgets/custom_text_form_field.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:autocomplete_textfield/autocomplete_textfield.dart'; | ||||
| import 'package:qr_flutter/qr_flutter.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
| 
 | ||||
| import 'dart:math'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_time_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_dropdown_field.dart'; | ||||
| import 'package:flutter/services.dart'; | ||||
| class SupportUpdateEntityScreen extends StatefulWidget { | ||||
|     final Map<String, dynamic> entity; | ||||
| 
 | ||||
| 
 | ||||
|   SupportUpdateEntityScreen({required this.entity}); | ||||
| 
 | ||||
|   @override | ||||
|   _SupportUpdateEntityScreenState createState() => _SupportUpdateEntityScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _SupportUpdateEntityScreenState extends State<SupportUpdateEntityScreen> { | ||||
|   final _formKey = GlobalKey<FormState>(); | ||||
| 
 | ||||
| @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<SupportViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
| // Start with all fields, then remove upload fields (generic filter by keys) | ||||
|         final Set<String> hiddenKeys = {  | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  }; | ||||
|         final fields = SupportFields.getFields(context) | ||||
|             .where((f) => !hiddenKeys.contains(f.fieldKey)) | ||||
|             .toList();        return EntityUpdateScreen( | ||||
|           fields: fields, | ||||
|           initialData: widget.entity, | ||||
|           onSubmit: (data) => _handleSubmit(data), | ||||
|           title: 'Support', | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   Future<void> _handleSubmit(Map<String, dynamic> formData) async { | ||||
|     final provider = | ||||
|         Provider.of<SupportViewModelScreen>(context, listen: false); | ||||
|     final success = await provider.updateEntity(widget.entity['id'], formData); | ||||
| 
 | ||||
|     if (success && mounted) { | ||||
|       Navigator.pop(context); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,93 @@ | ||||
| import 'package:dio/dio.dart'; | ||||
| import '../../../../data/network/base_network_service.dart'; | ||||
| import '../../../../data/network/network_api_service.dart'; | ||||
| import '../../../../resources/api_constants.dart'; | ||||
| import 'package:base_project/data/response/api_response.dart'; | ||||
| 
 | ||||
| class SupportRepoScreen { | ||||
| 
 | ||||
|   final String baseUrl = ApiConstants.baseUrl; | ||||
|   final BaseNetworkService _helper = NetworkApiService(); | ||||
|   final String _endpointPath = '/Support/Support'; | ||||
| 
 | ||||
|   Future<ApiResponse<List<Map<String, dynamic>>>> getEntities() async { | ||||
|     try { | ||||
|       final response = | ||||
|           await _helper.getGetApiResponse('$baseUrl$_endpointPath'); | ||||
|       print('Response received: $response'); | ||||
|       List<Map<String, dynamic>> entities = const []; | ||||
|       if (response is List) { | ||||
|         entities = response | ||||
|             .whereType<Map>() | ||||
|             .map((e) => Map<String, dynamic>.from(e as Map)) | ||||
|             .toList(); | ||||
|       } else if (response is Map<String, dynamic>) { | ||||
|         final dynamic content = response['content']; | ||||
|         if (content is List) { | ||||
|           entities = content | ||||
|               .whereType<Map>() | ||||
|               .map((e) => Map<String, dynamic>.from(e as Map)) | ||||
|               .toList(); | ||||
|         } | ||||
|       } | ||||
|       return ApiResponse.success(entities); | ||||
|     } catch (e) { | ||||
|       print(' error got $e'); | ||||
|       return ApiResponse.error('Failed to get all entities: $e'); | ||||
|     } | ||||
|   }  | ||||
| 
 | ||||
|   Future<ApiResponse<List<Map<String, dynamic>>>> getAllWithPagination( | ||||
|       int page, int size) async { | ||||
|     try { | ||||
|       final response = await _helper.getGetApiResponse( | ||||
|           '$baseUrl$_endpointPath/getall/page?page=$page&size=$size'); | ||||
| 
 | ||||
|       if (response is Map<String, dynamic> && response['content'] is List) { | ||||
|         final List<Map<String, dynamic>> entities = | ||||
|             (response['content'] as List).cast<Map<String, dynamic>>().toList(); | ||||
|         return ApiResponse.success(entities); | ||||
|       } else { | ||||
|         return ApiResponse.error('Invalid response format'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to get all without pagination: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<Map<String, dynamic>>> createEntity( | ||||
|       Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|       print("in post api$entity"); | ||||
|       final response = | ||||
|           await _helper.getPostApiResponse('$baseUrl$_endpointPath', entity); | ||||
|       return ApiResponse.success(response as Map<String, dynamic>); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to create entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<Map<String, dynamic>>> updateEntity( | ||||
|       int entityId, Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|       final response = await _helper.getPutApiResponse( | ||||
|           '$baseUrl$_endpointPath/$entityId', entity); | ||||
|       return ApiResponse.success(response as Map<String, dynamic>); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to update entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<void>> deleteEntity(int entityId) async { | ||||
|     try { | ||||
|       await _helper.getDeleteApiResponse('$baseUrl$_endpointPath/$entityId'); | ||||
|       return ApiResponse.success(null); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to delete entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,292 @@ | ||||
| import 'package:base_project/data/response/status.dart'; | ||||
| import 'dart:typed_data'; | ||||
| import 'package:dio/dio.dart'; | ||||
| import 'package:http_parser/http_parser.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import '../../../../BuilderField/shared/utils/entity_field_store.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import '../Support_Repo/Support_repo_screen.dart'; | ||||
| 
 | ||||
| class SupportViewModelScreen extends ChangeNotifier{ | ||||
|   final SupportRepoScreen repo = SupportRepoScreen(); | ||||
| 
 | ||||
|   | ||||
|   // State variables | ||||
|   List<Map<String, dynamic>> _supportList = []; | ||||
|   List<Map<String, dynamic>> _filteredList = []; | ||||
|   bool _isLoading = false; | ||||
|   String _errorMessage = ''; | ||||
|   int _currentPage = 0; | ||||
|   int _pageSize = 10; | ||||
|   bool _hasMoreData = true; | ||||
|   String _searchQuery = ''; | ||||
| 
 | ||||
|   // Getters | ||||
|   List<Map<String, dynamic>> get supportList => _supportList; | ||||
|   List<Map<String, dynamic>> get filteredList => _filteredList; | ||||
|   bool get isLoading => _isLoading; | ||||
|   String get errorMessage => _errorMessage; | ||||
|   bool get hasMoreData => _hasMoreData; | ||||
|   String get searchQuery => _searchQuery; | ||||
| 
 | ||||
|   // Set loading state | ||||
|   void _setLoading(bool loading) { | ||||
|     _isLoading = loading; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Set error message | ||||
|   void _setError(String error) { | ||||
|     _errorMessage = error; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Clear error | ||||
|   void clearError() { | ||||
|     _errorMessage = ''; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Get support list | ||||
|   Future<void> getEntities() async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.getEntities(); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         _supportList = response.data ?? []; | ||||
|         _filteredList = List.from(_supportList); | ||||
|         _currentPage = 0; | ||||
|         _hasMoreData = true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to fetch support list'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to fetch support list: $e'); | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Get support list with pagination | ||||
|   Future<void> getAllWithPagination({bool refresh = false}) async { | ||||
|     if (refresh) { | ||||
|       _currentPage = 0; | ||||
|       _supportList.clear(); | ||||
|       _filteredList.clear(); | ||||
|       _hasMoreData = true; | ||||
|     } | ||||
| 
 | ||||
|     if (!_hasMoreData || _isLoading) return; | ||||
| 
 | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.getAllWithPagination(_currentPage, _pageSize); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         final newItems = response.data ?? []; | ||||
| 
 | ||||
|         if (refresh) { | ||||
|           _supportList = newItems; | ||||
|         } else { | ||||
|           _supportList.addAll(newItems); | ||||
|         } | ||||
| 
 | ||||
|         _filteredList = List.from(_supportList); | ||||
|         _currentPage++; | ||||
| 
 | ||||
|         // Check if we have more data | ||||
|         _hasMoreData = newItems.length == _pageSize; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to fetch Support list'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to fetch support list: $e'); | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   // Create Support | ||||
|   Future<bool> createEntity(Map<String, dynamic> entity) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|       final response = await repo.createEntity(entity); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
| // Get the response ID for image upload | ||||
| 
 | ||||
|         final responseId = response.data!['id'].toString(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'support created successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Refresh the list | ||||
|         await getEntities(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to create Support'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to create Support', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to create support: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to create Support: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Update support | ||||
|   Future<bool> updateEntity(int id, Map<String, dynamic> entity) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.updateEntity(id, entity); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'Support updated successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Update the item in the list | ||||
|         final index = _supportList.indexWhere((item) => item['id'] == id); | ||||
|         if (index != -1) { | ||||
|           _supportList[index] = response.data!; | ||||
|           _filteredList = List.from(_supportList); | ||||
|           notifyListeners(); | ||||
|         } | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to update Support'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to update Support', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to update support: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to update Support: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Delete support | ||||
|   Future<bool> deleteEntity(int id) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.deleteEntity(id); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'Support deleted successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Remove the item from the list | ||||
|         _supportList.removeWhere((item) => item['id'] == id); | ||||
|         _filteredList = List.from(_supportList); | ||||
|         notifyListeners(); | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to delete Support'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to delete Support', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to delete support: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to delete Support: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Search support | ||||
|   void searchsupport(String query) { | ||||
|     _searchQuery = query; | ||||
| 
 | ||||
|     if (query.isEmpty) { | ||||
|       _filteredList = List.from(_supportList); | ||||
|     } else { | ||||
|       _filteredList = _supportList.where((item) { | ||||
|         return | ||||
| 
 | ||||
|               | ||||
| (item['name']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['description']?.toString().toLowerCase().contains(query.toLowerCase()) ??false)  | ||||
| 
 | ||||
| 
 | ||||
| ; | ||||
|       }).toList(); | ||||
|     } | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Clear search | ||||
|   void clearSearch() { | ||||
|     _searchQuery = ''; | ||||
|     _filteredList = List.from(_supportList); | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Refresh data | ||||
|   Future<void> refreshData() async { | ||||
|     await getAllWithPagination(refresh: true); | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,84 @@ | ||||
| import 'dart:typed_data'; | ||||
| import 'package:dio/dio.dart'; | ||||
| import 'package:http_parser/http_parser.dart'; | ||||
| import '../../../../resources/api_constants.dart'; | ||||
| import '../../../../data/network/base_network_service.dart'; | ||||
| import '../../../../data/network/network_api_service.dart'; | ||||
| 
 | ||||
| class CountryApiService { | ||||
|   final String baseUrl = ApiConstants.baseUrl; | ||||
| 
 | ||||
|       final BaseNetworkService _helper = NetworkApiService(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|    Future<List<Map<String, dynamic>>> getEntities() async { | ||||
| 
 | ||||
|     try { | ||||
|       final response = await _helper.getGetApiResponse('$baseUrl/Country/Country'); | ||||
|       final entities = (response as List).cast<Map<String, dynamic>>(); | ||||
|       return entities; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all entities: $e'); | ||||
|     } | ||||
|   } | ||||
| Future<List<Map<String, dynamic>>> getAllWithPagination( | ||||
|        int page, int size) async { | ||||
|     try { | ||||
|             final response = | ||||
|           await _helper.getGetApiResponse('$baseUrl/Country/Country/getall/page?page=$page&size=$size'); | ||||
|       final entities = | ||||
|           (response['content'] as List).cast<Map<String, dynamic>>(); | ||||
|       return entities; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to get all without pagination: $e'); | ||||
|     } | ||||
|   } | ||||
|   Future<Map<String, dynamic>> createEntity( | ||||
|        Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|             print("in post api$entity"); | ||||
|       final response = | ||||
|           await _helper.getPostApiResponse('$baseUrl/Country/Country', entity); | ||||
| 
 | ||||
|       print(entity); | ||||
| 
 | ||||
|       // Assuming the response is a Map<String, dynamic> | ||||
|       Map<String, dynamic> responseData = response; | ||||
| 
 | ||||
|       return responseData; | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to create entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   Future<void> updateEntity( int entityId, Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|      await _helper.getPutApiResponse('$baseUrl/Country/Country/$entityId', | ||||
|       entity);                print(entity); | ||||
| 
 | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to update entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<void> deleteEntity( int entityId) async { | ||||
|     try { | ||||
|  await _helper.getDeleteApiResponse('$baseUrl/Country/Country/$entityId'); | ||||
|     } catch (e) { | ||||
|       throw Exception('Failed to delete entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,82 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'dart:convert'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:file_picker/file_picker.dart'; | ||||
| import 'package:image_picker/image_picker.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../Country_viewModel/Country_view_model_screen.dart'; | ||||
| import 'Country_fields.dart';import 'package:base_project/BuilderField/shared/ui/entity_screens.dart'; | ||||
| import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import '../../../../widgets/custom_button.dart'; | ||||
| import '../../../../widgets/custom_text_form_field.dart';  | ||||
| import '../../../../widgets/custom_dropdown_field.dart'; | ||||
| import 'dart:math'; | ||||
| import 'package:qr_flutter/qr_flutter.dart'; | ||||
| import 'package:barcode_widget/barcode_widget.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
|   | ||||
| import 'package:autocomplete_textfield/autocomplete_textfield.dart'; | ||||
| import 'package:http/http.dart' as http; | ||||
| import 'package:flutter/services.dart'; | ||||
| import 'package:image_picker/image_picker.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| import '../../../../Reuseable/reusable_date_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_time_picker_field.dart' | ||||
| ;import 'package:multi_select_flutter/multi_select_flutter.dart'; | ||||
| import 'package:just_audio/just_audio.dart'; | ||||
| import 'package:video_player/video_player.dart'; | ||||
| import 'package:google_fonts/google_fonts.dart'; | ||||
| import 'package:lottie/lottie.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import 'dart:io'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import '../../../../Reuseable/reusable_dropdown_field.dart'; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| class CountryCreateEntityScreen extends StatefulWidget { | ||||
|   const CountryCreateEntityScreen({super.key}); | ||||
| 
 | ||||
|   @override | ||||
|   _CountryCreateEntityScreenState createState() => _CountryCreateEntityScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _CountryCreateEntityScreenState extends State<CountryCreateEntityScreen> { | ||||
| 
 | ||||
| final Map<String, dynamic> formData = {}; | ||||
|   final _formKey = GlobalKey<FormState>(); | ||||
|    | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<CountryViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityCreateScreen( | ||||
|           fields: CountryFields.getFields(context), | ||||
|           onSubmit: (data) => _handleSubmit(data), | ||||
|           title: 'Country', | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   Future<void> _handleSubmit(Map<String, dynamic> formData) async { | ||||
|     final provider = | ||||
|         Provider.of<CountryViewModelScreen>(context, listen: false); | ||||
|     final success = await provider.createEntity(formData); | ||||
| 
 | ||||
|     if (success && mounted) { | ||||
|       Navigator.pop(context); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,90 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../../../../BuilderField/shared/ui/entity_details.dart'; | ||||
| import '../Country_viewModel/Country_view_model_screen.dart'; | ||||
| import 'Country_update_entity_screen.dart'; | ||||
| 
 | ||||
| class CountryDetailsScreen extends StatefulWidget { | ||||
|   final Map<String, dynamic> entity; | ||||
| 
 | ||||
|   const CountryDetailsScreen({ | ||||
|     super.key, | ||||
|     required this.entity, | ||||
|   }); | ||||
| 
 | ||||
|   @override | ||||
|   State<CountryDetailsScreen> createState() => _CountryDetailsScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _CountryDetailsScreenState extends State<CountryDetailsScreen> { | ||||
|   void _navigateToUpdateScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => CountryViewModelScreen(), | ||||
|           child: CountryUpdateEntityScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       // Refresh the details screen with updated data | ||||
|       setState(() {}); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _showDeleteDialog(Map<String, dynamic> entity) { | ||||
|     showDialog( | ||||
|       context: context, | ||||
|       builder: (BuildContext context) { | ||||
|         return AlertDialog( | ||||
|           title: const Text('Confirm Deletion'), | ||||
|           content: const Text('Are you sure you want to delete this Country?'), | ||||
|           actions: [ | ||||
|             TextButton( | ||||
|               child: const Text('Cancel'), | ||||
|               onPressed: () { | ||||
|                 Navigator.of(context).pop(); | ||||
|               }, | ||||
|             ), | ||||
|             TextButton( | ||||
|               child: const Text('Delete'), | ||||
|               onPressed: () async { | ||||
|                 Navigator.of(context).pop(); | ||||
|                 final vm = | ||||
|                     Provider.of<CountryViewModelScreen>(context, listen: false); | ||||
|                 final success = await vm.deleteEntity(entity['id']); | ||||
|                 if (success && mounted) { | ||||
|                   Navigator.pop(context); // Go back to list | ||||
|                 } | ||||
|               }, | ||||
|             ), | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<CountryViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityDetails( | ||||
|           entity: widget.entity, | ||||
|           onEdit: (entity) => _navigateToUpdateScreen(entity), | ||||
|           onDelete: (entity) => _showDeleteDialog(entity), | ||||
|           title: 'Country', | ||||
|           displayFields: [ | ||||
|   {'key': 'name', 'label': 'Name', 'type': 'text'}, | ||||
| 
 | ||||
|   {'key': 'description', 'label': 'Description', 'type': 'textarea'}, | ||||
| 
 | ||||
|   {'key': 'active', 'label': 'Active', 'type': 'toggle_switch'}, | ||||
| 
 | ||||
|           ], | ||||
|           isLoading: viewModel.isLoading, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,150 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
| import 'package:base_project/BuilderField/shared/ui/entity_list.dart'; | ||||
| import 'Country_create_entity_screen.dart'; | ||||
| import 'Country_update_entity_screen.dart'; | ||||
| import '../Country_viewModel/Country_view_model_screen.dart'; | ||||
| import 'Country_details_screen.dart';import 'package:flutter/services.dart'; | ||||
| import 'package:speech_to_text/speech_to_text.dart' as stt; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../widgets/custom_icon_button.dart'; | ||||
| import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import '../../../../theme/app_decoration.dart'; | ||||
| import 'package:multi_select_flutter/multi_select_flutter.dart'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| 
 | ||||
| class Country_entity_list_screen extends StatefulWidget { | ||||
|   static const String routeName = '/entity-list'; | ||||
| 
 | ||||
|   @override | ||||
|   _Country_entity_list_screenState createState() => _Country_entity_list_screenState(); | ||||
| } | ||||
| 
 | ||||
| class _Country_entity_list_screenState extends State<Country_entity_list_screen> { | ||||
|   @override | ||||
|   void initState() { | ||||
|     super.initState(); | ||||
|     _loadData(); | ||||
|   } | ||||
| 
 | ||||
|   void _loadData() { | ||||
|     WidgetsBinding.instance.addPostFrameCallback((_) { | ||||
|       if (mounted) { | ||||
|         final vm = Provider.of<CountryViewModelScreen>(context, listen: false); | ||||
|         vm.getAllWithPagination(refresh: true); | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToCreateScreen() { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => CountryViewModelScreen(), | ||||
|           child: const CountryCreateEntityScreen(), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       final vm = Provider.of<CountryViewModelScreen>(context, listen: false); | ||||
|       vm.refreshData(); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToUpdateScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => CountryViewModelScreen(), | ||||
|           child: CountryUpdateEntityScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ).then((_) { | ||||
|       final vm = Provider.of<CountryViewModelScreen>(context, listen: false); | ||||
|       vm.refreshData(); | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   void _navigateToDetailsScreen(Map<String, dynamic> entity) { | ||||
|     Navigator.push( | ||||
|       context, | ||||
|       MaterialPageRoute( | ||||
|         builder: (context) => ChangeNotifierProvider( | ||||
|           create: (context) => CountryViewModelScreen(), | ||||
|           child: CountryDetailsScreen(entity: entity), | ||||
|         ), | ||||
|       ), | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   void _showDeleteDialog(Map<String, dynamic> entity) { | ||||
|  final parentContext = context;  | ||||
|     showDialog( | ||||
|       context: context, | ||||
|       builder: (BuildContext context) { | ||||
|         return AlertDialog( | ||||
|           title: const Text('Confirm Deletion'), | ||||
|           content: const Text('Are you sure you want to delete this Country?'), | ||||
|           actions: [ | ||||
|             TextButton( | ||||
|               child: const Text('Cancel'), | ||||
|               onPressed: () { | ||||
|                 Navigator.of(context).pop(); | ||||
|               }, | ||||
|             ), | ||||
|             TextButton( | ||||
|               child: const Text('Delete'), | ||||
|               onPressed: () async { | ||||
|                 Navigator.of(context).pop(); | ||||
|                 final vm = | ||||
|                     Provider.of<CountryViewModelScreen>(parentContext, listen: false); | ||||
|                 await vm.deleteEntity(entity['id']); | ||||
|               }, | ||||
|             ), | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<CountryViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
|         return EntityList( | ||||
|           entities: viewModel.filteredList, | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|           hasMoreData: viewModel.hasMoreData, | ||||
|           searchQuery: viewModel.searchQuery, | ||||
|           onSearchChanged: (query) => viewModel.searchcountry(query), | ||||
|           onEdit: (entity) => _navigateToUpdateScreen(entity), | ||||
|           onDelete: (entity) => _showDeleteDialog(entity), | ||||
|           onTap: (entity) => _navigateToDetailsScreen(entity), | ||||
|           onRefresh: () => viewModel.refreshData(), | ||||
|           onLoadMore: () => viewModel.getAllWithPagination(), | ||||
|           title: 'Country', | ||||
|           onAddNew: _navigateToCreateScreen, | ||||
|           displayFields: [ | ||||
|   {'key': 'name', 'label': 'Name', 'type': 'text'}, | ||||
| 
 | ||||
|   {'key': 'description', 'label': 'Description', 'type': 'textarea'}, | ||||
| 
 | ||||
|   {'key': 'active', 'label': 'Active', 'type': 'toggle_switch'}, | ||||
| 
 | ||||
|           ], | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,75 @@ | ||||
| import 'package:base_project/BuilderField/shared/fields/number_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/password_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/phone_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/custom_text_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/base_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/date_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/datetime_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/email_field.dart'; | ||||
| import 'package:base_project/BuilderField/shared/fields/url_field.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:provider/provider.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/custom_text_field.dart' as shared_text; | ||||
| import '../../../../BuilderField/shared/fields/one_to_one_relation_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/calculated_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/one_to_many_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/value_list_picker_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/captcha_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/switch_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/url_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/audio_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/checkbox_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/file_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/image_upload_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/radio_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/video_upload_field.dart'; | ||||
| 
 | ||||
| import '../../../../BuilderField/shared/fields/autocomplete_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/autocomplete_multiselect_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/one_to_one_relation_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/data_grid_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dynamic_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/dynamic_multiselect_dropdown_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/static_multiselect_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/currency_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/field_group_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/qr_code_field.dart'; | ||||
| import '../../../../BuilderField/shared/fields/barcode_field.dart'; | ||||
| import '../Country_viewModel/Country_view_model_screen.dart';/// Field definitions for Country entity | ||||
| /// This defines the structure and validation for Country forms | ||||
| class CountryFields { | ||||
|   /// Get field definitions for Country entity | ||||
|   static List<BaseField> getFields(BuildContext context) { | ||||
|     final viewModel = | ||||
|         Provider.of<CountryViewModelScreen>(context, listen: false); | ||||
|     return [ | ||||
|       // Basic Information | ||||
|  CustomTextField( | ||||
|         fieldKey: 'name', | ||||
|         label: 'Name', | ||||
|         hint: 'Enter Name', | ||||
|         isRequired: true, | ||||
|         maxLength: 50, | ||||
|       ), | ||||
| 
 | ||||
| CustomTextField( | ||||
|         fieldKey: 'description', | ||||
|         label: 'Description', | ||||
|         hint: 'Enter Description', | ||||
|         isRequired: false, | ||||
|         maxLength: 1000, | ||||
|       ), | ||||
| 
 | ||||
|  SwitchField( | ||||
|         fieldKey: 'active', | ||||
|         label: 'Active', | ||||
|       ), | ||||
| 
 | ||||
|     ]; | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,77 @@ | ||||
| // ignore_for_file: use_build_context_synchronously | ||||
| import 'dart:convert'; | ||||
| import 'package:provider/provider.dart'; | ||||
| import '../Country_viewModel/Country_view_model_screen.dart'; | ||||
| import 'package:base_project/BuilderField/shared/ui/entity_screens.dart'; | ||||
| import 'Country_fields.dart';import '../../../../utils/image_constant.dart'; | ||||
| import '../../../../utils/size_utils.dart'; | ||||
| import '../../../../theme/app_style.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_image.dart'; | ||||
| import '../../../../widgets/app_bar/appbar_title.dart'; | ||||
| import '../../../../widgets/app_bar/custom_app_bar.dart'; | ||||
| import 'package:barcode_widget/barcode_widget.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| import '../../../../widgets/custom_button.dart'; | ||||
| import '../../../../widgets/custom_text_form_field.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:autocomplete_textfield/autocomplete_textfield.dart'; | ||||
| import 'package:qr_flutter/qr_flutter.dart'; | ||||
| import 'package:intl/intl.dart'; | ||||
| 
 | ||||
| import 'dart:math'; | ||||
| import '../../../../Reuseable/reusable_text_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_date_time_picker_field.dart'; | ||||
| import '../../../../Reuseable/reusable_dropdown_field.dart'; | ||||
| import 'package:flutter/services.dart'; | ||||
| class CountryUpdateEntityScreen extends StatefulWidget { | ||||
|     final Map<String, dynamic> entity; | ||||
| 
 | ||||
| 
 | ||||
|   CountryUpdateEntityScreen({required this.entity}); | ||||
| 
 | ||||
|   @override | ||||
|   _CountryUpdateEntityScreenState createState() => _CountryUpdateEntityScreenState(); | ||||
| } | ||||
| 
 | ||||
| class _CountryUpdateEntityScreenState extends State<CountryUpdateEntityScreen> { | ||||
|   final _formKey = GlobalKey<FormState>(); | ||||
| 
 | ||||
| @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return Consumer<CountryViewModelScreen>( | ||||
|       builder: (context, viewModel, child) { | ||||
| // Start with all fields, then remove upload fields (generic filter by keys) | ||||
|         final Set<String> hiddenKeys = {  | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  }; | ||||
|         final fields = CountryFields.getFields(context) | ||||
|             .where((f) => !hiddenKeys.contains(f.fieldKey)) | ||||
|             .toList();        return EntityUpdateScreen( | ||||
|           fields: fields, | ||||
|           initialData: widget.entity, | ||||
|           onSubmit: (data) => _handleSubmit(data), | ||||
|           title: 'Country', | ||||
|           isLoading: viewModel.isLoading, | ||||
|           errorMessage: | ||||
|               viewModel.errorMessage.isNotEmpty ? viewModel.errorMessage : null, | ||||
|         ); | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   Future<void> _handleSubmit(Map<String, dynamic> formData) async { | ||||
|     final provider = | ||||
|         Provider.of<CountryViewModelScreen>(context, listen: false); | ||||
|     final success = await provider.updateEntity(widget.entity['id'], formData); | ||||
| 
 | ||||
|     if (success && mounted) { | ||||
|       Navigator.pop(context); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,95 @@ | ||||
| import 'package:dio/dio.dart'; | ||||
| import '../../../../data/network/base_network_service.dart'; | ||||
| import '../../../../data/network/network_api_service.dart'; | ||||
| import '../../../../resources/api_constants.dart'; | ||||
| import 'package:base_project/data/response/api_response.dart'; | ||||
| 
 | ||||
| class CountryRepoScreen { | ||||
| 
 | ||||
|   final String baseUrl = ApiConstants.baseUrl; | ||||
|   final BaseNetworkService _helper = NetworkApiService(); | ||||
|   final String _endpointPath = '/Country/Country'; | ||||
| 
 | ||||
|   Future<ApiResponse<List<Map<String, dynamic>>>> getEntities() async { | ||||
|     try { | ||||
|       final response = | ||||
|           await _helper.getGetApiResponse('$baseUrl$_endpointPath'); | ||||
|       print('Response received: $response'); | ||||
|       List<Map<String, dynamic>> entities = const []; | ||||
|       if (response is List) { | ||||
|         entities = response | ||||
|             .whereType<Map>() | ||||
|             .map((e) => Map<String, dynamic>.from(e as Map)) | ||||
|             .toList(); | ||||
|       } else if (response is Map<String, dynamic>) { | ||||
|         final dynamic content = response['content']; | ||||
|         if (content is List) { | ||||
|           entities = content | ||||
|               .whereType<Map>() | ||||
|               .map((e) => Map<String, dynamic>.from(e as Map)) | ||||
|               .toList(); | ||||
|         } | ||||
|       } | ||||
|       return ApiResponse.success(entities); | ||||
|     } catch (e) { | ||||
|       print(' error got $e'); | ||||
|       return ApiResponse.error('Failed to get all entities: $e'); | ||||
|     } | ||||
|   }  | ||||
| 
 | ||||
|   Future<ApiResponse<List<Map<String, dynamic>>>> getAllWithPagination( | ||||
|       int page, int size) async { | ||||
|     try { | ||||
|       final response = await _helper.getGetApiResponse( | ||||
|           '$baseUrl$_endpointPath/getall/page?page=$page&size=$size'); | ||||
| 
 | ||||
|       if (response is Map<String, dynamic> && response['content'] is List) { | ||||
|         final List<Map<String, dynamic>> entities = | ||||
|             (response['content'] as List).cast<Map<String, dynamic>>().toList(); | ||||
|         return ApiResponse.success(entities); | ||||
|       } else { | ||||
|         return ApiResponse.error('Invalid response format'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to get all without pagination: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<Map<String, dynamic>>> createEntity( | ||||
|       Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|       print("in post api$entity"); | ||||
|       final response = | ||||
|           await _helper.getPostApiResponse('$baseUrl$_endpointPath', entity); | ||||
|       return ApiResponse.success(response as Map<String, dynamic>); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to create entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<Map<String, dynamic>>> updateEntity( | ||||
|       int entityId, Map<String, dynamic> entity) async { | ||||
|     try { | ||||
|       final response = await _helper.getPutApiResponse( | ||||
|           '$baseUrl$_endpointPath/$entityId', entity); | ||||
|       return ApiResponse.success(response as Map<String, dynamic>); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to update entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Future<ApiResponse<void>> deleteEntity(int entityId) async { | ||||
|     try { | ||||
|       await _helper.getDeleteApiResponse('$baseUrl$_endpointPath/$entityId'); | ||||
|       return ApiResponse.success(null); | ||||
|     } catch (e) { | ||||
|       return ApiResponse.error('Failed to delete entity: $e'); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,305 @@ | ||||
| import 'package:base_project/data/response/status.dart'; | ||||
| import 'dart:typed_data'; | ||||
| import 'package:dio/dio.dart'; | ||||
| import 'package:http_parser/http_parser.dart'; | ||||
| import '../../../../utils/toast_messages/toast_message_util.dart'; | ||||
| import '../../../../BuilderField/shared/utils/entity_field_store.dart'; | ||||
| import 'package:flutter/material.dart'; | ||||
| import '../Country_Repo/Country_repo_screen.dart'; | ||||
| 
 | ||||
| class CountryViewModelScreen extends ChangeNotifier{ | ||||
|   final CountryRepoScreen repo = CountryRepoScreen(); | ||||
| 
 | ||||
|   | ||||
|   // State variables | ||||
|   List<Map<String, dynamic>> _countryList = []; | ||||
|   List<Map<String, dynamic>> _filteredList = []; | ||||
|   bool _isLoading = false; | ||||
|   String _errorMessage = ''; | ||||
|   int _currentPage = 0; | ||||
|   int _pageSize = 10; | ||||
|   bool _hasMoreData = true; | ||||
|   String _searchQuery = ''; | ||||
| 
 | ||||
|   // Getters | ||||
|   List<Map<String, dynamic>> get countryList => _countryList; | ||||
|   List<Map<String, dynamic>> get filteredList => _filteredList; | ||||
|   bool get isLoading => _isLoading; | ||||
|   String get errorMessage => _errorMessage; | ||||
|   bool get hasMoreData => _hasMoreData; | ||||
|   String get searchQuery => _searchQuery; | ||||
| 
 | ||||
|   // Set loading state | ||||
|   void _setLoading(bool loading) { | ||||
|     _isLoading = loading; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Set error message | ||||
|   void _setError(String error) { | ||||
|     _errorMessage = error; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Clear error | ||||
|   void clearError() { | ||||
|     _errorMessage = ''; | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Get country list | ||||
|   Future<void> getEntities() async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.getEntities(); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         _countryList = response.data ?? []; | ||||
|         _filteredList = List.from(_countryList); | ||||
|         _currentPage = 0; | ||||
|         _hasMoreData = true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to fetch country list'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to fetch country list: $e'); | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Get country list with pagination | ||||
|   Future<void> getAllWithPagination({bool refresh = false}) async { | ||||
|     if (refresh) { | ||||
|       _currentPage = 0; | ||||
|       _countryList.clear(); | ||||
|       _filteredList.clear(); | ||||
|       _hasMoreData = true; | ||||
|     } | ||||
| 
 | ||||
|     if (!_hasMoreData || _isLoading) return; | ||||
| 
 | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.getAllWithPagination(_currentPage, _pageSize); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         final newItems = response.data ?? []; | ||||
| 
 | ||||
|         if (refresh) { | ||||
|           _countryList = newItems; | ||||
|         } else { | ||||
|           _countryList.addAll(newItems); | ||||
|         } | ||||
| 
 | ||||
|         _filteredList = List.from(_countryList); | ||||
|         _currentPage++; | ||||
| 
 | ||||
|         // Check if we have more data | ||||
|         _hasMoreData = newItems.length == _pageSize; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to fetch Country list'); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to fetch country list: $e'); | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   // Create Country | ||||
|   Future<bool> createEntity(Map<String, dynamic> entity) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|       final response = await repo.createEntity(entity); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
| // Get the response ID for image upload | ||||
| 
 | ||||
|         final responseId = response.data!['id'].toString(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'country created successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Refresh the list | ||||
|         await getEntities(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to create Country'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to create Country', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to create country: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to create Country: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Update country | ||||
|   Future<bool> updateEntity(int id, Map<String, dynamic> entity) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.updateEntity(id, entity); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'Country updated successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Update the item in the list | ||||
|         final index = _countryList.indexWhere((item) => item['id'] == id); | ||||
|         if (index != -1) { | ||||
|           _countryList[index] = response.data!; | ||||
|           _filteredList = List.from(_countryList); | ||||
|           notifyListeners(); | ||||
|         } | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to update Country'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to update Country', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to update country: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to update Country: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Delete country | ||||
|   Future<bool> deleteEntity(int id) async { | ||||
|     _setLoading(true); | ||||
|     _setError(''); | ||||
| 
 | ||||
|     try { | ||||
|       final response = await repo.deleteEntity(id); | ||||
| 
 | ||||
|       if (response.status == Status.SUCCESS) { | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: 'Country deleted successfully', | ||||
|           toastType: ToastType.success, | ||||
|         ); | ||||
| 
 | ||||
|         // Remove the item from the list | ||||
|         _countryList.removeWhere((item) => item['id'] == id); | ||||
|         _filteredList = List.from(_countryList); | ||||
|         notifyListeners(); | ||||
|         return true; | ||||
|       } else { | ||||
|         _setError(response.message ?? 'Failed to delete Country'); | ||||
|         ToastMessageUtil.showToast( | ||||
|           message: response.message ?? 'Failed to delete Country', | ||||
|           toastType: ToastType.error, | ||||
|         ); | ||||
|         return false; | ||||
|       } | ||||
|     } catch (e) { | ||||
|       _setError('Failed to delete country: $e'); | ||||
|       ToastMessageUtil.showToast( | ||||
|         message: 'Failed to delete Country: $e', | ||||
|         toastType: ToastType.error, | ||||
|       ); | ||||
|       return false; | ||||
|     } finally { | ||||
|       _setLoading(false); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // Search country | ||||
|   void searchcountry(String query) { | ||||
|     _searchQuery = query; | ||||
| 
 | ||||
|     if (query.isEmpty) { | ||||
|       _filteredList = List.from(_countryList); | ||||
|     } else { | ||||
|       _filteredList = _countryList.where((item) { | ||||
|         return | ||||
| 
 | ||||
|               | ||||
| (item['name']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|               | ||||
| (item['description']?.toString().toLowerCase().contains(query.toLowerCase()) ??false) || | ||||
| 
 | ||||
| 
 | ||||
| (item['active']?.toString().toLowerCase().contains(query.toLowerCase()) ??false)  | ||||
| 
 | ||||
| 
 | ||||
| ; | ||||
|       }).toList(); | ||||
|     } | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Clear search | ||||
|   void clearSearch() { | ||||
|     _searchQuery = ''; | ||||
|     _filteredList = List.from(_countryList); | ||||
|     notifyListeners(); | ||||
|   } | ||||
| 
 | ||||
|   // Refresh data | ||||
|   Future<void> refreshData() async { | ||||
|     await getAllWithPagination(refresh: true); | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -69,6 +69,15 @@ public class BuilderService { | ||||
| 		executeDump(true); | ||||
| 
 | ||||
| 		// ADD OTHER SERVICE | ||||
| addCustomMenu( "Country","Country",  "Transcations");  | ||||
| 
 | ||||
| 
 | ||||
| addCustomMenu( "Support","Support",  "Transcations");  | ||||
| 
 | ||||
| 
 | ||||
| addCustomMenu( "Adv3","Adv3",  "Transcations");  | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 		System.out.println("dashboard and menu inserted..."); | ||||
| 
 | ||||
|  | ||||
| @ -0,0 +1,155 @@ | ||||
| package com.realnet.angulardatatype.Controllers; | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  import org.springframework.web.bind.annotation.*; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| import com.fasterxml.jackson.core.JsonProcessingException; | ||||
| import org.springframework.web.bind.annotation.CrossOrigin; | ||||
| import com.fasterxml.jackson.databind.JsonMappingException; | ||||
| import com.realnet.config.EmailService; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.fasterxml.jackson.databind.ObjectMapper; | ||||
| import org.springframework.data.domain.*; | ||||
| import com.realnet.fnd.response.EntityResponse; | ||||
| import org.springframework.http.*; | ||||
| import org.springframework.beans.factory.annotation.*; | ||||
| import com.realnet.angulardatatype.Entity.Adv3; | ||||
| import com.realnet.angulardatatype.Services.Adv3Service ; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @RequestMapping(value = "/Adv3") | ||||
|  @CrossOrigin("*")  | ||||
| @RestController | ||||
| public class Adv3Controller { | ||||
| 	@Autowired | ||||
| 	private Adv3Service Service; | ||||
| 
 | ||||
| @Value("${projectPath}") | ||||
| 	private String projectPath; | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	@PostMapping("/Adv3") | ||||
| 		  public Adv3 Savedata(@RequestBody Adv3 data) { | ||||
| 		Adv3 save = Service.Savedata(data)	; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 		System.out.println("data saved..." + save); | ||||
| 
 | ||||
|  return save; | ||||
| 	  } | ||||
| @PutMapping("/Adv3/{id}") | ||||
| 	public  Adv3 update(@RequestBody Adv3 data,@PathVariable Integer id ) { | ||||
| 		Adv3 update = Service.update(data,id); | ||||
| 		System.out.println("data update..." + update); | ||||
| 		return update; | ||||
| 	}	  | ||||
| //	get all with pagination | ||||
| 	@GetMapping("/Adv3/getall/page") | ||||
| 	public Page<Adv3> getall(@RequestParam(value = "page", required = false) Integer page, | ||||
| 			@RequestParam(value = "size", required = false) Integer size) { | ||||
| 		Pageable paging = PageRequest.of(page, size); | ||||
| 		Page<Adv3> get = Service.getAllWithPagination(paging); | ||||
| 
 | ||||
| 		return get; | ||||
| 
 | ||||
| 	}	 | ||||
| 	@GetMapping("/Adv3") | ||||
| 	public List<Adv3> getdetails() { | ||||
| 		 List<Adv3> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| // get all without authentication  | ||||
| 
 | ||||
| 	@GetMapping("/token/Adv3") | ||||
| 	public List<Adv3> getallwioutsec() { | ||||
| 		 List<Adv3> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| @GetMapping("/Adv3/{id}") | ||||
| 	public  Adv3  getdetailsbyId(@PathVariable Integer id ) { | ||||
| 		Adv3  get = Service.getdetailsbyId(id); | ||||
| 		return get; | ||||
| 	} | ||||
| @DeleteMapping("/Adv3/{id}") | ||||
| 	public  ResponseEntity<?> delete_by_id(@PathVariable Integer id ) { | ||||
| 	Service.delete_by_id(id); | ||||
| 			return new ResponseEntity<>(new EntityResponse("Deleted"), HttpStatus.OK); | ||||
| 	 | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,91 @@ | ||||
| package com.realnet.angulardatatype.Controllers; | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  import org.springframework.web.bind.annotation.*; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| import com.fasterxml.jackson.core.JsonProcessingException; | ||||
| import org.springframework.web.bind.annotation.CrossOrigin; | ||||
| import com.fasterxml.jackson.databind.JsonMappingException; | ||||
| import com.realnet.config.EmailService; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.fasterxml.jackson.databind.ObjectMapper; | ||||
| import org.springframework.data.domain.*; | ||||
| import com.realnet.fnd.response.EntityResponse; | ||||
| import org.springframework.http.*; | ||||
| import org.springframework.beans.factory.annotation.*; | ||||
| import com.realnet.angulardatatype.Entity.Support; | ||||
| import com.realnet.angulardatatype.Services.SupportService ; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @RequestMapping(value = "/Support") | ||||
|  @CrossOrigin("*")  | ||||
| @RestController | ||||
| public class SupportController { | ||||
| 	@Autowired | ||||
| 	private SupportService Service; | ||||
| 
 | ||||
| @Value("${projectPath}") | ||||
| 	private String projectPath; | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	@PostMapping("/Support") | ||||
| 		  public Support Savedata(@RequestBody Support data) { | ||||
| 		Support save = Service.Savedata(data)	; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 		System.out.println("data saved..." + save); | ||||
| 
 | ||||
|  return save; | ||||
| 	  } | ||||
| @PutMapping("/Support/{id}") | ||||
| 	public  Support update(@RequestBody Support data,@PathVariable Integer id ) { | ||||
| 		Support update = Service.update(data,id); | ||||
| 		System.out.println("data update..." + update); | ||||
| 		return update; | ||||
| 	}	  | ||||
| //	get all with pagination | ||||
| 	@GetMapping("/Support/getall/page") | ||||
| 	public Page<Support> getall(@RequestParam(value = "page", required = false) Integer page, | ||||
| 			@RequestParam(value = "size", required = false) Integer size) { | ||||
| 		Pageable paging = PageRequest.of(page, size); | ||||
| 		Page<Support> get = Service.getAllWithPagination(paging); | ||||
| 
 | ||||
| 		return get; | ||||
| 
 | ||||
| 	}	 | ||||
| 	@GetMapping("/Support") | ||||
| 	public List<Support> getdetails() { | ||||
| 		 List<Support> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| // get all without authentication  | ||||
| 
 | ||||
| 	@GetMapping("/token/Support") | ||||
| 	public List<Support> getallwioutsec() { | ||||
| 		 List<Support> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| @GetMapping("/Support/{id}") | ||||
| 	public  Support  getdetailsbyId(@PathVariable Integer id ) { | ||||
| 		Support  get = Service.getdetailsbyId(id); | ||||
| 		return get; | ||||
| 	} | ||||
| @DeleteMapping("/Support/{id}") | ||||
| 	public  ResponseEntity<?> delete_by_id(@PathVariable Integer id ) { | ||||
| 	Service.delete_by_id(id); | ||||
| 			return new ResponseEntity<>(new EntityResponse("Deleted"), HttpStatus.OK); | ||||
| 	 | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,155 @@ | ||||
| package com.realnet.angulardatatype.Controllers; | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  import org.springframework.web.bind.annotation.*; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| import com.fasterxml.jackson.core.JsonProcessingException; | ||||
| import org.springframework.web.bind.annotation.CrossOrigin; | ||||
| import com.fasterxml.jackson.databind.JsonMappingException; | ||||
| import com.realnet.config.EmailService; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.fasterxml.jackson.databind.ObjectMapper; | ||||
| import org.springframework.data.domain.*; | ||||
| import com.realnet.fnd.response.EntityResponse; | ||||
| import org.springframework.http.*; | ||||
| import org.springframework.beans.factory.annotation.*; | ||||
| import com.realnet.angulardatatype.Entity.Adv3; | ||||
| import com.realnet.angulardatatype.Services.Adv3Service ; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @RequestMapping(value = "/token/Adv3") | ||||
|  @CrossOrigin("*")  | ||||
| @RestController | ||||
| public class tokenFree_Adv3Controller { | ||||
| 	@Autowired | ||||
| 	private Adv3Service Service; | ||||
| 
 | ||||
| @Value("${projectPath}") | ||||
| 	private String projectPath; | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	@PostMapping("/Adv3") | ||||
| 		  public Adv3 Savedata(@RequestBody Adv3 data) { | ||||
| 		Adv3 save = Service.Savedata(data)	; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 		System.out.println("data saved..." + save); | ||||
| 
 | ||||
|  return save; | ||||
| 	  } | ||||
| @PutMapping("/Adv3/{id}") | ||||
| 	public  Adv3 update(@RequestBody Adv3 data,@PathVariable Integer id ) { | ||||
| 		Adv3 update = Service.update(data,id); | ||||
| 		System.out.println("data update..." + update); | ||||
| 		return update; | ||||
| 	}	  | ||||
| //	get all with pagination | ||||
| 	@GetMapping("/Adv3/getall/page") | ||||
| 	public Page<Adv3> getall(@RequestParam(value = "page", required = false) Integer page, | ||||
| 			@RequestParam(value = "size", required = false) Integer size) { | ||||
| 		Pageable paging = PageRequest.of(page, size); | ||||
| 		Page<Adv3> get = Service.getAllWithPagination(paging); | ||||
| 
 | ||||
| 		return get; | ||||
| 
 | ||||
| 	}	 | ||||
| 	@GetMapping("/Adv3") | ||||
| 	public List<Adv3> getdetails() { | ||||
| 		 List<Adv3> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| // get all without authentication  | ||||
| 
 | ||||
| 	@GetMapping("/token/Adv3") | ||||
| 	public List<Adv3> getallwioutsec() { | ||||
| 		 List<Adv3> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| @GetMapping("/Adv3/{id}") | ||||
| 	public  Adv3  getdetailsbyId(@PathVariable Integer id ) { | ||||
| 		Adv3  get = Service.getdetailsbyId(id); | ||||
| 		return get; | ||||
| 	} | ||||
| @DeleteMapping("/Adv3/{id}") | ||||
| 	public  ResponseEntity<?> delete_by_id(@PathVariable Integer id ) { | ||||
| 	Service.delete_by_id(id); | ||||
| 			return new ResponseEntity<>(new EntityResponse("Deleted"), HttpStatus.OK); | ||||
| 	 | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,91 @@ | ||||
| package com.realnet.angulardatatype.Controllers; | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  import org.springframework.web.bind.annotation.*; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| import com.fasterxml.jackson.core.JsonProcessingException; | ||||
| import org.springframework.web.bind.annotation.CrossOrigin; | ||||
| import com.fasterxml.jackson.databind.JsonMappingException; | ||||
| import com.realnet.config.EmailService; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.fasterxml.jackson.databind.ObjectMapper; | ||||
| import org.springframework.data.domain.*; | ||||
| import com.realnet.fnd.response.EntityResponse; | ||||
| import org.springframework.http.*; | ||||
| import org.springframework.beans.factory.annotation.*; | ||||
| import com.realnet.angulardatatype.Entity.Support; | ||||
| import com.realnet.angulardatatype.Services.SupportService ; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @RequestMapping(value = "/token/Support") | ||||
|  @CrossOrigin("*")  | ||||
| @RestController | ||||
| public class tokenFree_SupportController { | ||||
| 	@Autowired | ||||
| 	private SupportService Service; | ||||
| 
 | ||||
| @Value("${projectPath}") | ||||
| 	private String projectPath; | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	@PostMapping("/Support") | ||||
| 		  public Support Savedata(@RequestBody Support data) { | ||||
| 		Support save = Service.Savedata(data)	; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 		System.out.println("data saved..." + save); | ||||
| 
 | ||||
|  return save; | ||||
| 	  } | ||||
| @PutMapping("/Support/{id}") | ||||
| 	public  Support update(@RequestBody Support data,@PathVariable Integer id ) { | ||||
| 		Support update = Service.update(data,id); | ||||
| 		System.out.println("data update..." + update); | ||||
| 		return update; | ||||
| 	}	  | ||||
| //	get all with pagination | ||||
| 	@GetMapping("/Support/getall/page") | ||||
| 	public Page<Support> getall(@RequestParam(value = "page", required = false) Integer page, | ||||
| 			@RequestParam(value = "size", required = false) Integer size) { | ||||
| 		Pageable paging = PageRequest.of(page, size); | ||||
| 		Page<Support> get = Service.getAllWithPagination(paging); | ||||
| 
 | ||||
| 		return get; | ||||
| 
 | ||||
| 	}	 | ||||
| 	@GetMapping("/Support") | ||||
| 	public List<Support> getdetails() { | ||||
| 		 List<Support> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| // get all without authentication  | ||||
| 
 | ||||
| 	@GetMapping("/token/Support") | ||||
| 	public List<Support> getallwioutsec() { | ||||
| 		 List<Support> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| @GetMapping("/Support/{id}") | ||||
| 	public  Support  getdetailsbyId(@PathVariable Integer id ) { | ||||
| 		Support  get = Service.getdetailsbyId(id); | ||||
| 		return get; | ||||
| 	} | ||||
| @DeleteMapping("/Support/{id}") | ||||
| 	public  ResponseEntity<?> delete_by_id(@PathVariable Integer id ) { | ||||
| 	Service.delete_by_id(id); | ||||
| 			return new ResponseEntity<>(new EntityResponse("Deleted"), HttpStatus.OK); | ||||
| 	 | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,62 @@ | ||||
| package com.realnet.angulardatatype.Entity; | ||||
|  import lombok.*; | ||||
| import com.realnet.WhoColumn.Entity.Extension;  | ||||
|  import javax.persistence.*; | ||||
|  import java.time.LocalDateTime; | ||||
|  import java.util.*; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  @Entity  | ||||
|  @Data | ||||
|  public class    Adv3 extends Extension {  | ||||
|  /** | ||||
| 	 *  | ||||
| 	 */ | ||||
| 	private static final long serialVersionUID = 1L; | ||||
| 
 | ||||
|  @Id | ||||
|  @GeneratedValue(strategy = GenerationType.IDENTITY) | ||||
|  private Integer id; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| private String country; | ||||
| 
 | ||||
| private String state; | ||||
| 
 | ||||
| private String stmlit; | ||||
| 
 | ||||
| private String stmmlt2; | ||||
| 
 | ||||
| private String dy2; | ||||
| private String dy2identifier; | ||||
| 
 | ||||
| private String dy1; | ||||
| private String dy1identifier; | ||||
| 
 | ||||
| private String dymlti1; | ||||
| 
 | ||||
| private String dymlt2; | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,29 @@ | ||||
| package com.realnet.angulardatatype.Entity; | ||||
|  import lombok.*; | ||||
| import com.realnet.WhoColumn.Entity.Extension;  | ||||
|  import javax.persistence.*; | ||||
|  import java.time.LocalDateTime; | ||||
|  import java.util.*; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  @Entity  | ||||
|  @Data | ||||
|  public class    Support extends Extension {  | ||||
|  /** | ||||
| 	 *  | ||||
| 	 */ | ||||
| 	private static final long serialVersionUID = 1L; | ||||
| 
 | ||||
|  @Id | ||||
|  @GeneratedValue(strategy = GenerationType.IDENTITY) | ||||
|  private Integer id; | ||||
| 
 | ||||
| private String  name; | ||||
| 
 | ||||
| @Column(length = 2000) | ||||
| private String description; | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,44 @@ | ||||
| package com.realnet.angulardatatype.Repository; | ||||
| 
 | ||||
| 
 | ||||
| import org.springframework.data.domain.Page; | ||||
| import org.springframework.data.domain.Pageable; | ||||
| import org.springframework.data.jpa.repository.JpaRepository; | ||||
| import org.springframework.data.jpa.repository.Query; | ||||
| 
 | ||||
| import org.springframework.stereotype.Repository;  | ||||
| import java.util.*; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
| import com.realnet.angulardatatype.Entity.Adv3; | ||||
| 
 | ||||
| @Repository | ||||
| public interface  Adv3Repository  extends  JpaRepository<Adv3, Integer>  {  | ||||
| 
 | ||||
| @Query(value = "select * from adv3 where  created_by=?1", nativeQuery = true) | ||||
| 	List<Adv3> findAll(Long creayedBy); | ||||
| 
 | ||||
| @Query(value = "select * from adv3 where  created_by=?1", nativeQuery = true) | ||||
| 	Page<Adv3> findAll( Long creayedBy,Pageable page); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| package com.realnet.angulardatatype.Repository; | ||||
| 
 | ||||
| 
 | ||||
| import org.springframework.data.domain.Page; | ||||
| import org.springframework.data.domain.Pageable; | ||||
| import org.springframework.data.jpa.repository.JpaRepository; | ||||
| import org.springframework.data.jpa.repository.Query; | ||||
| 
 | ||||
| import org.springframework.stereotype.Repository;  | ||||
| import java.util.*; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
| import com.realnet.angulardatatype.Entity.Support; | ||||
| 
 | ||||
| @Repository | ||||
| public interface  SupportRepository  extends  JpaRepository<Support, Integer>  {  | ||||
| 
 | ||||
| @Query(value = "select * from support where  created_by=?1", nativeQuery = true) | ||||
| 	List<Support> findAll(Long creayedBy); | ||||
| 
 | ||||
| @Query(value = "select * from support where  created_by=?1", nativeQuery = true) | ||||
| 	Page<Support> findAll( Long creayedBy,Pageable page); | ||||
| } | ||||
| @ -0,0 +1,209 @@ | ||||
| package com.realnet.angulardatatype.Services; | ||||
| import com.realnet.angulardatatype.Repository.Adv3Repository; | ||||
| import com.realnet.angulardatatype.Entity.Adv3 | ||||
| ;import java.util.*; | ||||
| 
 | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import com.realnet.SequenceGenerator.Service.SequenceService; | ||||
| import org.springframework.data.domain.Page; | ||||
| import com.realnet.realm.Entity.Realm; | ||||
| import com.realnet.realm.Services.RealmService; | ||||
| import org.springframework.data.domain.Pageable; | ||||
| import org.springframework.http.*; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| import com.realnet.testdata.Entity.Country; | ||||
| import com.realnet.testdata.Services.CountryService; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| import com.realnet.testdata.Entity.Country; | ||||
| import com.realnet.testdata.Services.CountryService; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	import org.springframework.stereotype.Service; | ||||
| 
 | ||||
| @Service | ||||
|  public class Adv3Service { | ||||
| @Autowired | ||||
| private Adv3Repository Repository; | ||||
| 	@Autowired | ||||
| 	private AppUserServiceImpl userService;  | ||||
| @Autowired | ||||
| 	private RealmService realmService; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @Autowired | ||||
| 	private CountryService dy2serv; | ||||
| 
 | ||||
| @Autowired | ||||
| 	private CountryService dy1serv; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| public Adv3 Savedata(Adv3 data) { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   | ||||
| if (data.getDy2() != null) { | ||||
| 		try {	 | ||||
|   int dy2Id = Integer.valueOf(data.getDy2()); | ||||
| Country get =  dy2serv.getdetailsbyId(dy2Id); | ||||
| 			if (get != null) { | ||||
| 
 | ||||
| 			data.setDy2identifier(get.getName()); | ||||
| } | ||||
| } catch (NumberFormatException e) { | ||||
| 				System.out.println(" dy2Id is not integer.."); | ||||
| 				// Invalid integer string — ignore or log | ||||
| data.setDy2identifier(data.getDy2()); | ||||
| 			} | ||||
| 
 | ||||
| 		} | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   | ||||
| if (data.getDy1() != null) { | ||||
| 		try {	 | ||||
|   int dy1Id = Integer.valueOf(data.getDy1()); | ||||
| Country get =  dy1serv.getdetailsbyId(dy1Id); | ||||
| 			if (get != null) { | ||||
| 
 | ||||
| 			data.setDy1identifier(get.getDescription()); | ||||
| } | ||||
| } catch (NumberFormatException e) { | ||||
| 				System.out.println(" dy1Id is not integer.."); | ||||
| 				// Invalid integer string — ignore or log | ||||
| data.setDy1identifier(data.getDy1()); | ||||
| 			} | ||||
| 
 | ||||
| 		} | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	data.setUpdatedBy(getUser().getUserId()); | ||||
| 		data.setCreatedBy(getUser().getUserId()); | ||||
| 		data.setAccountId(getUser().getAccount().getAccount_id()); | ||||
| Adv3 save = Repository.save(data); | ||||
| 				return save;	 | ||||
| 			} | ||||
| 
 | ||||
| 
 | ||||
| //	get all with pagination | ||||
| 	public Page<Adv3> getAllWithPagination(Pageable page) { | ||||
| 		return Repository.findAll( getUser().getUserId(),page); | ||||
| 	}			 | ||||
| public List<Adv3> getdetails() {   | ||||
| 		List<Realm> realm = realmService.findByUserId(getUser().getUserId()); | ||||
| List<Adv3> all = Repository.findAll(getUser().getUserId()); | ||||
| 		 | ||||
| 		return all ;		} | ||||
| 
 | ||||
| 
 | ||||
| public Adv3 getdetailsbyId(Integer id) { | ||||
| 	return Repository.findById(id).get(); | ||||
| 			} | ||||
| 
 | ||||
| 
 | ||||
| 	public void delete_by_id(Integer id) { | ||||
|  Repository.deleteById(id); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| public Adv3 update(Adv3 data,Integer id) { | ||||
| 	Adv3 old = Repository.findById(id).get(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| old.setCountry(data.getCountry()); | ||||
| 
 | ||||
| old.setState(data.getState()); | ||||
| 
 | ||||
| old.setStmlit(data.getStmlit()); | ||||
| 
 | ||||
| old.setStmmlt2(data.getStmmlt2()); | ||||
| 
 | ||||
| old.setDy2(data.getDy2()); | ||||
| 
 | ||||
| old.setDy1(data.getDy1()); | ||||
| 
 | ||||
| old.setDymlti1(data.getDymlti1()); | ||||
| 
 | ||||
| old.setDymlt2(data.getDymlt2()); | ||||
| 
 | ||||
| final Adv3 test = Repository.save(old); | ||||
| 		data.setUpdatedBy(getUser().getUserId()); | ||||
|   return test;}  | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  public AppUser getUser() { | ||||
| 		AppUser user = userService.getLoggedInUser(); | ||||
| 		return user; | ||||
| 
 | ||||
| 	}} | ||||
| @ -0,0 +1,83 @@ | ||||
| package com.realnet.angulardatatype.Services; | ||||
| import com.realnet.angulardatatype.Repository.SupportRepository; | ||||
| import com.realnet.angulardatatype.Entity.Support | ||||
| ;import java.util.*; | ||||
| 
 | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import com.realnet.SequenceGenerator.Service.SequenceService; | ||||
| import org.springframework.data.domain.Page; | ||||
| import com.realnet.realm.Entity.Realm; | ||||
| import com.realnet.realm.Services.RealmService; | ||||
| import org.springframework.data.domain.Pageable; | ||||
| import org.springframework.http.*; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	import org.springframework.stereotype.Service; | ||||
| 
 | ||||
| @Service | ||||
|  public class SupportService { | ||||
| @Autowired | ||||
| private SupportRepository Repository; | ||||
| 	@Autowired | ||||
| 	private AppUserServiceImpl userService;  | ||||
| @Autowired | ||||
| 	private RealmService realmService; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| public Support Savedata(Support data) { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	data.setUpdatedBy(getUser().getUserId()); | ||||
| 		data.setCreatedBy(getUser().getUserId()); | ||||
| 		data.setAccountId(getUser().getAccount().getAccount_id()); | ||||
| Support save = Repository.save(data); | ||||
| 				return save;	 | ||||
| 			} | ||||
| 
 | ||||
| 
 | ||||
| //	get all with pagination | ||||
| 	public Page<Support> getAllWithPagination(Pageable page) { | ||||
| 		return Repository.findAll( getUser().getUserId(),page); | ||||
| 	}			 | ||||
| public List<Support> getdetails() {   | ||||
| 		List<Realm> realm = realmService.findByUserId(getUser().getUserId()); | ||||
| List<Support> all = Repository.findAll(getUser().getUserId()); | ||||
| 		 | ||||
| 		return all ;		} | ||||
| 
 | ||||
| 
 | ||||
| public Support getdetailsbyId(Integer id) { | ||||
| 	return Repository.findById(id).get(); | ||||
| 			} | ||||
| 
 | ||||
| 
 | ||||
| 	public void delete_by_id(Integer id) { | ||||
|  Repository.deleteById(id); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| public Support update(Support data,Integer id) { | ||||
| 	Support old = Repository.findById(id).get(); | ||||
| old.setName(data.getName()); | ||||
| 
 | ||||
| old.setDescription(data.getDescription()); | ||||
| 
 | ||||
| final Support test = Repository.save(old); | ||||
| 		data.setUpdatedBy(getUser().getUserId()); | ||||
|   return test;}  | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  public AppUser getUser() { | ||||
| 		AppUser user = userService.getLoggedInUser(); | ||||
| 		return user; | ||||
| 
 | ||||
| 	}} | ||||
| @ -0,0 +1,99 @@ | ||||
| package com.realnet.testdata.Controllers; | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  import org.springframework.web.bind.annotation.*; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| import com.fasterxml.jackson.core.JsonProcessingException; | ||||
| import org.springframework.web.bind.annotation.CrossOrigin; | ||||
| import com.fasterxml.jackson.databind.JsonMappingException; | ||||
| import com.realnet.config.EmailService; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.fasterxml.jackson.databind.ObjectMapper; | ||||
| import org.springframework.data.domain.*; | ||||
| import com.realnet.fnd.response.EntityResponse; | ||||
| import org.springframework.http.*; | ||||
| import org.springframework.beans.factory.annotation.*; | ||||
| import com.realnet.testdata.Entity.Country; | ||||
| import com.realnet.testdata.Services.CountryService ; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @RequestMapping(value = "/Country") | ||||
|  @CrossOrigin("*")  | ||||
| @RestController | ||||
| public class CountryController { | ||||
| 	@Autowired | ||||
| 	private CountryService Service; | ||||
| 
 | ||||
| @Value("${projectPath}") | ||||
| 	private String projectPath; | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	@PostMapping("/Country") | ||||
| 		  public Country Savedata(@RequestBody Country data) { | ||||
| 		Country save = Service.Savedata(data)	; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 		System.out.println("data saved..." + save); | ||||
| 
 | ||||
|  return save; | ||||
| 	  } | ||||
| @PutMapping("/Country/{id}") | ||||
| 	public  Country update(@RequestBody Country data,@PathVariable Integer id ) { | ||||
| 		Country update = Service.update(data,id); | ||||
| 		System.out.println("data update..." + update); | ||||
| 		return update; | ||||
| 	}	  | ||||
| //	get all with pagination | ||||
| 	@GetMapping("/Country/getall/page") | ||||
| 	public Page<Country> getall(@RequestParam(value = "page", required = false) Integer page, | ||||
| 			@RequestParam(value = "size", required = false) Integer size) { | ||||
| 		Pageable paging = PageRequest.of(page, size); | ||||
| 		Page<Country> get = Service.getAllWithPagination(paging); | ||||
| 
 | ||||
| 		return get; | ||||
| 
 | ||||
| 	}	 | ||||
| 	@GetMapping("/Country") | ||||
| 	public List<Country> getdetails() { | ||||
| 		 List<Country> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| // get all without authentication  | ||||
| 
 | ||||
| 	@GetMapping("/token/Country") | ||||
| 	public List<Country> getallwioutsec() { | ||||
| 		 List<Country> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| @GetMapping("/Country/{id}") | ||||
| 	public  Country  getdetailsbyId(@PathVariable Integer id ) { | ||||
| 		Country  get = Service.getdetailsbyId(id); | ||||
| 		return get; | ||||
| 	} | ||||
| @DeleteMapping("/Country/{id}") | ||||
| 	public  ResponseEntity<?> delete_by_id(@PathVariable Integer id ) { | ||||
| 	Service.delete_by_id(id); | ||||
| 			return new ResponseEntity<>(new EntityResponse("Deleted"), HttpStatus.OK); | ||||
| 	 | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,24 @@ | ||||
| package com.realnet.testdata.Controllers; | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  import org.springframework.web.bind.annotation.*; | ||||
| import com.realnet.testdata.Entity.Country_ListFilter1; | ||||
| import com.realnet.testdata.Services.Country_ListFilter1Service ; | ||||
| @RequestMapping(value = "/Country_ListFilter1") | ||||
| @RestController | ||||
| public class Country_ListFilter1Controller { | ||||
| 	 | ||||
| 	@Autowired | ||||
| 	private Country_ListFilter1Service Service; | ||||
| 
 | ||||
| 		@GetMapping("/Country_ListFilter1") | ||||
| 	public List<Country_ListFilter1> getlist() { | ||||
| 		 List<Country_ListFilter1> get = Service.getlistbuilder();		 | ||||
| 		return get; | ||||
| } | ||||
| 		@GetMapping("/Country_ListFilter11") | ||||
| 	public List<Country_ListFilter1> getlistwithparam( ) { | ||||
| 		 List<Country_ListFilter1> get = Service.getlistbuilderparam( );		 | ||||
| 		return get; | ||||
| } | ||||
| } | ||||
| @ -0,0 +1,99 @@ | ||||
| package com.realnet.testdata.Controllers; | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  import org.springframework.web.bind.annotation.*; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| import com.fasterxml.jackson.core.JsonProcessingException; | ||||
| import org.springframework.web.bind.annotation.CrossOrigin; | ||||
| import com.fasterxml.jackson.databind.JsonMappingException; | ||||
| import com.realnet.config.EmailService; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.fasterxml.jackson.databind.ObjectMapper; | ||||
| import org.springframework.data.domain.*; | ||||
| import com.realnet.fnd.response.EntityResponse; | ||||
| import org.springframework.http.*; | ||||
| import org.springframework.beans.factory.annotation.*; | ||||
| import com.realnet.testdata.Entity.Country; | ||||
| import com.realnet.testdata.Services.CountryService ; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @RequestMapping(value = "/token/Country") | ||||
|  @CrossOrigin("*")  | ||||
| @RestController | ||||
| public class tokenFree_CountryController { | ||||
| 	@Autowired | ||||
| 	private CountryService Service; | ||||
| 
 | ||||
| @Value("${projectPath}") | ||||
| 	private String projectPath; | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	@PostMapping("/Country") | ||||
| 		  public Country Savedata(@RequestBody Country data) { | ||||
| 		Country save = Service.Savedata(data)	; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 		System.out.println("data saved..." + save); | ||||
| 
 | ||||
|  return save; | ||||
| 	  } | ||||
| @PutMapping("/Country/{id}") | ||||
| 	public  Country update(@RequestBody Country data,@PathVariable Integer id ) { | ||||
| 		Country update = Service.update(data,id); | ||||
| 		System.out.println("data update..." + update); | ||||
| 		return update; | ||||
| 	}	  | ||||
| //	get all with pagination | ||||
| 	@GetMapping("/Country/getall/page") | ||||
| 	public Page<Country> getall(@RequestParam(value = "page", required = false) Integer page, | ||||
| 			@RequestParam(value = "size", required = false) Integer size) { | ||||
| 		Pageable paging = PageRequest.of(page, size); | ||||
| 		Page<Country> get = Service.getAllWithPagination(paging); | ||||
| 
 | ||||
| 		return get; | ||||
| 
 | ||||
| 	}	 | ||||
| 	@GetMapping("/Country") | ||||
| 	public List<Country> getdetails() { | ||||
| 		 List<Country> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| // get all without authentication  | ||||
| 
 | ||||
| 	@GetMapping("/token/Country") | ||||
| 	public List<Country> getallwioutsec() { | ||||
| 		 List<Country> get = Service.getdetails();		 | ||||
| 		return get; | ||||
| } | ||||
| @GetMapping("/Country/{id}") | ||||
| 	public  Country  getdetailsbyId(@PathVariable Integer id ) { | ||||
| 		Country  get = Service.getdetailsbyId(id); | ||||
| 		return get; | ||||
| 	} | ||||
| @DeleteMapping("/Country/{id}") | ||||
| 	public  ResponseEntity<?> delete_by_id(@PathVariable Integer id ) { | ||||
| 	Service.delete_by_id(id); | ||||
| 			return new ResponseEntity<>(new EntityResponse("Deleted"), HttpStatus.OK); | ||||
| 	 | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,24 @@ | ||||
| package com.realnet.testdata.Controllers; | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
|  import org.springframework.web.bind.annotation.*; | ||||
| import com.realnet.testdata.Entity.Country_ListFilter1; | ||||
| import com.realnet.testdata.Services.Country_ListFilter1Service ; | ||||
| @RequestMapping(value = "/token/Country_ListFilter1") | ||||
| @RestController | ||||
| public class tokenFree_Country_ListFilter1Controller { | ||||
| 	 | ||||
| 	@Autowired | ||||
| 	private Country_ListFilter1Service Service; | ||||
| 
 | ||||
| 		@GetMapping("/Country_ListFilter1") | ||||
| 	public List<Country_ListFilter1> getlist() { | ||||
| 		 List<Country_ListFilter1> get = Service.getlistbuilder();		 | ||||
| 		return get; | ||||
| } | ||||
| 		@GetMapping("/Country_ListFilter11") | ||||
| 	public List<Country_ListFilter1> getlistwithparam( ) { | ||||
| 		 List<Country_ListFilter1> get = Service.getlistbuilderparam( );		 | ||||
| 		return get; | ||||
| } | ||||
| } | ||||
| @ -0,0 +1,33 @@ | ||||
| package com.realnet.testdata.Entity; | ||||
|  import lombok.*; | ||||
| import com.realnet.WhoColumn.Entity.Extension;  | ||||
|  import javax.persistence.*; | ||||
|  import java.time.LocalDateTime; | ||||
|  import java.util.*; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  @Entity  | ||||
|  @Data | ||||
|  public class    Country extends Extension {  | ||||
|  /** | ||||
| 	 *  | ||||
| 	 */ | ||||
| 	private static final long serialVersionUID = 1L; | ||||
| 
 | ||||
|  @Id | ||||
|  @GeneratedValue(strategy = GenerationType.IDENTITY) | ||||
|  private Integer id; | ||||
| 
 | ||||
| private String  name; | ||||
| 
 | ||||
| @Column(length = 2000) | ||||
| private String description; | ||||
| 
 | ||||
| private Boolean active; | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,15 @@ | ||||
| package com.realnet.testdata.Entity; | ||||
|  import lombok.*; | ||||
|  import javax.persistence.*; | ||||
|  import java.time.LocalDateTime; | ||||
|  import java.util.*; | ||||
| 
 | ||||
|  @Data | ||||
|  public class    Country_ListFilter1 {  | ||||
| 
 | ||||
|  private Integer id; | ||||
| 
 | ||||
| 
 | ||||
|  private String name; | ||||
|  private String description; | ||||
| } | ||||
| @ -0,0 +1,30 @@ | ||||
| package com.realnet.testdata.Repository; | ||||
| 
 | ||||
| 
 | ||||
| import org.springframework.data.domain.Page; | ||||
| import org.springframework.data.domain.Pageable; | ||||
| import org.springframework.data.jpa.repository.JpaRepository; | ||||
| import org.springframework.data.jpa.repository.Query; | ||||
| 
 | ||||
| import org.springframework.stereotype.Repository;  | ||||
| import java.util.*; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   | ||||
| 
 | ||||
| import com.realnet.testdata.Entity.Country; | ||||
| 
 | ||||
| @Repository | ||||
| public interface  CountryRepository  extends  JpaRepository<Country, Integer>  {  | ||||
| 
 | ||||
| @Query(value = "select * from country where  created_by=?1", nativeQuery = true) | ||||
| 	List<Country> findAll(Long creayedBy); | ||||
| 
 | ||||
| @Query(value = "select * from country where  created_by=?1", nativeQuery = true) | ||||
| 	Page<Country> findAll( Long creayedBy,Pageable page); | ||||
| } | ||||
| @ -0,0 +1,93 @@ | ||||
| package com.realnet.testdata.Services; | ||||
| import com.realnet.testdata.Repository.CountryRepository; | ||||
| import com.realnet.testdata.Entity.Country | ||||
| ;import java.util.*; | ||||
| 
 | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import com.realnet.SequenceGenerator.Service.SequenceService; | ||||
| import org.springframework.data.domain.Page; | ||||
| import com.realnet.realm.Entity.Realm; | ||||
| import com.realnet.realm.Services.RealmService; | ||||
| import org.springframework.data.domain.Pageable; | ||||
| import org.springframework.http.*; | ||||
| import com.realnet.users.service1.AppUserServiceImpl; | ||||
| import com.realnet.users.entity1.AppUser; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	import org.springframework.stereotype.Service; | ||||
| 
 | ||||
| @Service | ||||
|  public class CountryService { | ||||
| @Autowired | ||||
| private CountryRepository Repository; | ||||
| 	@Autowired | ||||
| 	private AppUserServiceImpl userService;  | ||||
| @Autowired | ||||
| 	private RealmService realmService; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| public Country Savedata(Country data) { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	data.setUpdatedBy(getUser().getUserId()); | ||||
| 		data.setCreatedBy(getUser().getUserId()); | ||||
| 		data.setAccountId(getUser().getAccount().getAccount_id()); | ||||
| Country save = Repository.save(data); | ||||
| 				return save;	 | ||||
| 			} | ||||
| 
 | ||||
| 
 | ||||
| //	get all with pagination | ||||
| 	public Page<Country> getAllWithPagination(Pageable page) { | ||||
| 		return Repository.findAll( getUser().getUserId(),page); | ||||
| 	}			 | ||||
| public List<Country> getdetails() {   | ||||
| 		List<Realm> realm = realmService.findByUserId(getUser().getUserId()); | ||||
| List<Country> all = Repository.findAll(getUser().getUserId()); | ||||
| 		 | ||||
| 		return all ;		} | ||||
| 
 | ||||
| 
 | ||||
| public Country getdetailsbyId(Integer id) { | ||||
| 	return Repository.findById(id).get(); | ||||
| 			} | ||||
| 
 | ||||
| 
 | ||||
| 	public void delete_by_id(Integer id) { | ||||
|  Repository.deleteById(id); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| public Country update(Country data,Integer id) { | ||||
| 	Country old = Repository.findById(id).get(); | ||||
| old.setName(data.getName()); | ||||
| 
 | ||||
| old.setDescription(data.getDescription()); | ||||
| 
 | ||||
| old.setActive (data.getActive()); | ||||
| 
 | ||||
| final Country test = Repository.save(old); | ||||
| 		data.setUpdatedBy(getUser().getUserId()); | ||||
|   return test;}  | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  public AppUser getUser() { | ||||
| 		AppUser user = userService.getLoggedInUser(); | ||||
| 		return user; | ||||
| 
 | ||||
| 	}} | ||||
| @ -0,0 +1,53 @@ | ||||
| package com.realnet.testdata.Services; | ||||
| import java.util.*; | ||||
| import com.realnet.testdata.Repository.CountryRepository; | ||||
| import com.realnet.testdata.Entity.Country; | ||||
| 
 | ||||
| import com.realnet.testdata.Entity.Country_ListFilter1; | ||||
| import java.util.List; | ||||
| 
 | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| 	import org.springframework.stereotype.Service; | ||||
| 
 | ||||
| @Service | ||||
|  public class Country_ListFilter1Service { | ||||
| @Autowired | ||||
| private CountryRepository Repository; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  public   List<Country_ListFilter1>   getlistbuilder() { | ||||
| 	List<Country> list= Repository.findAll(); | ||||
| 		ArrayList<Country_ListFilter1> l = new ArrayList<>(); | ||||
| 		for (Country data : list) { | ||||
| boolean isactive = data.getActive(); | ||||
| 
 | ||||
| 				if (isactive) {{	 | ||||
| Country_ListFilter1 dummy = new Country_ListFilter1(); | ||||
| 			dummy.setId(data.getId()); | ||||
|   dummy.setName(data.getName()); | ||||
|   dummy.setDescription(data.getDescription()); | ||||
| 	l.add(dummy); | ||||
| }}  | ||||
| } 		 | ||||
| return l;} | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  public   List<Country_ListFilter1>   getlistbuilderparam( ) { | ||||
| 	List<Country> list= Repository.findAll(); | ||||
| 		ArrayList<Country_ListFilter1> l = new ArrayList<>(); | ||||
| 		for (Country data : list) { | ||||
| boolean isactive = data.getActive(); | ||||
| 
 | ||||
| 				if (isactive) {{	 | ||||
| Country_ListFilter1 dummy = new Country_ListFilter1(); | ||||
| 			dummy.setId(data.getId()); | ||||
|   dummy.setName(data.getName()); | ||||
|   dummy.setDescription(data.getDescription()); | ||||
| 	l.add(dummy); | ||||
| }}  | ||||
| } 		 | ||||
| return l;} | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user