всегда возвращается null setState () - PullRequest
0 голосов
/ 05 марта 2020

Я загружаю изображение в хранилище Firebase и загружаю URL, чтобы получить изображение позже. Я добавил скриншот и больше кода. При печати (url) работает нормально, а при передаче URL-адреса значения в функцию storenewuser сохраняет ноль

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);
    });
  }

База данных:

enter image description here

Хранение:

enter image description here

1 Ответ

3 голосов
/ 05 марта 2020

просто изменить

uploadPic();

на

await uploadPic();

:)

...