|
|
|
|
@ -6,10 +6,9 @@ import 'package:test_sa/controllers/api_routes/api_manager.dart';
|
|
|
|
|
import 'package:test_sa/controllers/api_routes/urls.dart';
|
|
|
|
|
import 'package:test_sa/models/user.dart';
|
|
|
|
|
|
|
|
|
|
class UserProvider extends ChangeNotifier{
|
|
|
|
|
|
|
|
|
|
class UserProvider extends ChangeNotifier {
|
|
|
|
|
//reset provider data
|
|
|
|
|
void reset(){
|
|
|
|
|
void reset() {
|
|
|
|
|
_user = null;
|
|
|
|
|
ApiManager.instance.user = user;
|
|
|
|
|
_loading = false;
|
|
|
|
|
@ -25,7 +24,6 @@ class UserProvider extends ChangeNotifier{
|
|
|
|
|
notifyListeners();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// when login or register in-process _login = true
|
|
|
|
|
// when login or register is done or not start = false
|
|
|
|
|
bool _loading = false;
|
|
|
|
|
@ -41,30 +39,30 @@ class UserProvider 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> login ({
|
|
|
|
|
Future<int> login({
|
|
|
|
|
@required String host,
|
|
|
|
|
@required User user,
|
|
|
|
|
}) async {
|
|
|
|
|
if(_loading == true)
|
|
|
|
|
return -2;
|
|
|
|
|
if (_loading == true) return -2;
|
|
|
|
|
_loading = true;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
Response response;
|
|
|
|
|
try{
|
|
|
|
|
try {
|
|
|
|
|
response = await ApiManager.instance.post(
|
|
|
|
|
URLs.login,
|
|
|
|
|
body: await user.toLoginJson(),
|
|
|
|
|
URLs.login,
|
|
|
|
|
body: await user.toLoginJson(),
|
|
|
|
|
);
|
|
|
|
|
_loading = false;
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
// client's request was successfully received
|
|
|
|
|
_user = User.fromJson(jsonDecode(response.body));
|
|
|
|
|
ApiManager.instance.user = _user;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
}
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
} catch(error) {
|
|
|
|
|
} catch (error) {
|
|
|
|
|
_loading = false;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return -1;
|
|
|
|
|
@ -77,28 +75,27 @@ class UserProvider extends ChangeNotifier{
|
|
|
|
|
/// return state code if request complete may be 200, 404 or 403
|
|
|
|
|
/// for more details about state codes check http state manager
|
|
|
|
|
/// lib\controllers\http_status_manger\http_status_manger.dart
|
|
|
|
|
Future<int> register ({
|
|
|
|
|
Future<int> register({
|
|
|
|
|
@required String host,
|
|
|
|
|
@required User user,
|
|
|
|
|
}) async {
|
|
|
|
|
if(_loading == true)
|
|
|
|
|
return -2;
|
|
|
|
|
if (_loading == true) return -2;
|
|
|
|
|
_loading = true;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
Response response;
|
|
|
|
|
try{
|
|
|
|
|
try {
|
|
|
|
|
response = await ApiManager.instance.post(
|
|
|
|
|
URLs.register,
|
|
|
|
|
body: await user.toLoginJson(),
|
|
|
|
|
);
|
|
|
|
|
} catch(error) {
|
|
|
|
|
} catch (error) {
|
|
|
|
|
_loading = false;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
_loading = false;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
// client's request was successfully received
|
|
|
|
|
_user = User.fromJson(jsonDecode(utf8.decode(response.bodyBytes))[0]);
|
|
|
|
|
_user.hospital = user.hospital;
|
|
|
|
|
@ -114,31 +111,27 @@ class UserProvider extends ChangeNotifier{
|
|
|
|
|
/// return state code if request complete may be 200, 404 or 403
|
|
|
|
|
/// for more details about state codes check http state manager
|
|
|
|
|
/// lib\controllers\http_status_manger\http_status_manger.dart
|
|
|
|
|
Future<int> updateProfile ({
|
|
|
|
|
Future<int> updateProfile({
|
|
|
|
|
@required String host,
|
|
|
|
|
@required User user,
|
|
|
|
|
}) async {
|
|
|
|
|
if(_loading == true)
|
|
|
|
|
return -2;
|
|
|
|
|
if (_loading == true) return -2;
|
|
|
|
|
_loading = true;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
Response response;
|
|
|
|
|
|
|
|
|
|
Map<String,dynamic> jsonObject ={};
|
|
|
|
|
Map<String, dynamic> jsonObject = {};
|
|
|
|
|
jsonObject["uid"] = user.id;
|
|
|
|
|
jsonObject["token"] = user.token;
|
|
|
|
|
if(user.department.id != _user.department.id)
|
|
|
|
|
jsonObject["department"] = user.department.id;
|
|
|
|
|
if(user.whatsApp != _user.whatsApp)
|
|
|
|
|
jsonObject["whatsapp"] = user.whatsApp;
|
|
|
|
|
if(user.phoneNumber != _user.phoneNumber)
|
|
|
|
|
jsonObject["phone"] = user.phoneNumber;
|
|
|
|
|
try{
|
|
|
|
|
if (user.department.id != _user.department.id) jsonObject["department"] = user.department.id;
|
|
|
|
|
if (user.whatsApp != _user.whatsApp) jsonObject["whatsapp"] = user.whatsApp;
|
|
|
|
|
if (user.phoneNumber != _user.phoneNumber) jsonObject["phone"] = user.phoneNumber;
|
|
|
|
|
try {
|
|
|
|
|
response = response = await ApiManager.instance.post(
|
|
|
|
|
URLs.login,
|
|
|
|
|
body: jsonObject,
|
|
|
|
|
);
|
|
|
|
|
} catch(error) {
|
|
|
|
|
} catch (error) {
|
|
|
|
|
_loading = false;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
return -1;
|
|
|
|
|
@ -147,7 +140,7 @@ class UserProvider extends ChangeNotifier{
|
|
|
|
|
_loading = false;
|
|
|
|
|
notifyListeners();
|
|
|
|
|
|
|
|
|
|
if(response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
|
|
|
|
// client's request was successfully received
|
|
|
|
|
_user = User.fromJson(jsonDecode(utf8.decode(response.bodyBytes))[0]);
|
|
|
|
|
_user.hospital = user.hospital;
|
|
|
|
|
@ -157,5 +150,4 @@ class UserProvider extends ChangeNotifier{
|
|
|
|
|
}
|
|
|
|
|
return response.statusCode;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|