|
|
|
@ -15,9 +15,8 @@ import 'package:test_sa/models/timer_model.dart';
|
|
|
|
|
import 'package:test_sa/models/user.dart';
|
|
|
|
|
|
|
|
|
|
class ServiceRequestsProvider extends ChangeNotifier {
|
|
|
|
|
|
|
|
|
|
// number of items call in each request
|
|
|
|
|
final pageItemNumber = 50;
|
|
|
|
|
final pageItemNumber = 10;
|
|
|
|
|
|
|
|
|
|
//reset provider data
|
|
|
|
|
void reset() {
|
|
|
|
@ -54,8 +53,7 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
@required User user,
|
|
|
|
|
@required int hospitalId,
|
|
|
|
|
}) async {
|
|
|
|
|
if(isLoading == true)
|
|
|
|
|
return -2;
|
|
|
|
|
if (isLoading == true) return -2;
|
|
|
|
|
isLoading = true;
|
|
|
|
|
if (serviceRequests == null) notifyListeners();
|
|
|
|
|
Response response;
|
|
|
|
@ -74,8 +72,7 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
// client's request was successfully received
|
|
|
|
|
List requestsListJson = json.decode(response.body)["data"];
|
|
|
|
|
List<ServiceRequest> serviceRequestsPage = requestsListJson.map(
|
|
|
|
|
(request) => ServiceRequest.fromJson(request)).toList();
|
|
|
|
|
List<ServiceRequest> serviceRequestsPage = requestsListJson.map((request) => ServiceRequest.fromJson(request)).toList();
|
|
|
|
|
serviceRequests ??= [];
|
|
|
|
|
serviceRequests.addAll(serviceRequestsPage);
|
|
|
|
|
if (serviceRequestsPage.length == pageItemNumber) {
|
|
|
|
@ -87,14 +84,12 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
isLoading = false;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
isLoading = false;
|
|
|
|
|
stateCode = -1;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<ServiceRequest> getSingleServiceRequest({
|
|
|
|
@ -111,15 +106,14 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
|
|
|
|
|
Response response;
|
|
|
|
|
try {
|
|
|
|
|
response = await get(
|
|
|
|
|
Uri.parse(
|
|
|
|
|
host+URLs.getSingleServiceRequest
|
|
|
|
|
+'?call_nid=$requestId'
|
|
|
|
|
'$userData',)
|
|
|
|
|
);
|
|
|
|
|
response = await get(Uri.parse(
|
|
|
|
|
host +
|
|
|
|
|
URLs.getSingleServiceRequest +
|
|
|
|
|
'?call_nid=$requestId'
|
|
|
|
|
'$userData',
|
|
|
|
|
));
|
|
|
|
|
} catch (error) {
|
|
|
|
|
throw(HttpStatusManger.getStatusMessage(
|
|
|
|
|
status: -1, subtitle: subtitle));
|
|
|
|
|
throw (HttpStatusManger.getStatusMessage(status: -1, subtitle: subtitle));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
@ -129,10 +123,8 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
List<ServiceRequest> _requests = jsonList.map((i) => ServiceRequest.fromJson(i)).toList();
|
|
|
|
|
return _requests[0];
|
|
|
|
|
} else {
|
|
|
|
|
throw(HttpStatusManger.getStatusMessage(
|
|
|
|
|
status: response.statusCode, subtitle: subtitle));
|
|
|
|
|
throw (HttpStatusManger.getStatusMessage(status: response.statusCode, subtitle: subtitle));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> createRequest({
|
|
|
|
@ -140,12 +132,8 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
@required User user,
|
|
|
|
|
@required ServiceRequest serviceRequest,
|
|
|
|
|
}) async {
|
|
|
|
|
|
|
|
|
|
var body = {
|
|
|
|
|
"callCreatedBy": {
|
|
|
|
|
"id":user.id,
|
|
|
|
|
"name":user.userName
|
|
|
|
|
},
|
|
|
|
|
"callCreatedBy": {"id": user.id, "name": user.userName},
|
|
|
|
|
"assets": serviceRequest.deviceId == null ? [] : [serviceRequest.deviceId],
|
|
|
|
|
"requestedDate": DateTime.now().toIso8601String(),
|
|
|
|
|
"requestedTime": DateTime.now().toIso8601String(),
|
|
|
|
@ -162,27 +150,16 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
}
|
|
|
|
|
Response response;
|
|
|
|
|
try {
|
|
|
|
|
response = await ApiManager.instance.post(
|
|
|
|
|
URLs.createRequest,
|
|
|
|
|
body: body
|
|
|
|
|
);
|
|
|
|
|
response = await ApiManager.instance.post(URLs.createRequest, body: body);
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
if(serviceRequests != null)
|
|
|
|
|
serviceRequests.insert(
|
|
|
|
|
0,
|
|
|
|
|
ServiceRequest.fromJson(
|
|
|
|
|
json.decode(utf8.decode(response.bodyBytes))[0]
|
|
|
|
|
)
|
|
|
|
|
);
|
|
|
|
|
if (serviceRequests != null) serviceRequests.insert(0, ServiceRequest.fromJson(json.decode(utf8.decode(response.bodyBytes))[0]));
|
|
|
|
|
notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> createIssueReport({
|
|
|
|
@ -201,15 +178,11 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> updateDate({
|
|
|
|
@ -230,8 +203,7 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
response = await post(
|
|
|
|
|
Uri.parse(
|
|
|
|
|
//host+
|
|
|
|
|
URLs.updateRequestDate
|
|
|
|
|
),
|
|
|
|
|
URLs.updateRequestDate),
|
|
|
|
|
body: body,
|
|
|
|
|
);
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
@ -240,11 +212,9 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> createServiceReport({
|
|
|
|
@ -254,15 +224,12 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
@required ServiceRequest request,
|
|
|
|
|
}) async {
|
|
|
|
|
Response response;
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
Map<String, dynamic> body = report.toMap(request);
|
|
|
|
|
// body["uid"] = user.id;
|
|
|
|
|
// body["token"] = user.token;
|
|
|
|
|
response = await ApiManager.instance.post(
|
|
|
|
|
URLs.createServiceReport,
|
|
|
|
|
body: body
|
|
|
|
|
);
|
|
|
|
|
response = await ApiManager.instance.post(URLs.createServiceReport, body: body);
|
|
|
|
|
print(response.body);
|
|
|
|
|
// response = await post(
|
|
|
|
|
// Uri.parse(
|
|
|
|
|
// host+URLs.createServiceReport),
|
|
|
|
@ -275,11 +242,9 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> createDuplicatedReport({
|
|
|
|
@ -296,10 +261,7 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
response = await get(
|
|
|
|
|
Uri.parse(
|
|
|
|
|
host+URLs.createDuplicatedReport
|
|
|
|
|
+"?nid=${request.id}"
|
|
|
|
|
+userData),
|
|
|
|
|
Uri.parse(host + URLs.createDuplicatedReport + "?nid=${request.id}" + userData),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
@ -309,12 +271,9 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> updateServiceReport({
|
|
|
|
@ -333,10 +292,7 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
Map<String, dynamic> body = report.toMap(request);
|
|
|
|
|
// body["uid"] = user.id;
|
|
|
|
|
// body["token"] = user.token;
|
|
|
|
|
response = await ApiManager.instance.put(
|
|
|
|
|
URLs.updateServiceReport,
|
|
|
|
|
body: body
|
|
|
|
|
);
|
|
|
|
|
response = await ApiManager.instance.put(URLs.updateServiceReport, body: body);
|
|
|
|
|
// response = await post(
|
|
|
|
|
// Uri.parse(
|
|
|
|
|
// host+URLs.updateServiceReport),
|
|
|
|
@ -349,11 +305,9 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> updateServiceReportTimer({
|
|
|
|
@ -373,8 +327,7 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
body["report_id"] = request.reportID;
|
|
|
|
|
try {
|
|
|
|
|
response = await post(
|
|
|
|
|
Uri.parse(
|
|
|
|
|
host+URLs.updateServiceReport),
|
|
|
|
|
Uri.parse(host + URLs.updateServiceReport),
|
|
|
|
|
body: body,
|
|
|
|
|
);
|
|
|
|
|
//stateCode = response.statusCode;
|
|
|
|
@ -384,12 +337,9 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
// notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<ServiceReport> getSingleServiceReport({
|
|
|
|
@ -398,29 +348,21 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
@required User user,
|
|
|
|
|
@required Subtitle subtitle,
|
|
|
|
|
}) async {
|
|
|
|
|
|
|
|
|
|
Response response;
|
|
|
|
|
try {
|
|
|
|
|
response = await ApiManager.instance.get(
|
|
|
|
|
URLs.getServiceReport + "?workOrderId=$reportId",
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
throw(HttpStatusManger.getStatusMessage(
|
|
|
|
|
status: -1, subtitle: subtitle));
|
|
|
|
|
throw (HttpStatusManger.getStatusMessage(status: -1, subtitle: subtitle));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
|
return ServiceReport.fromJson(
|
|
|
|
|
json.decode(response.body)["data"],reportId);
|
|
|
|
|
return ServiceReport.fromJson(json.decode(response.body)["data"], reportId);
|
|
|
|
|
} else {
|
|
|
|
|
throw(HttpStatusManger.getStatusMessage(
|
|
|
|
|
status: response.statusCode, subtitle: subtitle));
|
|
|
|
|
throw (HttpStatusManger.getStatusMessage(status: response.statusCode, subtitle: subtitle));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|