build_app

This commit is contained in:
risadmin_prod 2025-03-27 09:30:59 +00:00
parent cc3d04bfb1
commit 8bc7178f6c
13 changed files with 2653 additions and 1 deletions

View File

@ -69,6 +69,9 @@ public class BuilderService {
executeDump(true);
// ADD OTHER SERVICE
addCustomMenu( "Forma", "Transcations");
System.out.println("dashboard and menu inserted...");

View File

@ -0,0 +1,163 @@
package com.realnet.basicp1.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.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.http.ResponseEntity;
import org.springframework.data.domain.Pageable;
import org.springframework.beans.factory.annotation.*;
import com.realnet.basicp1.Entity.Forma;
import com.realnet.basicp1.Services.FormaService ;
@RequestMapping(value = "/Forma")
@CrossOrigin("*")
@RestController
public class FormaController {
@Autowired
private FormaService Service;
@Value("${projectPath}")
private String projectPath;
@PostMapping("/Forma")
public Forma Savedata(@RequestBody Forma data) {
Forma save = Service.Savedata(data) ;
System.out.println("data saved..." + save);
return save;
}
@PutMapping("/Forma/{id}")
public Forma update(@RequestBody Forma data,@PathVariable Integer id ) {
Forma update = Service.update(data,id);
System.out.println("data update..." + update);
return update;
}
// get all with pagination
@GetMapping("/Forma/getall/page")
public Page<Forma> getall(@RequestParam(value = "page", required = false) Integer page,
@RequestParam(value = "size", required = false) Integer size) {
Pageable paging = PageRequest.of(page, size);
Page<Forma> get = Service.getAllWithPagination(paging);
return get;
}
@GetMapping("/Forma")
public List<Forma> getdetails() {
List<Forma> get = Service.getdetails();
return get;
}
// get all without authentication
@GetMapping("/token/Forma")
public List<Forma> getallwioutsec() {
List<Forma> get = Service.getdetails();
return get;
}
@GetMapping("/Forma/{id}")
public Forma getdetailsbyId(@PathVariable Integer id ) {
Forma get = Service.getdetailsbyId(id);
return get;
}
@DeleteMapping("/Forma/{id}")
public void delete_by_id(@PathVariable Integer id ) {
Service.delete_by_id(id);
}
}

View File

@ -0,0 +1,70 @@
package com.realnet.basicp1.Entity;
import lombok.*;
import com.realnet.WhoColumn.Entity.Extension;
import javax.persistence.*;
import java.time.LocalDateTime;
import java.util.*;
@Entity
@Data
public class Forma extends Extension {
/**
*
*/
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
private String text_field;
private int number_field;
private String phone_number;
@Column(length = 2000)
private String paragraph_field;
private String password_field;
@Transient
private String confirmpassword_field;
@Column(length = 2000)
private String textarea;
private String date_field;
private String datetime_field;
private String email_field;
private boolean toggle_switch;
private String url_field;
}

View File

@ -0,0 +1,46 @@
package com.realnet.basicp1.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.basicp1.Entity.Forma;
@Repository
public interface FormaRepository extends JpaRepository<Forma, Integer> {
@Query(value = "select * from forma where created_by=?1", nativeQuery = true)
List<Forma> findAll(Long creayedBy);
@Query(value = "select * from forma where created_by=?1", nativeQuery = true)
Page<Forma> findAll(Pageable page, Long creayedBy);
}

View File

@ -0,0 +1,174 @@
package com.realnet.basicp1.Services;
import com.realnet.basicp1.Repository.FormaRepository;
import com.realnet.basicp1.Entity.Forma;import java.util.List;
import java.util.ArrayList;
import org.springframework.beans.factory.annotation.Autowired;
import com.realnet.SequenceGenerator.Service.SequenceService;
import com.realnet.Notification.Entity.NotificationService;
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.ResponseEntity;
import com.realnet.users.service1.AppUserServiceImpl;
import org.springframework.http.HttpStatus;
import com.realnet.users.entity1.AppUser;
import org.springframework.stereotype.Service;
@Service
public class FormaService {
@Autowired
private FormaRepository Repository;
@Autowired
private AppUserServiceImpl userService;
@Autowired
private RealmService realmService;
public Forma Savedata(Forma data) {
data.setUpdatedBy(getUser().getUserId());
data.setCreatedBy(getUser().getUserId());
data.setAccountId(getUser().getAccount().getAccount_id());
Forma save = Repository.save(data);
return save;
}
// get all with pagination
public Page<Forma> getAllWithPagination(Pageable page) {
return Repository.findAll(page, getUser().getUserId());
}
public List<Forma> getdetails() {
List<Realm> realm = realmService.findByUserId(getUser().getUserId());
List<Forma> all = Repository.findAll(getUser().getUserId());
return all ; }
public Forma getdetailsbyId(Integer id) {
return Repository.findById(id).get();
}
public void delete_by_id(Integer id) {
Repository.deleteById(id);
}
public Forma update(Forma data,Integer id) {
Forma old = Repository.findById(id).get();
old.setText_field(data.getText_field());
old.setNumber_field(data.getNumber_field());
old.setPhone_number(data.getPhone_number());
old.setParagraph_field(data.getParagraph_field());
old.setPassword_field(data.getPassword_field());
old.setTextarea(data.getTextarea());
old.setDate_field(data.getDate_field());
old.setDatetime_field(data.getDatetime_field());
old.setEmail_field(data.getEmail_field());
old.setToggle_switch (data.isToggle_switch());
old.setUrl_field(data.getUrl_field());
final Forma test = Repository.save(old);
data.setUpdatedBy(getUser().getUserId());
return test;}
public AppUser getUser() {
AppUser user = userService.getLoggedInUser();
return user;
}}

View File

@ -0,0 +1,2 @@
CREATE TABLE db.Forma(id BIGINT NOT NULL AUTO_INCREMENT, paragraph_field VARCHAR(400), textarea VARCHAR(400), toggle_switch VARCHAR(400), number_field int, text_field VARCHAR(400), datetime_field VARCHAR(400), phone_number VARCHAR(400), password_field VARCHAR(400), date_field Date, email_field VARCHAR(400), url_field VARCHAR(400), PRIMARY KEY (id));

View File

@ -0,0 +1,116 @@
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 formaApiService {
final String baseUrl = ApiConstants.baseUrl;
final BaseNetworkService _helper = NetworkApiService();
Future<List<Map<String, dynamic>>> getEntities() async {
try {
final response = await _helper.getGetApiResponse('$baseUrl/Forma/Forma');
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/Forma/Forma/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/Forma/Forma', 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/Forma/Forma/$entityId',
entity); print(entity);
} catch (e) {
throw Exception('Failed to update entity: $e');
}
}
Future<void> deleteEntity( int entityId) async {
try {
await _helper.getDeleteApiResponse('$baseUrl/Forma/Forma/$entityId');
} catch (e) {
throw Exception('Failed to delete entity: $e');
}
}
}

