When I click to upload button firebase is giving me below error:
Uncaught FirebaseStorageError {code_: "storage/invalid-argument-count", message_: "Firebase Storage: Invalid argument count in
put
: Expected between 1 and 2 arguments, received 0.", serverResponse_: null, name_: "FirebaseError"}
function ImageUpload(username) {
const [caption, setCaption] = useState('');
const [image, setImage] = useState(null);
// const [url, setUrl] = useState("");
const [progress, setProgress] = useState(0);
const handleChange = (e) => {
if(e.target.files[0]){
setImage(e.target.files[0]); // setting current image
}
};
const handleUpload = () => {
const uploadTask = firebase.storage().ref(`images/${image.name}`).put();
uploadTask.on(
"state_changed",
(snapshot) => {
// progress bar
const progress = Math.round(
(snapshot.bytesTransferred / snapshot.totalBytes) * 100
);
setProgress(progress);
},
(error) => {
// err function
console.log(error);
alert(error.message);
},
() => {
storage
.ref("images")
.child(image.name)
.getDownloadURL()
.then(url => {
//upload img inside DB
db.collection("posts").add({
timestamp : firebase.firestore.FieldValue.serverTimestamp(),
caption : caption ,
imageUrl : url ,
username : username
});
setProgress(0);
setCaption('');
setImage(null);
});
}
)
}
return (
<div>
<progress value={progress} max="100" />
<input type="text" placeholder='enter a caption...'
onChange={event => setCaption(event.target.value)} value={caption}
/>
<input type="file" onChange={handleChange} />
<Button className="imageUpload__button" onClick={handleUpload}>
Upload
</Button>
</div>
)
}
export default ImageUpload