Sandeep Sharma
Sandeep Sharma

Reputation: 705

it's always return null setState()

I m uploading an image in firebase storage and downloading URL to retrieve image later. I have added Screenshot and more code. In print(url) working fine and when passing the value URL to storenewuser function it stores null

This is the upload function:
Future uploadPic() async{
    String filename = phoneNumber;
    StorageReference ref = FirebaseStorage.instance.ref().child("User Profile Image").child(filename);
    StorageUploadTask uploadTask = ref.putFile(_Image);
    var downUrl = await (await uploadTask.onComplete).ref.getDownloadURL();
    var url = downUrl.toString();
    print(url);
    if (!mounted) return;
    setState(() {
      ImageUrl=url;
    });
  }
SignUp and storing usersdata:
void Signup() async{
    if(_key.currentState.validate()){
      FirebaseAuth.instance.createUserWithEmailAndPassword(email: Email, password: Password).then((signedInUser){
        uploadPic();
        UserManagement().storeNewUser(Name,Email,phoneNumber,ImageUrl,RollNumber,Course,Semester,signedInUser.user, context);
      }).catchError((e){
        final snackBar = SnackBar(
          content: Text(e.message),
        );
        Scaffold.of(context).showSnackBar(snackBar);
        print(e);
      });
    }
    else{
      print("NULL");
    }
  }

storeNewUser(Name,Email/*,password*/,phonenumber,ImageUrl,rollnumber,course,sem,user,context){
    Firestore.instance.collection('/users').document(user.uid).setData({
      'Name' : Name,
      'Email' : Email,
      'Image Url' : ImageUrl,
      'Phone Number' : phonenumber,
      'Roll Number' : rollnumber,
      'College' : 'Siliguri Institute of Technology',
      'Course' : course,
      'Semester' : sem
    }).then((value){
        Navigator.of(context).pop();
        Navigator.pushReplacement(context, MaterialPageRoute(builder: (context) => SignUpCompletePage()));
    }).catchError((e){
      final snackBar = SnackBar(
        content: Text(e.message),
      );
      Scaffold.of(context).showSnackBar(snackBar);
    });
  }

Database:

enter image description here

Storage:

enter image description here

Upvotes: 0

Views: 98

Answers (1)

GJJ2019
GJJ2019

Reputation: 5172

just change

uploadPic();

to

await uploadPic();

:)

Upvotes: 3

Related Questions