View File

@ -0,0 +1,530 @@
// 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 '../Forma_viewModel/Forma_view_model_screen.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:flutter_barcode_scanner/flutter_barcode_scanner.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 'dart:io';
import '../../../../Reuseable/reusable_text_field.dart';
class formaCreateEntityScreen extends StatefulWidget {
const formaCreateEntityScreen({super.key});
@override
_formaCreateEntityScreenState createState() => _formaCreateEntityScreenState();
}
class _formaCreateEntityScreenState extends State<formaCreateEntityScreen> {
final Map<String, dynamic> formData = {};
final _formKey = GlobalKey<FormState>();
final TextEditingController text_fieldController = TextEditingController();
final TextEditingController number_fieldController = TextEditingController();
final TextEditingController phone_numberController = TextEditingController();
final TextEditingController paragraph_fieldController = TextEditingController();
bool _passwordVisiblepassword_field = false;
bool _isPasswordValidpassword_field = true;
bool _doPasswordsMatchpassword_field = true;
String _passwordpassword_field = ''; // To store the first password
void _validatePasswordpassword_field(String password) {
setState(() {
_isPasswordValidpassword_field = password.isNotEmpty;
_passwordpassword_field = password; // Store the password for later comparison
_doPasswordsMatchpassword_field = true; // Reset match flag on new input
});
}
void _validateConfirmPasswordpassword_field(String confirmPassword) {
setState(() {
_doPasswordsMatchpassword_field = confirmPassword == _passwordpassword_field;
});
}
final TextEditingController textareaController = TextEditingController();
TextEditingController date_field = TextEditingController();
DateTime selectedDatedate_field = DateTime.now();
Future<void> _selectDatedate_field(BuildContext context) async {
final DateTime? picked = await showDatePicker(
context: context,
initialDate: selectedDatedate_field,
firstDate: DateTime(2000),
lastDate: DateTime(2101),
);
if (picked != null && picked != selectedDatedate_field) {
setState(() {
selectedDatedate_field = picked;
});
}
}
TextEditingController datetime_field = TextEditingController();
DateTime selectedDateTimedatetime_field = DateTime.now();
Future<void> _selectDateTimedatetime_field(BuildContext context) async {
final DateTime? picked = await showDatePicker(
context: context,
initialDate: selectedDateTimedatetime_field,
firstDate: DateTime(2000),
lastDate: DateTime(2101),
);
if (picked != null) {
final TimeOfDay? pickedTime = await showTimePicker(
context: context,
initialTime: TimeOfDay.fromDateTime(selectedDateTimedatetime_field),
);
print(pickedTime);
if (pickedTime != null) {
setState(() {
selectedDateTimedatetime_field = DateTime(
picked.year,
picked.month,
picked.day,
pickedTime.hour,
pickedTime.minute,
);
});
}
}
}
bool _isemail_fieldEmailValid = true;
void _validateemail_fieldEmail(String email) {
setState(() {
_isemail_fieldEmailValid = RegExp(r'^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$').hasMatch(email);
});
}
bool _isSwitchedtoggle_switch = false;
bool toggle_switch = false;
void _toggleSwitchtoggle_switch(bool value) {
setState(() {
_isSwitchedtoggle_switch = value;
});
}
bool _isUrlValidurl_field = true;
void _validateUrlurl_field(String url) {
setState(() {
_isUrlValidurl_field = Uri.parse(url).isAbsolute;
});
}
@override
void initState() {
super.initState();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: CustomAppBar(
height: getVerticalSize(49),
leadingWidth: 40,
leading: AppbarImage(
height: getSize(24),
width: getSize(24),
svgPath: ImageConstant.imgArrowleftBlueGray900,
margin: getMargin(left: 16, top: 12, bottom: 13),
onTap: () {
Navigator.pop(context);
}),
centerTitle: true,
title: AppbarTitle(text: "Create Forma"),
),
body:Consumer<FormaViewModelScreen>(
builder: (context, value, child) {
return SingleChildScrollView(
child: Padding(
padding: const EdgeInsets.all(16),
child: Form(
key: _formKey,
child: Column(
children: [
ReusableTextField(
controller: text_fieldController,
onSaved:(value) => formData['text_field'] = value ,
label:"Enter Text Field",
// ValidationProperties
),
SizedBox(height: 16),
ReusableTextField(
controller: number_fieldController,
onSaved:(value) => formData['number_field'] = value ,
label: "Enter Number Field",
keyboardType: TextInputType.number,
inputFormatters: [
FilteringTextInputFormatter.allow((RegExp(r'[0-9]'))),
],
// ValidationProperties
),
SizedBox(height: 16),
ReusableTextField(
onSaved:(value) => formData['phone_number'] = value ,
label: "Enter Phone Number",
keyboardType: TextInputType.number,
inputFormatters: [
FilteringTextInputFormatter.digitsOnly,
LengthLimitingTextInputFormatter(
10), // Limit input to 10 digits
],
validator: (value) {
if (value == null || value.isEmpty) {
return 'Please enter Phone Number';
}
if (value.length != 10) {
return 'Phone number must be exactly 10 digits';
}
return null;
},
),
ReusableTextField(
controller: paragraph_fieldController,
onSaved:(value) => formData['paragraph_field'] = value ,
label: "Enter Paragraph Field",
maxLines: 5,
),
TextFormField(
obscureText: !_passwordVisiblepassword_field,
decoration: InputDecoration(
labelText: 'Password Field',
suffixIcon: IconButton(
icon: Icon(
_passwordVisiblepassword_field
? Icons.visibility
: Icons.visibility_off,
),
onPressed: () {
setState(() {
_passwordVisiblepassword_field = !_passwordVisiblepassword_field;
});
},
),
errorText:
_isPasswordValidpassword_field ? null : 'Please enter a password',
border: OutlineInputBorder(),
),
onSaved: (value) => formData['password_field'] = value,
onChanged: _validatePasswordpassword_field,
),
const SizedBox(height: 16),
TextFormField(
obscureText: !_passwordVisiblepassword_field,
decoration: InputDecoration(
labelText: 'Confirm Password Field',
suffixIcon: IconButton(
icon: Icon(
_passwordVisiblepassword_field
? Icons.visibility
: Icons.visibility_off,
),
onPressed: () {
setState(() {
_passwordVisiblepassword_field = !_passwordVisiblepassword_field;
});
},
),
errorText:
_doPasswordsMatchpassword_field ? null : 'Passwords do not match',
border: OutlineInputBorder(),
),
onChanged: _validateConfirmPasswordpassword_field,
),
ReusableTextField(
controller: textareaController,
onSaved:(value) => formData['textarea'] = value ,
label: "Enter Textarea",
maxLines: 5,
// ValidationProperties
),
SizedBox(height: 16),
ReusableDatePickerField(
label:' Date Field', controller: date_field
,
onSaved: (value) => formData['date_field'] = value,),
const SizedBox(height: 16),
ReusableDateTimePickerField(label: 'Datetime Field', controller: datetime_field,
onSaved: (value) => formData['datetime_field'] = value,
),
const SizedBox(height: 16),
Padding(
padding: getPadding(top: 19),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.start,
children: [
Text("Email Field",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900),
CustomTextFormField(
hintText: "Enter Email Field",
errorText: _isemail_fieldEmailValid ? null : 'Please enter a valid email',
onsaved: (value) => formData['email_field'] = value,
onChanged: (value) {
_validateemail_fieldEmail(value);
},
margin: getMargin(top: 6))
])),
Switch(
value: _isSwitchedtoggle_switch,
onChanged: _toggleSwitchtoggle_switch,
activeColor: Colors.white,
activeTrackColor: Colors.green,
inactiveThumbColor: Colors.white,
inactiveTrackColor: Colors.red,
),
Padding(
padding: getPadding(top: 19),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.start,
children: [
Text("Url Field",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900),
CustomTextFormField(
hintText: "Enter Url Field",
errorText: _isUrlValidurl_field ? null : 'Please enter a valid URL',
keyboardType: TextInputType.url,
onsaved: (value) => formData['url_field'] = value,
onChanged: _validateUrlurl_field,
margin: getMargin(top: 6))
])),
SizedBox(height: 16),
const SizedBox(width: 8),
CustomButton(
height: getVerticalSize(50),
text: "Submit",
margin: getMargin(top: 24, bottom: 5),
onTap: () async {
if (_formKey.currentState!.validate()) {
_formKey.currentState!.save();
formData['toggle_switch'] = toggle_switch;
try {
print(formData);
Map<String, dynamic> createdEntity = await value.createEntity(formData);
Navigator.pop(context);
} catch (e) {
// ignore: use_build_context_synchronously
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: const Text('Error'),
content: Text('Failed to create Forma: $e'),
actions: [
TextButton(
child: const Text('OK'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
}
}
},
),
],
),
),
),
);
}));
}
}

