bug was fixed in the holiday screen

This commit is contained in:
Daniah Ayad Al-sultani
2025-12-13 14:10:08 +03:00
parent 20b21fec2d
commit de48e56a41
2 changed files with 50 additions and 70 deletions

View File

@@ -8,8 +8,9 @@ class RequestService {
factory RequestService() => _instance;
RequestService._internal();
final List<LeaveRequest> _leaveRequests = [];
final List<AdvanceRequest> _advanceRequests = [];
// Initialize as empty lists (this should already be working, but let's make it explicit)
final List<LeaveRequest> _leaveRequests = <LeaveRequest>[];
final List<AdvanceRequest> _advanceRequests = <AdvanceRequest>[];
// Stream controllers to notify listeners of changes
final _leaveRequestsController = StreamController<List<LeaveRequest>>.broadcast();
@@ -21,29 +22,23 @@ class RequestService {
// Get all leave requests as a Future
Future<List<LeaveRequest>> getLeaveRequests() async {
print("Getting ${_leaveRequests.length} leave requests");
return List.from(_leaveRequests);
}
// Get all advance requests as a Future
Future<List<AdvanceRequest>> getAdvanceRequests() async {
print("Getting ${_advanceRequests.length} advance requests");
return List.from(_advanceRequests);
}
// Add a new leave request
Future<void> addLeaveRequest(LeaveRequest request) async {
_leaveRequests.add(request);
print("Added leave request: ${request.id}, total: ${_leaveRequests.length}");
// Notify listeners
_leaveRequestsController.add(List.from(_leaveRequests));
}
// Add a new advance request
Future<void> addAdvanceRequest(AdvanceRequest request) async {
_advanceRequests.add(request);
print("Added advance request: ${request.id}, total: ${_advanceRequests.length}");
// Notify listeners
_advanceRequestsController.add(List.from(_advanceRequests));
}
@@ -51,7 +46,6 @@ class RequestService {
Future<void> updateLeaveRequestStatus(String id, String status) async {
final index = _leaveRequests.indexWhere((request) => request.id == id);
if (index != -1) {
// Create a new request with the updated status
final updatedRequest = LeaveRequest(
id: _leaveRequests[index].id,
leaveType: _leaveRequests[index].leaveType,
@@ -62,13 +56,9 @@ class RequestService {
toTime: _leaveRequests[index].toTime,
reason: _leaveRequests[index].reason,
requestDate: _leaveRequests[index].requestDate,
status: status, // Updated status
status: status,
);
// Replace the old request with the updated one
_leaveRequests[index] = updatedRequest;
print("Updated leave request status: $id to $status");
// Notify listeners
_leaveRequestsController.add(List.from(_leaveRequests));
}
}
@@ -77,18 +67,13 @@ class RequestService {
Future<void> updateAdvanceRequestStatus(String id, String status) async {
final index = _advanceRequests.indexWhere((request) => request.id == id);
if (index != -1) {
// Create a new request with the updated status
final updatedRequest = AdvanceRequest(
id: _advanceRequests[index].id,
amount: _advanceRequests[index].amount,
reason: _advanceRequests[index].reason,
status: status, // Updated status
status: status,
);
// Replace the old request with the updated one
_advanceRequests[index] = updatedRequest;
print("Updated advance request status: $id to $status");
// Notify listeners
_advanceRequestsController.add(List.from(_advanceRequests));
}
}