Initial commit
This commit is contained in:
95
lib/controllers/edit_profile_controller.dart
Normal file
95
lib/controllers/edit_profile_controller.dart
Normal file
@@ -0,0 +1,95 @@
|
||||
import 'dart:io';
|
||||
|
||||
import 'package:driver/constant/constant.dart';
|
||||
import 'package:driver/constant/show_toast_dialog.dart';
|
||||
import 'package:driver/models/user_model.dart';
|
||||
import 'package:driver/models/zone_model.dart';
|
||||
import 'package:driver/utils/fire_store_utils.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter/services.dart';
|
||||
import 'package:get/get.dart';
|
||||
import 'package:image_picker/image_picker.dart';
|
||||
|
||||
class EditProfileController extends GetxController {
|
||||
RxBool isLoading = true.obs;
|
||||
Rx<UserModel> userModel = UserModel().obs;
|
||||
|
||||
Rx<TextEditingController> firstNameController = TextEditingController().obs;
|
||||
Rx<TextEditingController> lastNameController = TextEditingController().obs;
|
||||
Rx<TextEditingController> emailController = TextEditingController().obs;
|
||||
Rx<TextEditingController> phoneNumberController = TextEditingController().obs;
|
||||
Rx<TextEditingController> countryCodeController = TextEditingController(text: "+91").obs;
|
||||
|
||||
Rx<ZoneModel> selectedZone = ZoneModel().obs;
|
||||
RxList<ZoneModel> zoneList = <ZoneModel>[].obs;
|
||||
|
||||
@override
|
||||
void onInit() {
|
||||
getData();
|
||||
super.onInit();
|
||||
}
|
||||
|
||||
Future<void> getData() async {
|
||||
await FireStoreUtils.getZone().then((value) {
|
||||
if (value != null) {
|
||||
zoneList.value = value;
|
||||
}
|
||||
});
|
||||
|
||||
await FireStoreUtils.getUserProfile(FireStoreUtils.getCurrentUid()).then((value) {
|
||||
if (value != null) {
|
||||
userModel.value = value;
|
||||
firstNameController.value.text = userModel.value.firstName.toString();
|
||||
lastNameController.value.text = userModel.value.lastName.toString();
|
||||
emailController.value.text = userModel.value.email.toString();
|
||||
phoneNumberController.value.text = userModel.value.phoneNumber.toString();
|
||||
countryCodeController.value.text = userModel.value.countryCode.toString();
|
||||
profileImage.value = userModel.value.profilePictureURL ?? '';
|
||||
|
||||
for (var element in zoneList) {
|
||||
if (element.id == userModel.value.zoneId) {
|
||||
selectedZone.value = element;
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
isLoading.value = false;
|
||||
}
|
||||
|
||||
Future<void> saveData() async {
|
||||
ShowToastDialog.showLoader("Please wait".tr);
|
||||
if (Constant().hasValidUrl(profileImage.value) == false && profileImage.value.isNotEmpty) {
|
||||
profileImage.value = await Constant.uploadUserImageToFireStorage(
|
||||
File(profileImage.value),
|
||||
"profileImage/${FireStoreUtils.getCurrentUid()}",
|
||||
File(profileImage.value).path.split('/').last,
|
||||
);
|
||||
}
|
||||
|
||||
userModel.value.firstName = firstNameController.value.text;
|
||||
userModel.value.lastName = lastNameController.value.text;
|
||||
userModel.value.profilePictureURL = profileImage.value;
|
||||
userModel.value.zoneId = selectedZone.value.id;
|
||||
|
||||
await FireStoreUtils.updateUser(userModel.value).then((value) {
|
||||
ShowToastDialog.closeLoader();
|
||||
Get.back(result: true);
|
||||
});
|
||||
}
|
||||
|
||||
final ImagePicker _imagePicker = ImagePicker();
|
||||
RxString profileImage = "".obs;
|
||||
|
||||
Future pickFile({required ImageSource source}) async {
|
||||
try {
|
||||
XFile? image = await _imagePicker.pickImage(source: source);
|
||||
if (image == null) return;
|
||||
Get.back();
|
||||
profileImage.value = image.path;
|
||||
} on PlatformException catch (e) {
|
||||
ShowToastDialog.showToast("${"failed_to_pick".tr} : \n $e");
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user