build_app
This commit is contained in:
parent
600693c5a1
commit
3a1c0bc279
|
@ -46,6 +46,9 @@ public class BuilderService {
|
||||||
public void callotherService() {
|
public void callotherService() {
|
||||||
|
|
||||||
// ADD OTHER SERVICE
|
// ADD OTHER SERVICE
|
||||||
|
addCustomMenu( "Test1", "Transcations");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,94 @@
|
||||||
|
package com.realnet.fluttertesting.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.data.domain.Pageable;
|
||||||
|
import org.springframework.beans.factory.annotation.*;
|
||||||
|
import com.realnet.fluttertesting.Entity.Test1;
|
||||||
|
import com.realnet.fluttertesting.Services.Test1Service ;
|
||||||
|
@RequestMapping(value = "/Test1")
|
||||||
|
@CrossOrigin("*")
|
||||||
|
@RestController
|
||||||
|
public class Test1Controller {
|
||||||
|
@Autowired
|
||||||
|
private Test1Service Service;
|
||||||
|
|
||||||
|
@Value("${projectPath}")
|
||||||
|
private String projectPath;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@PostMapping("/Test1")
|
||||||
|
public Test1 Savedata(@RequestBody Test1 data) {
|
||||||
|
Test1 save = Service.Savedata(data) ;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
System.out.println("data saved..." + save);
|
||||||
|
|
||||||
|
return save;
|
||||||
|
}
|
||||||
|
@PutMapping("/Test1/{id}")
|
||||||
|
public Test1 update(@RequestBody Test1 data,@PathVariable Integer id ) {
|
||||||
|
Test1 update = Service.update(data,id);
|
||||||
|
System.out.println("data update..." + update);
|
||||||
|
return update;
|
||||||
|
}
|
||||||
|
// get all with pagination
|
||||||
|
@GetMapping("/Test1/getall/page")
|
||||||
|
public Page<Test1> getall(@RequestParam(value = "page", required = false) Integer page,
|
||||||
|
@RequestParam(value = "size", required = false) Integer size) {
|
||||||
|
Pageable paging = PageRequest.of(page, size);
|
||||||
|
Page<Test1> get = Service.getAllWithPagination(paging);
|
||||||
|
|
||||||
|
return get;
|
||||||
|
|
||||||
|
}
|
||||||
|
@GetMapping("/Test1")
|
||||||
|
public List<Test1> getdetails() {
|
||||||
|
List<Test1> get = Service.getdetails();
|
||||||
|
return get;
|
||||||
|
}
|
||||||
|
// get all without authentication
|
||||||
|
|
||||||
|
@GetMapping("/token/Test1")
|
||||||
|
public List<Test1> getallwioutsec() {
|
||||||
|
List<Test1> get = Service.getdetails();
|
||||||
|
return get;
|
||||||
|
}
|
||||||
|
@GetMapping("/Test1/{id}")
|
||||||
|
public Test1 getdetailsbyId(@PathVariable Integer id ) {
|
||||||
|
Test1 get = Service.getdetailsbyId(id);
|
||||||
|
return get;
|
||||||
|
}
|
||||||
|
@DeleteMapping("/Test1/{id}")
|
||||||
|
public void delete_by_id(@PathVariable Integer id ) {
|
||||||
|
Service.delete_by_id(id);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
package com.realnet.fluttertesting.Entity;
|
||||||
|
import lombok.*;
|
||||||
|
import com.realnet.WhoColumn.Extension;
|
||||||
|
import javax.persistence.*;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@Data
|
||||||
|
public class Test1 extends Extension {
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@Id
|
||||||
|
@GeneratedValue(strategy = GenerationType.IDENTITY)
|
||||||
|
private Integer id;
|
||||||
|
|
||||||
|
private String sname;
|
||||||
|
|
||||||
|
private int rollnumber;
|
||||||
|
|
||||||
|
private String monumber;
|
||||||
|
|
||||||
|
|
||||||
|
@Column(length = 2000)
|
||||||
|
private String parag;
|
||||||
|
|
||||||
|
@Column(length = 2000)
|
||||||
|
private String address;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,25 @@
|
||||||
|
package com.realnet.fluttertesting.Repository;
|
||||||
|
|
||||||
|
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
import com.realnet.fluttertesting.Entity.Test1;
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
public interface Test1Repository extends JpaRepository<Test1, Integer> {
|
||||||
|
}
|
|
@ -0,0 +1,92 @@
|
||||||
|
package com.realnet.fluttertesting.Services;
|
||||||
|
import com.realnet.fluttertesting.Repository.Test1Repository;
|
||||||
|
import com.realnet.fluttertesting.Entity.Test1;import java.util.List;
|
||||||
|
|
||||||
|
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 org.springframework.data.domain.Pageable;
|
||||||
|
import com.realnet.users.service1.AppUserServiceImpl;
|
||||||
|
import com.realnet.users.entity1.AppUser;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
@Service
|
||||||
|
public class Test1Service {
|
||||||
|
@Autowired
|
||||||
|
private Test1Repository Repository;
|
||||||
|
@Autowired
|
||||||
|
private AppUserServiceImpl userService;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public Test1 Savedata(Test1 data) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Test1 save = Repository.save(data);
|
||||||
|
return save;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// get all with pagination
|
||||||
|
public Page<Test1> getAllWithPagination(Pageable page) {
|
||||||
|
return Repository.findAll(page);
|
||||||
|
}
|
||||||
|
public List<Test1> getdetails() {
|
||||||
|
return (List<Test1>) Repository.findAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public Test1 getdetailsbyId(Integer id) {
|
||||||
|
return Repository.findById(id).get();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void delete_by_id(Integer id) {
|
||||||
|
Repository.deleteById(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public Test1 update(Test1 data,Integer id) {
|
||||||
|
Test1 old = Repository.findById(id).get();
|
||||||
|
old.setSname(data.getSname());
|
||||||
|
|
||||||
|
old.setRollnumber(data.getRollnumber());
|
||||||
|
|
||||||
|
old.setMonumber(data.getMonumber());
|
||||||
|
|
||||||
|
old.setParag(data.getParag());
|
||||||
|
|
||||||
|
old.setAddress(data.getAddress());
|
||||||
|
|
||||||
|
final Test1 test = Repository.save(old);
|
||||||
|
return test;}
|
||||||
|
public AppUser getUser() {
|
||||||
|
AppUser user = userService.getLoggedInUser();
|
||||||
|
return user;
|
||||||
|
|
||||||
|
}}
|
|
@ -0,0 +1,2 @@
|
||||||
|
CREATE TABLE db.Test1(id BIGINT NOT NULL AUTO_INCREMENT, Parag VARCHAR(400), address VARCHAR(400), sName VARCHAR(400), rollNumber VARCHAR(400), moNumber VARCHAR(400), PRIMARY KEY (id));
|
||||||
|
|
|
@ -0,0 +1,96 @@
|
||||||
|
import 'package:dio/dio.dart';
|
||||||
|
import 'package:http_parser/http_parser.dart';
|
||||||
|
import 'dart:typed_data';
|
||||||
|
import 'package:image_picker/image_picker.dart';
|
||||||
|
import '../../../resources/api_constants.dart';
|
||||||
|
import '../../../helpers/api_helper/api_helper.dart';
|
||||||
|
import 'dart:convert';
|
||||||
|
import 'dart:typed_data';
|
||||||
|
class test1ApiService {
|
||||||
|
final String baseUrl = ApiConstants.baseUrl;
|
||||||
|
final Dio dio = Dio();
|
||||||
|
final ApiHelper _helper = ApiHelper();
|
||||||
|
|
||||||
|
|
||||||
|
Future<List<Map<String, dynamic>>> getEntities() async {
|
||||||
|
|
||||||
|
try {
|
||||||
|
final response = await _helper.get('$baseUrl/Test1/Test1');
|
||||||
|
final entities = (response.data as List).cast<Map<String, dynamic>>();
|
||||||
|
return entities;
|
||||||
|
} catch (e) {
|
||||||
|
throw Exception('Failed to get all entities: $e');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Future<List<Map<String, dynamic>>> getAllWithPagination(
|
||||||
|
String token, int page, int Size) async {
|
||||||
|
try {
|
||||||
|
dio.options.headers['Authorization'] = 'Bearer $token';
|
||||||
|
final response = await dio
|
||||||
|
.get('$baseUrl/Test1/Test1/getall/page?page=$page&size=$Size');
|
||||||
|
final entities =
|
||||||
|
(response.data['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(
|
||||||
|
String token, Map<String, dynamic> entity) async {
|
||||||
|
try {
|
||||||
|
print("in post api$entity");
|
||||||
|
dio.options.headers['Authorization'] = 'Bearer $token';
|
||||||
|
final response =
|
||||||
|
await dio.post('$baseUrl/Test1/Test1', data: entity);
|
||||||
|
|
||||||
|
print(entity);
|
||||||
|
|
||||||
|
// Assuming the response is a Map<String, dynamic>
|
||||||
|
Map<String, dynamic> responseData = response.data;
|
||||||
|
|
||||||
|
return responseData;
|
||||||
|
} catch (e) {
|
||||||
|
throw Exception('Failed to create entity: $e');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Future<void> updateEntity(String token, int entityId, Map<String, dynamic> entity) async {
|
||||||
|
try {
|
||||||
|
dio.options.headers['Authorization'] = 'Bearer $token';
|
||||||
|
await dio.put('$baseUrl/Test1/Test1/$entityId',
|
||||||
|
data: entity); print(entity);
|
||||||
|
|
||||||
|
} catch (e) {
|
||||||
|
throw Exception('Failed to update entity: $e');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> deleteEntity(String token, int entityId) async {
|
||||||
|
try {
|
||||||
|
dio.options.headers['Authorization'] = 'Bearer $token';
|
||||||
|
await dio.delete('$baseUrl/Test1/Test1/$entityId');
|
||||||
|
} catch (e) {
|
||||||
|
throw Exception('Failed to delete entity: $e');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,309 @@
|
||||||
|
// 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 '../../../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 'Test1_api_service.dart';
|
||||||
|
import '../../../providers/token_manager.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 'dart:io';
|
||||||
|
import '../../../Reuseable/reusable_text_field.dart';
|
||||||
|
import 'package:google_mlkit_text_recognition/google_mlkit_text_recognition.dart';
|
||||||
|
class test1CreateEntityScreen extends StatefulWidget {
|
||||||
|
const test1CreateEntityScreen({super.key});
|
||||||
|
|
||||||
|
@override
|
||||||
|
_test1CreateEntityScreenState createState() => _test1CreateEntityScreenState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _test1CreateEntityScreenState extends State<test1CreateEntityScreen> {
|
||||||
|
final test1ApiService apiService = test1ApiService();
|
||||||
|
final Map<String, dynamic> formData = {};
|
||||||
|
final _formKey = GlobalKey<FormState>();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> performOCR() async {
|
||||||
|
try {
|
||||||
|
final ImagePicker _picker = ImagePicker();
|
||||||
|
|
||||||
|
// Show options for gallery or camera using a dialog
|
||||||
|
await showDialog(
|
||||||
|
context: context,
|
||||||
|
builder: (BuildContext context) {
|
||||||
|
return AlertDialog(
|
||||||
|
title: const Text('Select Image Source'),
|
||||||
|
content: SingleChildScrollView(
|
||||||
|
child: ListBody(
|
||||||
|
children: <Widget>[
|
||||||
|
GestureDetector(
|
||||||
|
child: const Text('Gallery'),
|
||||||
|
onTap: () async {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
final XFile? image =
|
||||||
|
await _picker.pickImage(source: ImageSource.gallery);
|
||||||
|
processImage(image);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
const SizedBox(height: 20),
|
||||||
|
GestureDetector(
|
||||||
|
child: const Text('Camera'),
|
||||||
|
onTap: () async {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
final XFile? image =
|
||||||
|
await _picker.pickImage(source: ImageSource.camera);
|
||||||
|
processImage(image);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
} catch (e) {
|
||||||
|
print("OCR Error: $e");
|
||||||
|
// Handle OCR errors here
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
final textRecognizer = TextRecognizer();
|
||||||
|
|
||||||
|
void processImage(XFile? image) async {
|
||||||
|
if (image == null) return; // User canceled image picking
|
||||||
|
|
||||||
|
final file = File(image.path);
|
||||||
|
|
||||||
|
final inputImage = InputImage.fromFile(file);
|
||||||
|
final recognizedText = await textRecognizer.processImage(inputImage);
|
||||||
|
|
||||||
|
StringBuffer extractedTextBuffer = StringBuffer();
|
||||||
|
for (TextBlock block in recognizedText.blocks) {
|
||||||
|
for (TextLine line in block.lines) {
|
||||||
|
extractedTextBuffer.write(line.text + ' ');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
textRecognizer.close();
|
||||||
|
|
||||||
|
String extractedText = extractedTextBuffer.toString().trim();
|
||||||
|
|
||||||
|
// Now you can process the extracted text as needed
|
||||||
|
// For example, you can update the corresponding TextFormField with the extracted text
|
||||||
|
setState(() {
|
||||||
|
formData['description'] = extractedText;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@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 Test1"),
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
),
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.all(16),
|
||||||
|
child: Form(
|
||||||
|
key: _formKey,
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
ReusableTextField(
|
||||||
|
onSaved:(value) => formData['sname'] = value ,
|
||||||
|
label:"Enter sName",
|
||||||
|
// ValidationProperties
|
||||||
|
),
|
||||||
|
|
||||||
|
SizedBox(height: 16),
|
||||||
|
|
||||||
|
|
||||||
|
ReusableTextField(
|
||||||
|
onSaved:(value) => formData['rollnumber'] = value ,
|
||||||
|
label: "Enter rollNumber",
|
||||||
|
keyboardType: TextInputType.number,
|
||||||
|
inputFormatters: [
|
||||||
|
FilteringTextInputFormatter.allow((RegExp(r'[0-9]'))),
|
||||||
|
],
|
||||||
|
// ValidationProperties
|
||||||
|
),
|
||||||
|
|
||||||
|
SizedBox(height: 16),
|
||||||
|
|
||||||
|
ReusableTextField(
|
||||||
|
onSaved:(value) => formData['monumber'] = value ,
|
||||||
|
label: "Enter moNumber",
|
||||||
|
keyboardType: TextInputType.number,
|
||||||
|
inputFormatters: [
|
||||||
|
FilteringTextInputFormatter.digitsOnly,
|
||||||
|
],
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null || value.isEmpty) {
|
||||||
|
return 'Please enter a number';
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
},
|
||||||
|
),
|
||||||
|
|
||||||
|
ReusableTextField(
|
||||||
|
onSaved:(value) => formData['parag'] = value ,
|
||||||
|
label: "Enter Parag",
|
||||||
|
maxLines: 5,
|
||||||
|
|
||||||
|
),
|
||||||
|
|
||||||
|
ReusableTextField(
|
||||||
|
onSaved:(value) => formData['address'] = value ,
|
||||||
|
label: "Enter address",
|
||||||
|
maxLines: 5,
|
||||||
|
// ValidationProperties
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
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();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
final token = await TokenManager.getToken();
|
||||||
|
try {
|
||||||
|
print(formData);
|
||||||
|
Map<String, dynamic> createdEntity = await apiService.createEntity(token!, 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 Test1: $e'),
|
||||||
|
actions: [
|
||||||
|
TextButton(
|
||||||
|
child: const Text('OK'),
|
||||||
|
onPressed: () {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,706 @@
|
||||||
|
// ignore_for_file: use_build_context_synchronously
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:intl/intl.dart';
|
||||||
|
import 'Test1_api_service.dart';
|
||||||
|
import 'Test1_create_entity_screen.dart';
|
||||||
|
import 'Test1_update_entity_screen.dart';
|
||||||
|
import '../../../providers/token_manager.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 test1_entity_list_screen extends StatefulWidget {
|
||||||
|
static const String routeName = '/entity-list';
|
||||||
|
|
||||||
|
@override
|
||||||
|
_test1_entity_list_screenState createState() => _test1_entity_list_screenState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _test1_entity_list_screenState extends State<test1_entity_list_screen> {
|
||||||
|
|
||||||
|
final test1ApiService apiService = test1ApiService();
|
||||||
|
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 token = await TokenManager.getToken();
|
||||||
|
if (token != null) {
|
||||||
|
final fetchedEntities =
|
||||||
|
await apiService.getEntities();
|
||||||
|
print('withoutpaging data is $fetchedEntities');
|
||||||
|
setState(() {
|
||||||
|
serachEntities = fetchedEntities; // Update only filteredEntities
|
||||||
|
});
|
||||||
|
print('Test1 entity is .. $serachEntities');
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
showDialog(
|
||||||
|
context: context,
|
||||||
|
builder: (BuildContext context) {
|
||||||
|
return AlertDialog(
|
||||||
|
title: const Text('Error'),
|
||||||
|
content: Text('Failed to fetch Test1: $e'),
|
||||||
|
actions: [
|
||||||
|
TextButton(
|
||||||
|
child: const Text('OK'),
|
||||||
|
onPressed: () {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Future<void> fetchEntities() async {
|
||||||
|
try {
|
||||||
|
setState(() {
|
||||||
|
isLoading = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
final token = await TokenManager.getToken();
|
||||||
|
if (token != null) {
|
||||||
|
|
||||||
|
final fetchedEntities =
|
||||||
|
await apiService.getAllWithPagination(token, 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 Test1 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 {
|
||||||
|
final token = await TokenManager.getToken();
|
||||||
|
await apiService.deleteEntity(token!, 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['sname'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
entity['rollnumber'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
entity['monumber'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
entity['parag'].toString().toLowerCase().contains(keyword.toLowerCase()) ||
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
entity['address'].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: " Test1"),
|
||||||
|
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) => test1CreateEntityScreen(),
|
||||||
|
),
|
||||||
|
).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) =>
|
||||||
|
test1UpdateEntityScreen(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(
|
||||||
|
"sName : ",
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16,
|
||||||
|
),
|
||||||
|
Text(
|
||||||
|
entity['sname'] ?? 'No sName Available',
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16Bluegray900,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
Padding(
|
||||||
|
padding: getPadding(
|
||||||
|
top: 10,
|
||||||
|
),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
"rollNumber : ",
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16,
|
||||||
|
),
|
||||||
|
Text(
|
||||||
|
entity['rollnumber'].toString() ?? 'No rollNumber Available',
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16Bluegray900,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
Padding(
|
||||||
|
padding: getPadding(
|
||||||
|
top: 10,
|
||||||
|
),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
"moNumber : ",
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16,
|
||||||
|
),
|
||||||
|
Text(
|
||||||
|
entity['monumber'] ?? 'No moNumber Available',
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16Bluegray900,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
Padding(
|
||||||
|
padding: getPadding(
|
||||||
|
top: 10,
|
||||||
|
),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
"Parag : ",
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16,
|
||||||
|
),
|
||||||
|
Text(
|
||||||
|
entity['parag'] ?? 'No Parag Available',
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16Bluegray900,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
Padding(
|
||||||
|
padding: getPadding(
|
||||||
|
top: 10,
|
||||||
|
),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
"address : ",
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style: AppStyle.txtGilroyMedium16,
|
||||||
|
),
|
||||||
|
Text(
|
||||||
|
entity['address'] ?? 'No address 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';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,229 @@
|
||||||
|
// ignore_for_file: use_build_context_synchronously
|
||||||
|
import 'dart:convert';
|
||||||
|
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 'Test1_api_service.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 '../../../providers/token_manager.dart';
|
||||||
|
|
||||||
|
import 'package:flutter/services.dart';
|
||||||
|
class test1UpdateEntityScreen extends StatefulWidget {
|
||||||
|
final Map<String, dynamic> entity;
|
||||||
|
|
||||||
|
|
||||||
|
test1UpdateEntityScreen({required this.entity});
|
||||||
|
|
||||||
|
@override
|
||||||
|
_test1UpdateEntityScreenState createState() => _test1UpdateEntityScreenState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _test1UpdateEntityScreenState extends State<test1UpdateEntityScreen> {
|
||||||
|
final test1ApiService apiService = test1ApiService();
|
||||||
|
final _formKey = GlobalKey<FormState>();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@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: "Update Test1")),
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.all(16),
|
||||||
|
child: Form(
|
||||||
|
key: _formKey,
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
Padding(
|
||||||
|
padding: getPadding(top: 18),
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Text("sName",
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
textAlign: TextAlign.left,
|
||||||
|
style:
|
||||||
|
AppStyle.txtGilroyMedium16Bluegray900),
|
||||||
|
CustomTextFormField(
|
||||||
|
focusNode: FocusNode(),
|
||||||
|
hintText: "Please Enter sName",
|
||||||
|
initialValue: widget.entity['sname'],
|
||||||
|
|
||||||
|
// ValidationProperties
|
||||||
|
onsaved: (value) => widget.entity['sname'] = value,
|
||||||
|
margin: getMargin(top: 7))
|
||||||
|
]),
|
||||||
|
),
|
||||||
|
|
||||||
|
ReusableTextField(
|
||||||
|
initialValue: widget.entity['rollnumber'],
|
||||||
|
onSaved: (value) => widget.entity['rollnumber']= value,
|
||||||
|
label: "Enter rollNumber",
|
||||||
|
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['monumber'],
|
||||||
|
onSaved: (value) => widget.entity['monumber'] = value,
|
||||||
|
label: "Enter moNumber",
|
||||||
|
keyboardType: TextInputType.number,
|
||||||
|
inputFormatters: [
|
||||||
|
FilteringTextInputFormatter.digitsOnly,
|
||||||
|
],
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null || value.isEmpty) {
|
||||||
|
return 'Please enter a number';
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
},
|
||||||
|
),
|
||||||
|
|
||||||
|
// }),
|
||||||
|
ReusableTextField(
|
||||||
|
initialValue: widget.entity['parag'],
|
||||||
|
onSaved: (value) => widget.entity['parag']= value,
|
||||||
|
label: "Enter Parag",
|
||||||
|
maxLines: 5,
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
ReusableTextField(
|
||||||
|
initialValue: widget.entity['address'],
|
||||||
|
onSaved: (value) => widget.entity['address']= value,
|
||||||
|
label: "Enter address",
|
||||||
|
maxLines: 5,
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
CustomButton(
|
||||||
|
height: getVerticalSize(50),
|
||||||
|
text: "Update",
|
||||||
|
margin: getMargin(top: 24, bottom: 5),
|
||||||
|
onTap: () async {
|
||||||
|
if (_formKey.currentState!.validate()) {
|
||||||
|
_formKey.currentState!.save();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
final token = await TokenManager.getToken();
|
||||||
|
try {
|
||||||
|
await apiService.updateEntity(
|
||||||
|
token!,
|
||||||
|
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 Test1: $e'),
|
||||||
|
actions: [
|
||||||
|
TextButton(
|
||||||
|
child: const Text('OK'),
|
||||||
|
onPressed: () {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,3 +1,5 @@
|
||||||
|
import '../../Entity/fluttertesting/Test1/Test1_entity_list_screen.dart';
|
||||||
|
|
||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
import 'package:base_project/core/app_export.dart';
|
import 'package:base_project/core/app_export.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
@ -140,6 +142,21 @@ class _CustomDrawerState extends State<CustomDrawer> {
|
||||||
SizedBox(height: 18.v),
|
SizedBox(height: 18.v),
|
||||||
|
|
||||||
// NEW MENU
|
// NEW MENU
|
||||||
|
_myButton(
|
||||||
|
context,
|
||||||
|
"Test1",
|
||||||
|
() {
|
||||||
|
Navigator.push(
|
||||||
|
context,
|
||||||
|
MaterialPageRoute(
|
||||||
|
builder: (context) => test1_entity_list_screen(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
false,
|
||||||
|
),
|
||||||
|
SizedBox(height: 18.v),
|
||||||
|
|
||||||
|
|
||||||
_myButton(
|
_myButton(
|
||||||
context,
|
context,
|
||||||
|
|
Loading…
Reference in New Issue