|
|
|
@ -8,13 +8,12 @@ import 'package:test_sa/models/device/device_transfer.dart';
|
|
|
|
|
import 'package:test_sa/models/device/device_transfer_info.dart';
|
|
|
|
|
import 'package:test_sa/models/user.dart';
|
|
|
|
|
|
|
|
|
|
class DeviceTransferProvider extends ChangeNotifier{
|
|
|
|
|
|
|
|
|
|
class DeviceTransferProvider extends ChangeNotifier {
|
|
|
|
|
// number of items call in each request
|
|
|
|
|
final pageItemNumber = 50;
|
|
|
|
|
|
|
|
|
|
//reset provider data
|
|
|
|
|
void reset(){
|
|
|
|
|
void reset() {
|
|
|
|
|
items = null;
|
|
|
|
|
nextPage = true;
|
|
|
|
|
stateCode = null;
|
|
|
|
@ -41,12 +40,11 @@ class DeviceTransferProvider extends ChangeNotifier{
|
|
|
|
|
/// return state code if request complete may be 200, 404 or 403
|
|
|
|
|
/// for more details check http state manager
|
|
|
|
|
/// lib\controllers\http_status_manger\http_status_manger.dart
|
|
|
|
|
Future<int> getRequests ({
|
|
|
|
|
Future<int> getRequests({
|
|
|
|
|
@required String host,
|
|
|
|
|
@required User user,
|
|
|
|
|
}) async {
|
|
|
|
|
if(isLoading == true)
|
|
|
|
|
return -2;
|
|
|
|
|
if (isLoading == true) return -2;
|
|
|
|
|
isLoading = true;
|
|
|
|
|
|
|
|
|
|
// isLoading = false;
|
|
|
|
@ -64,9 +62,9 @@ class DeviceTransferProvider extends ChangeNotifier{
|
|
|
|
|
// notifyListeners();
|
|
|
|
|
// return 200;
|
|
|
|
|
Response response;
|
|
|
|
|
try{
|
|
|
|
|
Map<String,dynamic> body = {};
|
|
|
|
|
body["pageNumber"] = (items?.length ?? 0) ~/pageItemNumber + 1;
|
|
|
|
|
try {
|
|
|
|
|
Map<String, dynamic> body = {};
|
|
|
|
|
body["pageNumber"] = (items?.length ?? 0) ~/ pageItemNumber + 1;
|
|
|
|
|
body["pageSize"] = pageItemNumber;
|
|
|
|
|
|
|
|
|
|
response = await ApiManager.instance.post(
|
|
|
|
@ -75,38 +73,35 @@ class DeviceTransferProvider extends ChangeNotifier{
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
|
if(stateCode >= 200 && stateCode < 300) {
|
|
|
|
|
if (stateCode >= 200 && stateCode < 300) {
|
|
|
|
|
// client's request was successfully received
|
|
|
|
|
List listJson = json.decode(response.body)["data"];
|
|
|
|
|
List<DeviceTransfer> itemsPage = listJson.map(
|
|
|
|
|
(request) => DeviceTransfer.fromJson(request)).toList();
|
|
|
|
|
List<DeviceTransfer> itemsPage = listJson.map((request) => DeviceTransfer.fromJson(request)).toList();
|
|
|
|
|
items ??= [];
|
|
|
|
|
items.addAll(itemsPage);
|
|
|
|
|
if(itemsPage.length == pageItemNumber){
|
|
|
|
|
if (itemsPage.length == pageItemNumber) {
|
|
|
|
|
nextPage = true;
|
|
|
|
|
}else{
|
|
|
|
|
} else {
|
|
|
|
|
nextPage = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
isLoading = false;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch(error) {
|
|
|
|
|
} catch (error) {
|
|
|
|
|
isLoading = false;
|
|
|
|
|
stateCode = -1;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> createRequest ({
|
|
|
|
|
Future<int> createRequest({
|
|
|
|
|
@required String host,
|
|
|
|
|
@required User user,
|
|
|
|
|
@required DeviceTransfer model,
|
|
|
|
|
}) async {
|
|
|
|
|
Map<String,dynamic> body = {
|
|
|
|
|
Map<String, dynamic> body = {
|
|
|
|
|
// "uid": user.id.toString(),
|
|
|
|
|
// "token": user.token ?? "",
|
|
|
|
|
"assetId": model.device.id ?? "",
|
|
|
|
@ -115,34 +110,23 @@ class DeviceTransferProvider extends ChangeNotifier{
|
|
|
|
|
"senderSiteId": model.receiver.client.id ?? "",
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Response response;
|
|
|
|
|
try{
|
|
|
|
|
response = await ApiManager.instance.post(
|
|
|
|
|
URLs.requestDeviceTransfer,
|
|
|
|
|
body: body
|
|
|
|
|
);
|
|
|
|
|
try {
|
|
|
|
|
response = await ApiManager.instance.post(URLs.requestDeviceTransfer, body: body);
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
if(items != null) {
|
|
|
|
|
items.insert(
|
|
|
|
|
0,
|
|
|
|
|
DeviceTransfer.fromJson(
|
|
|
|
|
json.decode(utf8.decode(response.bodyBytes))[0]
|
|
|
|
|
)
|
|
|
|
|
);
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
if (items != null) {
|
|
|
|
|
items.insert(0, DeviceTransfer.fromJson(json.decode(utf8.decode(response.bodyBytes))[0]));
|
|
|
|
|
notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch(error) {
|
|
|
|
|
} catch (error) {
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future<int> updateRequest ({
|
|
|
|
|
Future<int> updateRequest({
|
|
|
|
|
@required String host,
|
|
|
|
|
@required User user,
|
|
|
|
|
@required bool isSender,
|
|
|
|
@ -150,57 +134,49 @@ class DeviceTransferProvider extends ChangeNotifier{
|
|
|
|
|
@required DeviceTransfer oldModel,
|
|
|
|
|
@required DeviceTransferInfo newModel,
|
|
|
|
|
}) async {
|
|
|
|
|
|
|
|
|
|
Map<String,dynamic> body = {
|
|
|
|
|
Map<String, dynamic> body = {
|
|
|
|
|
"id": oldModel.id,
|
|
|
|
|
"assetId": oldModel.device.id ?? "",
|
|
|
|
|
"senderSiteId": oldModel.sender.client.id,
|
|
|
|
|
"destSiteId": oldModel.receiver.client.id,
|
|
|
|
|
"destDepartmentId": oldModel.receiver.department.id,
|
|
|
|
|
"destDepartmentId": oldModel.receiver.department.id,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
if(isSender){
|
|
|
|
|
body.addAll(
|
|
|
|
|
{
|
|
|
|
|
//"senderSiteId": newModel.client.id,
|
|
|
|
|
//"senderDepartmentId": newModel.department.id,
|
|
|
|
|
"senderAssignedEmployeeId": newModel.userId,
|
|
|
|
|
"senderMachineStatusId": newModel.status.id,
|
|
|
|
|
"senderComment": newModel.comment,
|
|
|
|
|
"senderWorkingHours": newModel.workingHours,
|
|
|
|
|
"senderTravelingHours": newModel.travelingHours,
|
|
|
|
|
"senderAttachmentName": "${DateTime.now().toIso8601String()}.png|${newModel.signature}",
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
}else{
|
|
|
|
|
body.addAll(
|
|
|
|
|
{
|
|
|
|
|
//"destSiteId": newModel.client.id,
|
|
|
|
|
//"destDepartmentId": newModel.department.id,
|
|
|
|
|
"receiverAssignedEmployeeId": newModel.userId,
|
|
|
|
|
"receiverMachineStatusId": newModel.status.id,
|
|
|
|
|
"receiverComment": newModel.comment,
|
|
|
|
|
"receiverWorkingHours": newModel.workingHours,
|
|
|
|
|
"receiverTravelingHours": newModel.travelingHours,
|
|
|
|
|
"receiverAttachmentName": "${DateTime.now().toIso8601String()}.png|${newModel.signature}",
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
if (isSender) {
|
|
|
|
|
body.addAll({
|
|
|
|
|
//"senderSiteId": newModel.client.id,
|
|
|
|
|
//"senderDepartmentId": newModel.department.id,
|
|
|
|
|
"senderAssignedEmployeeId": newModel.userId,
|
|
|
|
|
"senderMachineStatusId": newModel.status.id,
|
|
|
|
|
"senderComment": newModel.comment,
|
|
|
|
|
"senderWorkingHours": newModel.workingHours,
|
|
|
|
|
"senderTravelingHours": newModel.travelingHours,
|
|
|
|
|
"senderAttachmentName": "${DateTime.now().toIso8601String()}.png|${newModel.signature}",
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
body.addAll({
|
|
|
|
|
//"destSiteId": newModel.client.id,
|
|
|
|
|
//"destDepartmentId": newModel.department.id,
|
|
|
|
|
"receiverAssignedEmployeeId": newModel.userId,
|
|
|
|
|
"receiverMachineStatusId": newModel.status.id,
|
|
|
|
|
"receiverComment": newModel.comment,
|
|
|
|
|
"receiverWorkingHours": newModel.workingHours,
|
|
|
|
|
"receiverTravelingHours": newModel.travelingHours,
|
|
|
|
|
"receiverAttachmentName": "${DateTime.now().toIso8601String()}.png|${newModel.signature}",
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
body.addAll(newModel.toJson(isSender));
|
|
|
|
|
Response response;
|
|
|
|
|
try{
|
|
|
|
|
response = await ApiManager.instance.put(
|
|
|
|
|
URLs.updateDeviceTransfer,
|
|
|
|
|
body: body
|
|
|
|
|
);
|
|
|
|
|
try {
|
|
|
|
|
response = await ApiManager.instance.put(URLs.updateDeviceTransfer, body: body);
|
|
|
|
|
// response = await post(
|
|
|
|
|
// Uri.parse("$host${URLs.updateDeviceTransfer}/$requestId"),
|
|
|
|
|
// body: body,
|
|
|
|
|
// );
|
|
|
|
|
|
|
|
|
|
stateCode = response.statusCode;
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
reset();
|
|
|
|
|
// oldModel.fromDeviceTransfer(
|
|
|
|
|
// DeviceTransfer.fromJson(
|
|
|
|
@ -210,10 +186,8 @@ class DeviceTransferProvider extends ChangeNotifier{
|
|
|
|
|
notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
|
|
|
|
|
} catch(error) {
|
|
|
|
|
} catch (error) {
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|