|
|
|
@ -2,24 +2,24 @@ import 'dart:convert';
|
|
|
|
|
|
|
|
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
import 'package:http/http.dart';
|
|
|
|
import 'package:http/http.dart';
|
|
|
|
import 'package:test_sa/controllers/api_routes/urls.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/controllers/http_status_manger/http_status_manger.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/models/issue.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/models/lookup.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/models/service_report.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/models/service_request/service_request.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/models/service_request/service_request_search.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/models/subtitle.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/models/timer_model.dart';
|
|
|
|
|
|
|
|
import 'package:test_sa/models/user.dart';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import '../../../models/issue.dart';
|
|
|
|
|
|
|
|
import '../../../models/lookup.dart';
|
|
|
|
|
|
|
|
import '../../../models/service_report.dart';
|
|
|
|
|
|
|
|
import '../../../models/service_request/service_request.dart';
|
|
|
|
|
|
|
|
import '../../../models/service_request/service_request_search.dart';
|
|
|
|
|
|
|
|
import '../../../models/subtitle.dart';
|
|
|
|
|
|
|
|
import '../../../models/timer_model.dart';
|
|
|
|
|
|
|
|
import '../../../models/user.dart';
|
|
|
|
|
|
|
|
import '../../api_routes/urls.dart';
|
|
|
|
|
|
|
|
import '../../http_status_manger/http_status_manger.dart';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ServiceRequestsProvider extends ChangeNotifier {
|
|
|
|
// number of items call in each request
|
|
|
|
// number of items call in each request
|
|
|
|
final pageItemNumber = 50;
|
|
|
|
final pageItemNumber = 50;
|
|
|
|
|
|
|
|
|
|
|
|
//reset provider data
|
|
|
|
//reset provider data
|
|
|
|
void reset(){
|
|
|
|
void reset() {
|
|
|
|
serviceRequests = null;
|
|
|
|
serviceRequests = null;
|
|
|
|
nextPage = true;
|
|
|
|
nextPage = true;
|
|
|
|
stateCode = null;
|
|
|
|
stateCode = null;
|
|
|
|
@ -28,121 +28,108 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
// state code of current request to defied error message
|
|
|
|
// state code of current request to defied error message
|
|
|
|
// like 400 customer request failed
|
|
|
|
// like 400 customer request failed
|
|
|
|
// 500 service not available
|
|
|
|
// 500 service not available
|
|
|
|
int stateCode;
|
|
|
|
int? stateCode;
|
|
|
|
|
|
|
|
|
|
|
|
// true if there is next page in product list and false if not
|
|
|
|
// true if there is next page in product list and false if not
|
|
|
|
bool nextPage = true;
|
|
|
|
bool? nextPage = true;
|
|
|
|
|
|
|
|
|
|
|
|
// list of user requests
|
|
|
|
// list of user requests
|
|
|
|
List<ServiceRequest> serviceRequests;
|
|
|
|
List<ServiceRequest>? serviceRequests;
|
|
|
|
|
|
|
|
|
|
|
|
// when requests in-process _loading = true
|
|
|
|
// when requests in-process _loading = true
|
|
|
|
// done _loading = true
|
|
|
|
// done _loading = true
|
|
|
|
// failed _loading = false
|
|
|
|
// failed _loading = false
|
|
|
|
bool isLoading;
|
|
|
|
bool? isLoading;
|
|
|
|
|
|
|
|
|
|
|
|
ServiceRequestSearch search = ServiceRequestSearch();
|
|
|
|
ServiceRequestSearch? search = ServiceRequestSearch();
|
|
|
|
|
|
|
|
|
|
|
|
/// return -2 if request in progress
|
|
|
|
/// return -2 if request in progress
|
|
|
|
/// return -1 if error happen when sending request
|
|
|
|
/// return -1 if error happen when sending request
|
|
|
|
/// return state code if request complete may be 200, 404 or 403
|
|
|
|
/// return state code if request complete may be 200, 404 or 403
|
|
|
|
/// for more details check http state manager
|
|
|
|
/// for more details check http state manager
|
|
|
|
/// lib\controllers\http_status_manger\http_status_manger.dart
|
|
|
|
/// lib\controllers\http_status_manger\http_status_manger.dart
|
|
|
|
Future<int> getRequests ({
|
|
|
|
Future<int> getRequests({
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required String hospitalId,
|
|
|
|
required String? hospitalId,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
if(isLoading == true)
|
|
|
|
if (isLoading == true) {
|
|
|
|
return -2;
|
|
|
|
return -2;
|
|
|
|
|
|
|
|
}
|
|
|
|
isLoading = true;
|
|
|
|
isLoading = true;
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
response = await get(
|
|
|
|
response = await get(
|
|
|
|
Uri.parse(
|
|
|
|
Uri.parse(
|
|
|
|
host+URLs.getServiceRequests
|
|
|
|
"$host${URLs.getServiceRequests}?uid=${user.id}${hospitalId == null ? "" : "&client_nid=$hospitalId"}&token=${user.token}&page=${(serviceRequests?.length ?? 0) ~/ pageItemNumber}${search?.toSearchString()}",
|
|
|
|
+"?uid=${user.id}"
|
|
|
|
),
|
|
|
|
+(hospitalId == null? "" :"&client_nid=$hospitalId")
|
|
|
|
headers: {"Content-Type": "application/json; charset=utf-8"},
|
|
|
|
+"&token=${user.token}"
|
|
|
|
|
|
|
|
"&page=${(serviceRequests?.length ?? 0) ~/pageItemNumber}"
|
|
|
|
|
|
|
|
+search?.toSearchString() ?? ""
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
|
|
"Content-Type":"application/json; charset=utf-8"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
);
|
|
|
|
);
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
// client's request was successfully received
|
|
|
|
// client's request was successfully received
|
|
|
|
List requestsListJson = json.decode(utf8.decode(response.bodyBytes).replaceAll("\\", ""));
|
|
|
|
List requestsListJson =
|
|
|
|
List<ServiceRequest> _serviceRequestsPage = requestsListJson.map(
|
|
|
|
json.decode(utf8.decode(response.bodyBytes).replaceAll("\\", ""));
|
|
|
|
(request) => ServiceRequest.fromJson(request)).toList();
|
|
|
|
List<ServiceRequest> _serviceRequestsPage = requestsListJson
|
|
|
|
if(serviceRequests == null)
|
|
|
|
.map((request) => ServiceRequest.fromJson(request))
|
|
|
|
serviceRequests = [];
|
|
|
|
.toList();
|
|
|
|
serviceRequests.addAll(_serviceRequestsPage);
|
|
|
|
serviceRequests ??= [];
|
|
|
|
if(_serviceRequestsPage.length == pageItemNumber){
|
|
|
|
serviceRequests?.addAll(_serviceRequestsPage);
|
|
|
|
|
|
|
|
if (_serviceRequestsPage.length == pageItemNumber) {
|
|
|
|
nextPage = true;
|
|
|
|
nextPage = true;
|
|
|
|
}else{
|
|
|
|
} else {
|
|
|
|
nextPage = false;
|
|
|
|
nextPage = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
isLoading = false;
|
|
|
|
isLoading = false;
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
return response.statusCode;
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
} catch(error) {
|
|
|
|
|
|
|
|
isLoading = false;
|
|
|
|
isLoading = false;
|
|
|
|
stateCode = -1;
|
|
|
|
stateCode = -1;
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<ServiceRequest> getSingleServiceRequest({
|
|
|
|
Future<ServiceRequest> getSingleServiceRequest({
|
|
|
|
@required String requestId,
|
|
|
|
required String requestId,
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required Subtitle subtitle,
|
|
|
|
required Subtitle subtitle,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
String userData = '';
|
|
|
|
String userData = '';
|
|
|
|
if(user != null){
|
|
|
|
userData += "&uid=${user.id}";
|
|
|
|
userData += "&uid="+user.id;
|
|
|
|
userData += "&token=${user.token}";
|
|
|
|
userData += "&token="+user.token;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
response = await get(
|
|
|
|
response = await get(Uri.parse(
|
|
|
|
Uri.parse(
|
|
|
|
'$host${URLs.getSingleServiceRequest}?call_nid=$requestId$userData',
|
|
|
|
host+URLs.getSingleServiceRequest
|
|
|
|
));
|
|
|
|
+'?call_nid=$requestId'
|
|
|
|
} catch (error) {
|
|
|
|
'$userData',)
|
|
|
|
throw (HttpStatusManger.getStatusMessage(status: -1, subtitle: subtitle));
|
|
|
|
);
|
|
|
|
|
|
|
|
}catch(error){
|
|
|
|
|
|
|
|
throw(HttpStatusManger.getStatusMessage(
|
|
|
|
|
|
|
|
status: -1, subtitle: subtitle));
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300){
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
List jsonList = json.decode(utf8.decode(response.bodyBytes).replaceAll("\\", ""));
|
|
|
|
List jsonList =
|
|
|
|
List<ServiceRequest> _requests = jsonList.map((i) => ServiceRequest.fromJson(i)).toList();
|
|
|
|
json.decode(utf8.decode(response.bodyBytes).replaceAll("\\", ""));
|
|
|
|
return _requests[0];
|
|
|
|
List<ServiceRequest> requests =
|
|
|
|
}else{
|
|
|
|
jsonList.map((i) => ServiceRequest.fromJson(i)).toList();
|
|
|
|
throw(HttpStatusManger.getStatusMessage(
|
|
|
|
return requests[0];
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
throw (HttpStatusManger.getStatusMessage(
|
|
|
|
status: response.statusCode, subtitle: subtitle));
|
|
|
|
status: response.statusCode, subtitle: subtitle));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<int> createRequest ({
|
|
|
|
Future<int> createRequest({
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required ServiceRequest serviceRequest,
|
|
|
|
required ServiceRequest serviceRequest,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
|
|
|
|
|
|
|
|
var body = {
|
|
|
|
var body = {
|
|
|
|
"uid": user.id,
|
|
|
|
"uid": user.id,
|
|
|
|
"token": user.token ?? "",
|
|
|
|
"token": user.token ?? "",
|
|
|
|
@ -154,269 +141,233 @@ class ServiceRequestsProvider extends ChangeNotifier{
|
|
|
|
"priority": (serviceRequest.priority?.id).toString(),
|
|
|
|
"priority": (serviceRequest.priority?.id).toString(),
|
|
|
|
"defect_types": (serviceRequest.defectType?.id).toString(),
|
|
|
|
"defect_types": (serviceRequest.defectType?.id).toString(),
|
|
|
|
};
|
|
|
|
};
|
|
|
|
if(serviceRequest.audio != null){
|
|
|
|
body["audio"] = serviceRequest.audio;
|
|
|
|
body["audio"] = serviceRequest.audio;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
response = await post(
|
|
|
|
response = await post(
|
|
|
|
Uri.parse(
|
|
|
|
Uri.parse(host + URLs.createRequest),
|
|
|
|
host+URLs.createRequest),
|
|
|
|
body: body,
|
|
|
|
body: body,
|
|
|
|
|
|
|
|
);
|
|
|
|
);
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if(serviceRequests != null)
|
|
|
|
final serviceRequests = this.serviceRequests;
|
|
|
|
|
|
|
|
if (serviceRequests != null) {
|
|
|
|
serviceRequests.insert(
|
|
|
|
serviceRequests.insert(
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
ServiceRequest.fromJson(
|
|
|
|
ServiceRequest.fromJson(
|
|
|
|
json.decode(utf8.decode(response.bodyBytes))[0]
|
|
|
|
json.decode(utf8.decode(response.bodyBytes))[0],
|
|
|
|
)
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return response.statusCode;
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
} catch(error) {
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<int> createIssueReport ({
|
|
|
|
Future<int> createIssueReport({
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required Issue issue,
|
|
|
|
required Issue issue,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
Map<String,String> body = issue.toMap();
|
|
|
|
Map<String, String> body = issue.toMap();
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["token"] = user.token;
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
response = await post(
|
|
|
|
response = await post(
|
|
|
|
Uri.parse(host+URLs.createReport),
|
|
|
|
Uri.parse(host + URLs.createReport),
|
|
|
|
body: body,
|
|
|
|
body: body,
|
|
|
|
);
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return response.statusCode;
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
} catch(error) {
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<int> updateDate ({
|
|
|
|
Future<int> updateDate({
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required String newDate,
|
|
|
|
required String newDate,
|
|
|
|
@required Lookup employee,
|
|
|
|
required Lookup employee,
|
|
|
|
@required ServiceRequest request,
|
|
|
|
required ServiceRequest request,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
Map<String,String> body = {};
|
|
|
|
Map<String, String> body = {};
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["nid"] = request.id;
|
|
|
|
body["nid"] = request.id ?? '';
|
|
|
|
if(newDate != null) body["date"] = newDate;
|
|
|
|
body["date"] = newDate;
|
|
|
|
if(employee != null) body["ass_emp"] = employee.id.toString();
|
|
|
|
body["ass_emp"] = employee.id.toString();
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
response = await post(
|
|
|
|
response = await post(
|
|
|
|
Uri.parse(
|
|
|
|
Uri.parse(host + URLs.updateRequestDate),
|
|
|
|
host+URLs.updateRequestDate),
|
|
|
|
|
|
|
|
body: body,
|
|
|
|
body: body,
|
|
|
|
);
|
|
|
|
);
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
request.engineerName = employee.label;
|
|
|
|
request.engineerName = employee.label;
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return response.statusCode;
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
} catch(error) {
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<int> createServiceReport ({
|
|
|
|
Future<int> createServiceReport({
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required ServiceReport report,
|
|
|
|
required ServiceReport report,
|
|
|
|
@required ServiceRequest request,
|
|
|
|
required ServiceRequest request,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
Map<String,String> body = report.toMap();
|
|
|
|
Map<String, String> body = report.toMap();
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["job_id"] = request.id;
|
|
|
|
body["job_id"] = request.id ?? '';
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
response = await post(
|
|
|
|
response = await post(
|
|
|
|
Uri.parse(
|
|
|
|
Uri.parse(host + URLs.createServiceReport),
|
|
|
|
host+URLs.createServiceReport),
|
|
|
|
|
|
|
|
body: body,
|
|
|
|
body: body,
|
|
|
|
);
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
reset();
|
|
|
|
reset();
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return response.statusCode;
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
} catch(error) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<int> createDuplicatedReport ({
|
|
|
|
Future<int> createDuplicatedReport({
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required ServiceRequest request,
|
|
|
|
required ServiceRequest request,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
String userData = '';
|
|
|
|
String userData = '';
|
|
|
|
if(user != null){
|
|
|
|
userData += "&uid=${user.id}";
|
|
|
|
userData += "&uid="+user.id;
|
|
|
|
userData += "&token=${user.token}";
|
|
|
|
userData += "&token="+user.token;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
response = await get(
|
|
|
|
response = await get(
|
|
|
|
Uri.parse(
|
|
|
|
Uri.parse(
|
|
|
|
host+URLs.createDuplicatedReport
|
|
|
|
"$host${URLs.createDuplicatedReport}?nid=${request.id}$userData",
|
|
|
|
+"?nid=${request.id}"
|
|
|
|
),
|
|
|
|
+userData),
|
|
|
|
|
|
|
|
);
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
|
|
|
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
reset();
|
|
|
|
reset();
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return response.statusCode;
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
} catch(error) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<int> updateServiceReport ({
|
|
|
|
Future<int> updateServiceReport({
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required ServiceReport report,
|
|
|
|
required ServiceReport report,
|
|
|
|
@required ServiceRequest request,
|
|
|
|
required ServiceRequest request,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
Map<String,String> body = report.toMap();
|
|
|
|
Map<String, String> body = report.toMap();
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["job_id"] = request.id;
|
|
|
|
body["job_id"] = request.id ?? '';
|
|
|
|
body["report_id"] = request.reportID;
|
|
|
|
body["report_id"] = request.reportID ?? '';
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
response = await post(
|
|
|
|
response = await post(
|
|
|
|
Uri.parse(
|
|
|
|
Uri.parse(host + URLs.updateServiceReport),
|
|
|
|
host+URLs.updateServiceReport),
|
|
|
|
|
|
|
|
body: body,
|
|
|
|
body: body,
|
|
|
|
);
|
|
|
|
);
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
|
|
|
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
reset();
|
|
|
|
reset();
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return response.statusCode;
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
} catch(error) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<int> updateServiceReportTimer ({
|
|
|
|
Future<int> updateServiceReportTimer({
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required TimerModel timer,
|
|
|
|
required TimerModel timer,
|
|
|
|
@required ServiceRequest request,
|
|
|
|
required ServiceRequest request,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
Map<String,String> body = {};
|
|
|
|
Map<String, String> body = {};
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["uid"] = user.id;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["token"] = user.token;
|
|
|
|
body["job_id"] = request.id;
|
|
|
|
body["job_id"] = request.id ?? '';
|
|
|
|
body["start_time"] = (timer.startAt.millisecondsSinceEpoch / 1000).toStringAsFixed(0);
|
|
|
|
body["start_time"] =
|
|
|
|
body["end_time"] = (timer.endAt.millisecondsSinceEpoch / 1000).toStringAsFixed(0);
|
|
|
|
(timer.startAt.millisecondsSinceEpoch / 1000).toStringAsFixed(0);
|
|
|
|
body["working_hours"] = (timer.durationInSecond / 60 / 60).toStringAsFixed(5);
|
|
|
|
body["end_time"] =
|
|
|
|
body["report_id"] = request.reportID;
|
|
|
|
(timer.endAt.millisecondsSinceEpoch / 1000).toStringAsFixed(0);
|
|
|
|
try{
|
|
|
|
body["working_hours"] =
|
|
|
|
|
|
|
|
(timer.durationInSecond / 60 / 60).toStringAsFixed(5);
|
|
|
|
|
|
|
|
body["report_id"] = request.reportID ?? '';
|
|
|
|
|
|
|
|
try {
|
|
|
|
response = await post(
|
|
|
|
response = await post(
|
|
|
|
Uri.parse(
|
|
|
|
Uri.parse(host + URLs.updateServiceReport),
|
|
|
|
host+URLs.updateServiceReport),
|
|
|
|
|
|
|
|
body: body,
|
|
|
|
body: body,
|
|
|
|
);
|
|
|
|
);
|
|
|
|
//stateCode = response.statusCode;
|
|
|
|
//stateCode = response.statusCode;
|
|
|
|
|
|
|
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
// reset();
|
|
|
|
// reset();
|
|
|
|
// notifyListeners();
|
|
|
|
// notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return response.statusCode;
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
} catch(error) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<ServiceReport> getSingleServiceReport({
|
|
|
|
Future<ServiceReport> getSingleServiceReport({
|
|
|
|
@required String reportId,
|
|
|
|
required String reportId,
|
|
|
|
@required String host,
|
|
|
|
required String host,
|
|
|
|
@required User user,
|
|
|
|
required User user,
|
|
|
|
@required Subtitle subtitle,
|
|
|
|
required Subtitle subtitle,
|
|
|
|
}) async {
|
|
|
|
}) async {
|
|
|
|
String userData = '';
|
|
|
|
String userData = '';
|
|
|
|
if(user != null){
|
|
|
|
userData += "&uid=${user.id}";
|
|
|
|
userData += "&uid="+user.id;
|
|
|
|
userData += "&token=${user.token}";
|
|
|
|
userData += "&token="+user.token;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Response response;
|
|
|
|
Response response;
|
|
|
|
try{
|
|
|
|
try {
|
|
|
|
|
|
|
|
response = await get(Uri.parse(
|
|
|
|
response = await get(
|
|
|
|
'$host${URLs.getServiceReport}?report_id=$reportId$userData',
|
|
|
|
Uri.parse(
|
|
|
|
));
|
|
|
|
host+URLs.getServiceReport
|
|
|
|
} catch (error) {
|
|
|
|
+'?report_id=$reportId'
|
|
|
|
throw (HttpStatusManger.getStatusMessage(status: -1, subtitle: subtitle));
|
|
|
|
'$userData',)
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}catch(error){
|
|
|
|
|
|
|
|
throw(HttpStatusManger.getStatusMessage(
|
|
|
|
|
|
|
|
status: -1, subtitle: subtitle));
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300){
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
// If the call to the server was successful, parse the JSON.
|
|
|
|
return ServiceReport.fromJson(
|
|
|
|
return ServiceReport.fromJson(
|
|
|
|
json.decode(utf8.decode(response.bodyBytes)),reportId);
|
|
|
|
json.decode(utf8.decode(response.bodyBytes)), reportId);
|
|
|
|
}else{
|
|
|
|
} else {
|
|
|
|
throw(HttpStatusManger.getStatusMessage(
|
|
|
|
throw (HttpStatusManger.getStatusMessage(
|
|
|
|
status: response.statusCode, subtitle: subtitle));
|
|
|
|
status: response.statusCode, subtitle: subtitle));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|