bug was fixed in the holiday screen
This commit is contained in:
@@ -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));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user