View File

@ -0,0 +1,900 @@
// ignore_for_file: use_build_context_synchronously
import 'package:flutter/material.dart';
import 'package:intl/intl.dart';
import 'Forma_api_service.dart';
import 'Forma_create_entity_screen.dart';
import 'Forma_update_entity_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:fluttertoast/fluttertoast.dart';
class forma_entity_list_screen extends StatefulWidget {
static const String routeName = '/entity-list';
@override
_forma_entity_list_screenState createState() => _forma_entity_list_screenState();
}
class _forma_entity_list_screenState extends State<forma_entity_list_screen> {
final formaApiService apiService = formaApiService();
List<Map<String, dynamic>> entities = [];
List<Map<String, dynamic>> filteredEntities = [];
List<Map<String, dynamic>> serachEntities = [];
bool showCardView = true; // Add this variable to control the view mode
TextEditingController searchController = TextEditingController();
late stt.SpeechToText _speech;
bool isLoading = false; // Add this variable to track loading state
int currentPage = 0;
int pageSize = 10; // Adjust this based on your backend API
final ScrollController _scrollController = ScrollController();
@override
void initState() {
_speech = stt.SpeechToText();
super.initState();
fetchEntities();
_scrollController.addListener(_scrollListener);
fetchwithoutpaging();
}
Future<void> fetchwithoutpaging() async {
try {
final fetchedEntities =
await apiService.getEntities();
print('withoutpaging data is $fetchedEntities');
setState(() {
serachEntities = fetchedEntities; // Update only filteredEntities
});
print('Forma entity is .. $serachEntities');
} catch (e) {
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: const Text('Error'),
content: Text('Failed to fetch Forma: $e'),
actions: [
TextButton(
child: const Text('OK'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
}
}
Future<void> fetchEntities() async {
try {
setState(() {
isLoading = true;
});
final fetchedEntities =
await apiService.getAllWithPagination( currentPage, pageSize);
print('pagination data is $fetchedEntities');
setState(() {
entities.addAll(fetchedEntities); // Add new data to the existing list
filteredEntities = entities.toList(); // Update only filteredEntities
currentPage++;
});
print(' entity is .. $filteredEntities');
} catch (e) {
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: const Text('Error'),
content: Text('Failed to fetch Forma data: $e'),
actions: [
TextButton(
child: const Text('OK'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
} finally {
setState(() {
isLoading = false;
});
}
}
void _scrollListener() {
if (_scrollController.position.pixels ==
_scrollController.position.maxScrollExtent) {
fetchEntities();
}
}
Future<void> deleteEntity(Map<String, dynamic> entity) async {
try {
await apiService.deleteEntity(entity['id']);
setState(() {
entities.remove(entity);
});
} catch (e) {
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: const Text('Error'),
content: Text('Failed to delete entity: $e'),
actions: [
TextButton(
child: const Text('OK'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
}
}
void _searchEntities(String keyword) {
setState(() {
filteredEntities = serachEntities
.where((entity) =>
entity['text_field'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['number_field'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['phone_number'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['paragraph_field'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['password_field'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['textarea'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['date_field'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['datetime_field'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['email_field'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['toggle_switch'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
entity['url_field'].toString().toLowerCase().contains(keyword.toLowerCase())
).toList();
});
}
void _startListening() async {
if (!_speech.isListening) {
bool available = await _speech.initialize(
onStatus: (status) {
print('Speech recognition status: $status');
},
onError: (error) {
print('Speech recognition error: $error');
},
);
if (available) {
_speech.listen(
onResult: (result) {
if (result.finalResult) {
searchController.text = result.recognizedWords;
_searchEntities(result.recognizedWords);
}
},
);
}
}
}
void _stopListening() {
if (_speech.isListening) {
_speech.stop();
}
}
@override
void dispose() {
_speech.cancel();
super.dispose();
}
onTapArrowleft1(BuildContext context) {
Navigator.pop(context);
}
@override
Widget build(BuildContext context) {
return SafeArea(
child: Scaffold(
appBar: CustomAppBar(
height: getVerticalSize(49),
leadingWidth: 40,
leading: AppbarImage(
height: getSize(24),
width: getSize(24),
svgPath: ImageConstant.imgArrowleft,
margin: getMargin(left: 16, top: 12, bottom: 13),
onTap: () {
onTapArrowleft1(context);
}),
centerTitle: true,
title: AppbarTitle(text: " Forma"),
actions: [
Row(
children: [
Switch(
activeColor: Colors.greenAccent,
inactiveThumbColor: Colors.white,
value: showCardView,
onChanged: (value) {
setState(() {
showCardView = value;
});
},
),
],
), ],
),
body: RefreshIndicator(
onRefresh: () async {
currentPage = 1;
entities.clear();
await fetchEntities();
},
child: Column(
children: [
Padding(
padding: const EdgeInsets.all(8.0),
child: TextField(
controller: searchController,
onChanged: (value) {
_searchEntities(value);
},
decoration: InputDecoration(
hintText: 'Search...',
contentPadding: const EdgeInsets.symmetric(horizontal: 16.0),
filled: true,
fillColor: Colors.grey[200],
border: OutlineInputBorder(
borderRadius: BorderRadius.circular(10.0),
borderSide: BorderSide.none,
),
suffixIcon: IconButton(
icon: const Icon(Icons.mic),
onPressed: () {
_startListening();
},
),
),
),
),
Expanded(
child: ListView.builder(
itemCount: filteredEntities.length + (isLoading ? 1 : 0),
itemBuilder: (BuildContext context, int index) {
if (index < filteredEntities.length) {
final entity = filteredEntities[index];
return _buildListItem(entity);
} else {
// Display the loading indicator at the bottom when new data is loading
return const Padding(
padding: EdgeInsets.all(8.0),
child: Center(
child: CircularProgressIndicator(),
),
);
}
},
controller: _scrollController,
),
),
],
),
),
floatingActionButton: FloatingActionButton(
onPressed: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => formaCreateEntityScreen(),
),
).then((_) {
fetchEntities();
});
},
child: const Icon(Icons.add),
),
));
}
Widget _buildListItem(Map<String, dynamic> entity) {
return showCardView ? _buildCardView(entity) : _buildNormalView(entity);
}
// Function to build card view for a list item
Widget _buildCardView(Map<String, dynamic> entity) {
return Card(
elevation: 2,
margin: const EdgeInsets.symmetric(vertical: 8, horizontal: 16),
child: _buildNormalView(entity))
; }
// Function to build normal view for a list item
// Function to build normal view for a list item
Widget _buildNormalView(Map<String, dynamic> entity) {
final values = entity.values.elementAt(21) ?? 'Authsec';
return SizedBox(
width: double.maxFinite,
child: Container(
padding: getPadding(
left: 16,
top: 5,
right: 5,
bottom: 17,
),
decoration: AppDecoration.outlineGray70011.copyWith(
borderRadius: BorderRadiusStyle.roundedBorder6,
color: Colors.grey[100]),
child: Column(
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Padding(
padding: getPadding(
//right: 13,
),
child: Row(
children: [
Container(
width: MediaQuery.of(context).size.width * 0.30,
margin: getMargin(
left: 8,
top: 3,
bottom: 1,
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.start,
children: [
Text(
entity['id'].toString(),
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGreenSemiBold16,
),
],
),
),
const Spacer(),
PopupMenuButton<String>(
icon: const Icon(
Icons.more_vert,
color: Colors.black,
size: 16,
),
itemBuilder: (BuildContext context) {
return [
PopupMenuItem<String>(
value: 'edit',
child: Row(
children: [
const Icon(
Icons.edit,
size: 16, // Adjust the icon size as needed
),
const SizedBox(width: 8),
Text(
'Edit',
style: AppStyle
.txtGilroySemiBold16, // Adjust the text size as needed
),
],
),
),
PopupMenuItem<String>(
value: 'delete',
child: Row(
children: [
const Icon(
Icons.delete,
size: 16, // Adjust the icon size as needed
),
const SizedBox(width: 8),
Text(
'Delete',
style: AppStyle
.txtGilroySemiBold16, // Adjust the text size as needed
),
],
),
),
];
},
onSelected: (String value) {
if (value == 'edit') {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) =>
formaUpdateEntityScreen(entity: entity),
),
).then((_) {
fetchEntities();
});
} else if (value == 'delete') {
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: const Text('Confirm Deletion'),
content: const Text(
'Are you sure you want to delete?'),
actions: [
TextButton(
child: const Text('Cancel'),
onPressed: () {
Navigator.of(context).pop();
},
),
TextButton(
child: const Text('Delete'),
onPressed: () {
Navigator.of(context).pop();
deleteEntity(entity)
.then((value) => {fetchEntities()});
},
),
],
);
},
);
}
},
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Text Field : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['text_field'].toString() ?? 'No Text Field Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Number Field : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['number_field'].toString() ?? 'No Number Field Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Phone Number : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['phone_number'].toString() ?? 'No Phone Number Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Paragraph Field : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['paragraph_field'].toString() ?? 'No Paragraph Field Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Password Field : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['password_field'].toString() ?? 'No Password Field Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Textarea : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['textarea'].toString() ?? 'No Textarea Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Date Field : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['date_field'].toString() ?? 'No Date Field Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Datetime Field : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['datetime_field'].toString() ?? 'No Datetime Field Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Email Field : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['email_field'].toString() ?? 'No Email Field Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Toggle Switch : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['toggle_switch'].toString() ?? 'No Toggle Switch Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
Padding(
padding: getPadding(
top: 10,
),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"Url Field : ",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16,
),
Text(
entity['url_field'].toString() ?? 'No Url Field Available',
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle.txtGilroyMedium16Bluegray900,
),
],
),
),
],
),
),
);
}
Widget _buildLeadingIcon(String title) {
return CircleAvatar(
backgroundColor: Colors.blue,
child: Text(
title.isNotEmpty ? title[0].toUpperCase() : 'NA',
style: const TextStyle(fontSize: 16, fontWeight: FontWeight.bold),
),
);
}
void _showAdditionalFieldsDialog(
BuildContext context,
Map<String, dynamic> entity,
) {
final dateFormat = DateFormat('yyyy-MM-dd HH:mm:ss');
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: const Text('Additional Fields'),
content: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min,
children: [
Text(
'Created At: ${_formatTimestamp(entity['createdAt'], dateFormat)}'),
Text('Created By: ${entity['createdBy'] ?? 'N/A'}'),
Text('Updated By: ${entity['updatedBy'] ?? 'N/A'}'),
Text(
'Updated At: ${_formatTimestamp(entity['updatedAt'], dateFormat)}'),
Text('Account ID: ${entity['accountId'] ?? 'N/A'}'),
],
),
actions: [
TextButton(
child: const Text('Close'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
}
String _formatTimestamp(dynamic timestamp, DateFormat dateFormat) {
if (timestamp is int) {
final DateTime dateTime = DateTime.fromMillisecondsSinceEpoch(timestamp);
return dateFormat.format(dateTime);
} else if (timestamp is String) {
return timestamp;
} else {
return 'N/A';
}
}
}

View File

@ -0,0 +1,508 @@
// ignore_for_file: use_build_context_synchronously
import 'dart:convert';
import 'package:provider/provider.dart';
import '../Forma_viewModel/Forma_view_model_screen.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 'package:flutter/services.dart';
class formaUpdateEntityScreen extends StatefulWidget {
final Map<String, dynamic> entity;
formaUpdateEntityScreen({required this.entity});
@override
_formaUpdateEntityScreenState createState() => _formaUpdateEntityScreenState();
}
class _formaUpdateEntityScreenState extends State<formaUpdateEntityScreen> {
final _formKey = GlobalKey<FormState>();
bool _passwordVisiblepassword_field = false;
bool _isPasswordValidpassword_field = true;
bool _doPasswordsMatchpassword_field = true;
String _passwordpassword_field = ''; // To store the first password
void _validatePasswordpassword_field(String password) {
setState(() {
_isPasswordValidpassword_field = password.isNotEmpty;
_passwordpassword_field = password; // Store the password for later comparison
_doPasswordsMatchpassword_field = true; // Reset match flag on new input
});
}
void _validateConfirmPasswordpassword_field(String confirmPassword) {
setState(() {
_doPasswordsMatchpassword_field = confirmPassword == _passwordpassword_field;
});
}
TextEditingController date_field = TextEditingController();
DateTime selectedDatedate_field = DateTime.now();
Future<void> _selectDatedate_field(BuildContext context) async {
final DateTime? picked = await showDatePicker(
context: context,
initialDate: selectedDatedate_field,
firstDate: DateTime(2000),
lastDate: DateTime(2101),
);
print(picked);
if (picked != null && picked != selectedDatedate_field) {
setState(() {
selectedDatedate_field = picked;
});
}
}
DateTime selectedDateTimedatetime_field = DateTime.now();
TextEditingController datetime_field = TextEditingController();
Future<void> _selectDateTimedatetime_field(BuildContext context) async {
final DateTime? picked = await showDatePicker(
context: context,
initialDate: selectedDateTimedatetime_field,
firstDate: DateTime(2000),
lastDate: DateTime(2101),
);
if (picked != null) {
final TimeOfDay? pickedTime = await showTimePicker(
context: context,
initialTime: TimeOfDay.fromDateTime(selectedDateTimedatetime_field),
);
print(pickedTime);
if (pickedTime != null) {
setState(() {
selectedDateTimedatetime_field = DateTime(
picked.year,
picked.month,
picked.day,
pickedTime.hour,
pickedTime.minute,
);
});
}
}
}
bool _isemail_fieldEmailValid = true;
void _validateemail_fieldEmail(String email) {
setState(() {
_isemail_fieldEmailValid = RegExp(r'^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$').hasMatch(email);
});
}
bool istoggle_switch = false;
bool _isUrlValidurl_field = true;
void _validateUrlurl_field(String url) {
setState(() {
_isUrlValidurl_field= Uri.parse(url).isAbsolute;
});
}
@override
void initState() {
super.initState();
istoggle_switch = widget.entity['toggle_switch'] ?? false; // Set initial value
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: CustomAppBar(
height: getVerticalSize(49),
leadingWidth: 40,
leading: AppbarImage(
height: getSize(24),
width: getSize(24),
svgPath: ImageConstant.imgArrowleftBlueGray900,
margin: getMargin(left: 16, top: 12, bottom: 13),
onTap: () {
Navigator.pop(context);
}),
centerTitle: true,
title: AppbarTitle(text: "Update Forma"), actions: [
],
),
body: Consumer<FormaViewModelScreen>(builder: (context, value, child) {
return SingleChildScrollView(
child: Padding(
padding: const EdgeInsets.all(16),
child: Form(
key: _formKey,
child: Column(
children: [
ReusableTextField(
label: "Please Enter Text Field",
initialValue: widget.entity['text_field'] ?? '',
// ValidationProperties
onSaved: (value) => widget.entity['text_field'] = value,
),
SizedBox(height: 16),
ReusableTextField(
initialValue: widget.entity['number_field'].toString(),
onSaved: (value) => widget.entity['number_field']= value,
label: "Enter Number Field",
keyboardType: TextInputType.number,
inputFormatters: [
FilteringTextInputFormatter.allow((RegExp(r'[0-9]'))),
],
validator: (value) {
if (value == null || value.isEmpty) {
return 'Please enter a number';
}
return null;
},
),
ReusableTextField(
initialValue: widget.entity['phone_number'],
onSaved: (value) => widget.entity['phone_number'] = value,
label: "Enter Phone Number",
keyboardType: TextInputType.number,
inputFormatters: [
FilteringTextInputFormatter.digitsOnly,
LengthLimitingTextInputFormatter(
10), // Limit input to 10 digits
],
validator: (value) {
if (value == null || value.isEmpty) {
return 'Please enter Phone Number';
}
if (value.length != 10) {
return 'Phone number must be exactly 10 digits';
}
return null;
},
),
// }),
ReusableTextField(
initialValue: widget.entity['paragraph_field'],
onSaved: (value) => widget.entity['paragraph_field']= value,
label: "Enter Paragraph Field",
maxLines: 5,
),
TextFormField(
initialValue: widget.entity['password_field'],
obscureText: !_passwordVisiblepassword_field,
decoration: InputDecoration(
labelText: 'Password Field',
suffixIcon: IconButton(
icon: Icon(
_passwordVisiblepassword_field
? Icons.visibility
: Icons.visibility_off,
),
onPressed: () {
setState(() {
_passwordVisiblepassword_field = !_passwordVisiblepassword_field;
});
},
),
errorText:
_isPasswordValidpassword_field ? null : 'Please enter a password',
border: OutlineInputBorder(),
),
onSaved: (value) => widget.entity['password_field'] = value,
onChanged: _validatePasswordpassword_field,
),
const SizedBox(height: 16),
TextFormField(
obscureText: !_passwordVisiblepassword_field,
decoration: InputDecoration(
labelText: 'Confirm Password Field',
suffixIcon: IconButton(
icon: Icon(
_passwordVisiblepassword_field
? Icons.visibility
: Icons.visibility_off,
),
onPressed: () {
setState(() {
_passwordVisiblepassword_field = !_passwordVisiblepassword_field;
});
},
),
errorText:
_doPasswordsMatchpassword_field ? null : 'Passwords do not match',
border: OutlineInputBorder(),
),
onChanged: _validateConfirmPasswordpassword_field,
),
ReusableTextField(
initialValue: widget.entity['textarea'],
onSaved: (value) => widget.entity['textarea']= value,
label: "Enter Textarea",
maxLines: 5,
),
ReusableDatePickerField(label: 'Date Field', controller: date_field, initialDate: widget.entity['date_field'],
onSaved: (value) => widget.entity['date_field'] = value,),
ReusableDateTimePickerField(label:'Datetime Field', controller: datetime_field, initialDateTime:widget.entity['datetime_field'] ,
onSaved: (value) => widget.entity['datetime_field'] = value,),
Padding(
padding: getPadding(top: 19),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.start,
children: [
Text("Email Field",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle
.txtGilroyMedium16Bluegray900),
CustomTextFormField(
hintText: "Enter Email Field",
initialValue: widget.entity['email_field'],
keyboardType: TextInputType.url,
errorText: _isemail_fieldEmailValid ? null : 'Please enter a valid URL',
onChanged: _validateemail_fieldEmail,
// ValidationProperties
onsaved: (value) {
widget.entity['email_field'] = value;
},
margin: getMargin(top: 6))
])),
SizedBox(height: 16),
Row(
children: [
Switch(
value: istoggle_switch,
onChanged: (newValue) {
setState(() {
istoggle_switch = newValue;
});
},
activeColor: Colors.white,
activeTrackColor: Colors.green,
inactiveThumbColor: Colors.white,
inactiveTrackColor: Colors.red,
),
const SizedBox(width: 8),
const Text('Toggle Switch'),
],
),
Padding(
padding: getPadding(top: 19),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.start,
children: [
Text("Url Field",
overflow: TextOverflow.ellipsis,
textAlign: TextAlign.left,
style: AppStyle
.txtGilroyMedium16Bluegray900),
CustomTextFormField(
hintText: "Enter Url Field",
initialValue: widget.entity['url_field'],
keyboardType: TextInputType.url,
errorText: _isUrlValidurl_field ? null : 'Please enter a valid URL',
onChanged: _validateUrlurl_field,
// ValidationProperties
onsaved: (value) {
widget.entity['url_field'] = value;
},
margin: getMargin(top: 6))
])),
SizedBox(height: 16),
CustomButton(
height: getVerticalSize(50),
text: "Update",
margin: getMargin(top: 24, bottom: 5),
onTap: () async {
if (_formKey.currentState!.validate()) {
_formKey.currentState!.save();
widget.entity['toggle_switch'] = istoggle_switch;
try {
await value.updateEntity(
widget.entity[
'id'], // Assuming 'id' is the key in your entity map
widget.entity);
Navigator.pop(context);
} catch (e) {
// ignore: use_build_context_synchronously
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: const Text('Error'),
content:
Text('Failed to update Forma: $e'),
actions: [
TextButton(
child: const Text('OK'),
onPressed: () {
Navigator.of(context).pop();
},
),
],
);
},
);
}
}
},
),
],
),
),
),
);
}));
}
}

View File

@ -0,0 +1,61 @@
import '../../../../data/network/base_network_service.dart';
import '../../../../data/network/network_api_service.dart';
import '../../../../resources/api_constants.dart';
class FormaRepoScreen {
final String baseUrl = ApiConstants.baseUrl;
final BaseNetworkService _helper = NetworkApiService();
Future<dynamic> getEntities() async {
try {
final response =
await _helper.getGetApiResponse('$baseUrl/Forma/Forma');
return response;
} catch (e) {
throw Exception('Failed to get all entities: $e');
}
}
Future<dynamic> getAllWithPagination(int page, int size) async {
try {
final response = await _helper.getGetApiResponse(
'$baseUrl/Forma/Forma/getall/page?page=$page&size=$size');
return response;
} catch (e) {
throw Exception('Failed to get all without pagination: $e');
}
}
Future<dynamic> createEntity(Map<String, dynamic> entity) async {
try {
print("in post api$entity");
final response = await _helper.getPostApiResponse(
'$baseUrl/Forma/Forma', entity);
print(entity);
return response;
} catch (e) {
throw Exception('Failed to create entity: $e');
}
}
Future<void> updateEntity(int entityId, Map<String, dynamic> entity) async {
try {
await _helper.getPutApiResponse(
'$baseUrl/Forma/Forma/$entityId', entity);
print(entity);
} catch (e) {
throw Exception('Failed to update entity: $e');
}
}
Future<void> deleteEntity(int entityId) async {
try {
await _helper
.getDeleteApiResponse('$baseUrl/Forma/Forma/$entityId');
} catch (e) {
throw Exception('Failed to delete entity: $e');
}
}
}

View File

@ -0,0 +1,63 @@
import '../Forma_Repo/Forma_repo_screen.dart';
class FormaViewModelScreen {
final FormaRepoScreen repo = FormaRepoScreen();
Future<List<Map<String, dynamic>>> getEntities() async {
try {
final response = await repo.getEntities();
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 = repo.getAllWithPagination(page, size);
Map<String, dynamic> responseData = response as Map<String, dynamic>;
final entities =
(responseData['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 = repo.createEntity(entity);
print(entity);
// Assuming the response is a Map<String, dynamic>
Map<String, dynamic> responseData = response as Map<String, dynamic>;
return responseData;
} catch (e) {
throw Exception('Failed to create entity: $e');
}
}
Future<void> updateEntity(int entityId, Map<String, dynamic> entity) async {
try {
repo.updateEntity(entityId, entity);
print(entity);
} catch (e) {
throw Exception('Failed to update entity: $e');
}
}
Future<void> deleteEntity(int entityId) async {
try {
repo.deleteEntity(entityId);
} catch (e) {
throw Exception('Failed to delete entity: $e');
}
}
}

View File

@ -1,3 +1,5 @@
import '../../Entity/basicp1/Forma/FormaView/Forma_entity_list_screen.dart';
import 'package:base_project/utils/image_constant.dart';
import 'package:base_project/commans/widgets/custome_drawe_item.dart';
import 'package:base_project/resources/app_colors.dart';
@ -70,6 +72,20 @@ class MyCustomDrawer extends StatelessWidget {
),
// NEW MENU
DrawerItem(
color: AppColors.primary,
icon: Icons.chat_bubble,
title: 'Forma',
onTap: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => forma_entity_list_screen(),
),
);
},
),
DrawerItem(
icon: Icons.logout,
color: Colors.red,
@ -83,4 +99,4 @@ class MyCustomDrawer extends StatelessWidget {
),
);
}
}
}